/* ============================================================
   PAGE RESET
   ============================================================ */

body.casamore-restaurant-page {
	--casamore-premium-top-space: 0 !important;
	--casamore-premium-bottom-space: 0 !important;
	background: #ffffff;
	color: #171310;
}

.casamore-restaurant-page .site-content,
.casamore-restaurant-page .entry-content,
.casamore-restaurant-page .ast-article-single {
	background: transparent;
}

.casamore-restaurant-page .site-content > .ast-container {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.casamore-restaurant-page .site-content,
.casamore-restaurant-page .site-main,
.casamore-restaurant-page .content-area,
.casamore-restaurant-page #primary {
	margin-top: 0 !important;
	padding-top: 0;
	padding-bottom: 0;
}

.casamore-restaurant-page .entry-content {
	max-width: none;
	margin: 0 !important;
	padding: 0;
}

.casamore-restaurant-page .entry-content > .casamore-restaurant.alignfull,
.casamore-restaurant-page .entry-content[data-ast-blocks-layout="true"] > .casamore-restaurant.alignfull {
	position: relative;
	right: 50%;
	left: 50%;
	width: 100vw !important;
	max-width: 100vw !important;
	margin-right: -50vw !important;
	margin-left: -50vw !important;
	padding-right: 0 !important;
	padding-left: 0 !important;
}

@supports (width: 100dvw) {
	.casamore-restaurant-page .entry-content > .casamore-restaurant.alignfull,
	.casamore-restaurant-page .entry-content[data-ast-blocks-layout="true"] > .casamore-restaurant.alignfull {
		width: 100dvw !important;
		max-width: 100dvw !important;
		margin-right: -50dvw !important;
		margin-left: -50dvw !important;
	}
}

.casamore-restaurant-page .entry-header,
.casamore-restaurant-page .entry-title,
.casamore-restaurant-page .ast-single-entry-banner,
.casamore-restaurant-page .ast-page-title-bar {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* ============================================================
   WRAPPER
   ============================================================ */

.casamore-restaurant {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0 0 clamp(3rem, 5vw, 4.5rem) !important;
	overflow: hidden;
}

.casamore-restaurant *,
.casamore-restaurant *::before,
.casamore-restaurant *::after {
	box-sizing: border-box;
}

.casamore-restaurant :where(.wp-block-group, .wp-block-columns, .wp-block-column, .wp-block-image, .wp-block-heading, p, figure) {
	margin: 0;
}

.casamore-restaurant :where(img) {
	display: block;
	width: 100%;
}

.casamore-restaurant__section,
.casamore-restaurant__menu {
	width: min(calc(100% - 48px), 1400px);
	margin-left: auto;
	margin-right: auto;
}

/* ============================================================
   HERO
   ============================================================ */

.casamore-restaurant__hero {
	width: 100%;
	max-width: 100%;
	margin: 0;
	line-height: 0;
	position: relative;
}
.casamore-restaurant__hero::after {
	content: "RESTAURANT & BAR";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	
	color: white;
	font-family: "Oswald", sans-serif;
	font-size: clamp(2rem, 5vw, 4rem);
	font-weight: 400;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: center;

	text-shadow: 0 2px 10px rgba(0,0,0,0.25);
}
.casamore-restaurant__hero img {
	width: 100%;
	height: auto;
	aspect-ratio: 2.15 / 1;
	object-fit: cover;
	object-position: center;
}

/* ============================================================
   INTRO
   ============================================================ */

.casamore-restaurant__section--intro {
	padding-top: 1rem;
	padding-bottom: clamp(56px, 7vw, 92px);
}

.casamore-restaurant__intro-grid.wp-block-columns {
	display: grid !important;
	grid-template-columns: 230px minmax(0, 1fr);
	gap: clamp(58px, 6.8vw, 98px);
	align-items: start;
	flex-wrap: unset;
}

.casamore-restaurant__intro-grid .wp-block-column {
	flex-basis: unset !important;
	max-width: none !important;
}

.casamore-restaurant__title.wp-block-heading {
	margin: 0 !important;
	font-family: "Oswald", sans-serif;
	font-size: clamp(2.3rem, 4.3vw, 3.9rem) !important;
	font-weight: 400 !important;
	line-height: 1.02 !important;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: #171310 !important;
}

.casamore-restaurant__intro-copy-col {
	padding-top: clamp(52px, 5.6vw, 68px);
}

.casamore-restaurant__copy {
	max-width: 50rem;
	font-family: "Oswald", sans-serif;
	font-size: clamp(0.96rem, 1.16vw, 1.02rem);
	font-weight: 400;
	line-height: 1.55;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #171310;
}

/* ============================================================
   SCENES
   ============================================================ */

.casamore-restaurant__scene {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-bottom: clamp(2.8rem, 6vw, 4.8rem);
	overflow: visible;
}

.casamore-restaurant__scene-grid.wp-block-columns {
	display: grid !important;
	width: 100%;
	max-width: 100%;
	margin: 0 !important;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	align-items: stretch;
	flex-wrap: unset;
	overflow: hidden;
}

.casamore-restaurant__scene-grid--left {
	grid-template-columns: 1fr 1fr;
}

.casamore-restaurant__scene-grid .wp-block-column {
	flex-basis: unset !important;
	max-width: none !important;
}

.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-media {
	order: 1;
}

.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-copy {
	order: 2;
}

.casamore-restaurant__scene-copy {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	padding-top: clamp(36px, 5vw, 64px);
	padding-bottom: clamp(36px, 5vw, 64px);
}

.casamore-restaurant__scene-media {
	display: flex;
	overflow: hidden;
}

.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-copy {
	padding-left: clamp(24px, 5vw, 80px);
	padding-right: clamp(28px, 4vw, 56px);
}

.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-media {
	justify-content: flex-end;
}

.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-copy {
	padding-left: clamp(28px, 4vw, 56px);
	padding-right: clamp(24px, 5vw, 80px);
}

.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-media {
	justify-content: flex-start;
}

.casamore-restaurant__scene-title.wp-block-heading {
	margin: 0 0 1.15rem !important;
	font-family: "Oswald", sans-serif;
	font-size: clamp(2rem, 3.7vw, 3.2rem) !important;
	font-weight: 400 !important;
	line-height: 1.02 !important;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: #171310 !important;
}

.casamore-restaurant__scene-text {
	max-width: 22rem;
	font-family: "Courier Prime", monospace;
	font-size: clamp(0.9rem, 1.05vw, 0.98rem);
	line-height: 1.5;
	color: #171310;
}

.casamore-restaurant__scene-image {
	width: 100%;
	max-width: 100%;
	margin: 0;
	height: 100%;
}

.casamore-restaurant__scene-image img {
	width: 100%;
	height: 100%;
	min-height: clamp(420px, 34vw, 560px);
	object-fit: cover;
	object-position: center;
}

.casamore-restaurant__scene-image--patio img,
.casamore-restaurant__scene-image--dolce img,
.casamore-restaurant__scene-image--gioia img,
.casamore-restaurant__scene-image--cabanon img {
	aspect-ratio: 1.48 / 1;
}

/* ============================================================
   MENU
   ============================================================ */

.casamore-restaurant__menu {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-top: clamp(2rem, 5vw, 2.8rem);
}

.casamore-restaurant__menu-round {
	width: clamp(150px, 18vw, 210px);
	margin: 0 auto;
}

.casamore-restaurant__menu-round img {
	aspect-ratio: 1 / 1;
	border-radius: 999px;
	object-fit: cover;
	object-position: center;
}

.casamore-restaurant__menu-title {
	margin-top: 1rem !important;
	font-family: "Oswald", sans-serif;
	font-size: clamp(1rem, 1.4vw, 1.18rem);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: #171310;
}

.casamore-restaurant__menu-list {
	width: min(100%, 540px);
	margin-top: 2.6rem;
}

.casamore-restaurant__menu-section {
	margin-top: 2rem !important;
	margin-bottom: 1rem !important;
	font-family: "Oswald", sans-serif;
	font-size: clamp(1rem, 1.4vw, 1.18rem);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: #171310;
}

.casamore-restaurant__menu-list > .casamore-restaurant__menu-section:first-child {
	margin-top: 0 !important;
}

.casamore-restaurant__menu-item {
	font-family: "Courier Prime", monospace;
	font-size: 0.92rem;
	line-height: 1.36;
	color: #171310;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 900px) {
	.casamore-restaurant__section,
	.casamore-restaurant__menu {
		width: min(100% - 2.5rem, 920px);
	}

	.casamore-restaurant__intro-grid.wp-block-columns {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}

	.casamore-restaurant__intro-copy-col {
		padding-top: 0;
		padding-bottom: 0;
		padding-left: 0;
		padding-right: 0;
	}

	.casamore-restaurant__scene {
		width: 100vw;
		max-width: 100vw;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		padding-bottom: 2.5rem;
	}

	.casamore-restaurant__scene-grid.wp-block-columns,
	.casamore-restaurant__scene-grid--left {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.casamore-restaurant__scene-copy,
	.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-copy,
	.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-copy {
		width: min(100% - 2.5rem, 920px);
		margin-left: auto;
		margin-right: auto;
		padding-top: 2rem;
		padding-bottom: 1.5rem;
		padding-left: 0;
		padding-right: 0;
	}

	.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-copy,
	.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-copy {
		order: 1;
	}

	.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-media,
	.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-media {
		order: 2;
	}

	.casamore-restaurant__scene-image,
	.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-image,
	.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-image {
		width: 100%;
		margin-left: 0;
		margin-right: 0;
		height: auto;
	}

	.casamore-restaurant__scene-image img {
		min-height: 0;
	}

	.casamore-restaurant__copy,
	.casamore-restaurant__scene-text,
	.casamore-restaurant__menu-list {
		max-width: none;
	}
}

@media (max-width: 600px) {
	.casamore-restaurant__section,
	.casamore-restaurant__menu {
		width: min(100% - 2rem, 920px);
	}

	.casamore-restaurant__hero img {
		aspect-ratio: 1.58 / 1;
	}

	.casamore-restaurant__section--intro {
		padding-top: 2rem;
		padding-bottom: 2.8rem;
	}

	.casamore-restaurant__scene {
		padding-bottom: 2.8rem;
	}

	.casamore-restaurant__scene-copy,
	.casamore-restaurant__scene-grid--left .casamore-restaurant__scene-copy,
	.casamore-restaurant__scene-grid--right .casamore-restaurant__scene-copy {
		width: min(100% - 2rem, 920px);
		padding-top: 1.6rem;
		padding-bottom: 1.25rem;
	}

	.casamore-restaurant__copy {
		font-size: 0.9rem;
		line-height: 1.52;
	}

	.casamore-restaurant__scene-title.wp-block-heading {
		font-size: clamp(1.9rem, 9vw, 2.8rem) !important;
	}

	.casamore-restaurant__scene-text,
	.casamore-restaurant__menu-item,
	.casamore-restaurant__menu-section {
		font-size: 0.88rem;
	}
}
