.menu-product-description,
.menu-product-action {
	display: none;
}

.cpp-image-frame {
	background: #eef2f6;
	background: color-mix(in srgb, var(--restaurant-surface, #fff) 88%, #94a3b8);
	overflow: hidden;
	position: relative;
}

.cpp-image-frame:before,
.cpp-image-frame:after {
	content: "";
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.cpp-image-frame:before {
	animation: cppImageShimmer 1.45s ease-in-out infinite;
	background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,.46) 42%, transparent 70%);
	inset: 0;
	transform: translateX(-100%);
}

.cpp-image-frame:after {
	animation: cppImageSpin .82s linear infinite;
	border: 2px solid rgba(100,116,139,.22);
	border-top-color: var(--restaurant-button-color, #15ad96);
	border-radius: 999px;
	height: 22px;
	left: 50%;
	margin: -11px 0 0 -11px;
	top: 50%;
	width: 22px;
}

.cpp-image-frame.is-loaded:before,
.cpp-image-frame.is-loaded:after {
	opacity: 0;
	visibility: hidden;
}

.cpp-image-frame .cpp-lazy-image {
	opacity: 0;
	transition: opacity .24s ease, transform .24s ease;
}

.cpp-image-frame .cpp-lazy-image.cpp-image-loaded {
	opacity: 1;
}

@keyframes cppImageShimmer {
	100% { transform: translateX(100%); }
}

@keyframes cppImageSpin {
	to { transform: rotate(360deg); }
}

body[data-product-layout="grid2"] .list_menu section > .row,
body[data-product-layout="featured1"] .list_menu section > .row {
	display: grid !important;
	gap: 18px;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

body[data-product-layout="grid2"] .list_menu section > .row {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-product-layout="featured1"] .list_menu section > .row {
	grid-template-columns: minmax(0, 760px);
	justify-content: center;
}

body[data-product-layout="grid2"] .list_menu .menu-product-cell,
body[data-product-layout="featured1"] .list_menu .menu-product-cell {
	float: none !important;
	max-width: none !important;
	padding: 0 !important;
	width: auto !important;
}

body[data-product-layout="grid2"] .menu-product-card,
body[data-product-layout="featured1"] .menu-product-card {
	background: var(--restaurant-surface, #fff) !important;
	border: 1px solid var(--restaurant-border, #e2e8f0) !important;
	border-radius: var(--restaurant-card-radius, 16px) !important;
	box-shadow: var(--restaurant-card-shadow, 0 12px 30px rgba(15, 23, 42, .07)) !important;
	display: flex !important;
	flex-direction: column;
	height: 100%;
	margin: 0 !important;
	overflow: hidden;
	padding: 0 0 16px !important;
	transition: border-color .18s ease, transform .18s ease !important;
}

body[data-product-layout="grid2"] .menu-product-card {
	height: auto;
}

body[data-product-layout="grid2"] .menu-product-card:hover,
body[data-product-layout="featured1"] .menu-product-card:hover {
	border-color: var(--restaurant-button-color, #15ad96) !important;
	transform: translateY(-2px);
}

body[data-product-layout="grid2"] .menu-product-card figure,
body[data-product-layout="featured1"] .menu-product-card figure {
	background: color-mix(in srgb, var(--restaurant-surface, #fff) 92%, #94a3b8);
	border: 0 !important;
	border-radius: 0 !important;
	height: auto !important;
	inset: auto !important;
	margin: 0 0 15px !important;
	overflow: hidden !important;
	position: relative !important;
	right: auto !important;
	top: auto !important;
	width: 100% !important;
}

body[data-product-layout="grid2"] .menu-product-card figure {
	aspect-ratio: 1 / 1;
}

body[data-product-layout="featured1"] .menu-product-card figure {
	aspect-ratio: 16 / 11;
}

body[data-product-layout="grid2"] .menu-product-card figure img,
body[data-product-layout="featured1"] .menu-product-card figure img {
	border-radius: 0 !important;
	height: 100% !important;
	object-fit: cover !important;
	width: 100% !important;
}

body[data-product-layout="grid2"] .menu-product-card h3,
body[data-product-layout="featured1"] .menu-product-card h3,
body[data-product-layout="grid2"] .menu-product-card > strong,
body[data-product-layout="featured1"] .menu-product-card > strong,
body[data-product-layout="grid2"] .menu-product-card > span,
body[data-product-layout="featured1"] .menu-product-card > span,
body[data-product-layout="grid2"] .menu-product-description,
body[data-product-layout="featured1"] .menu-product-description {
	margin-left: 16px !important;
	margin-right: 16px !important;
}

body[data-product-layout="grid2"] .menu-product-card h3,
body[data-product-layout="featured1"] .menu-product-card h3 {
	color: var(--restaurant-title, #0b1f33) !important;
	font-weight: 750 !important;
	line-height: 1.2;
	margin-bottom: 7px !important;
}

body[data-product-layout="grid2"] .menu-product-card h3 {
	font-size: 17px !important;
}

body[data-product-layout="featured1"] .menu-product-card h3 {
	font-size: 24px !important;
}

body[data-product-layout="grid2"] .menu-product-description,
body[data-product-layout="featured1"] .menu-product-description {
	color: var(--restaurant-muted, #64748b) !important;
	display: -webkit-box;
	line-height: 1.45;
	overflow: hidden;
	-webkit-box-orient: vertical;
}

body[data-product-layout="grid2"] .menu-product-description {
	font-size: 13px;
	margin-bottom: 12px;
	-webkit-line-clamp: 2;
}

body[data-product-layout="featured1"] .menu-product-description {
	font-size: 15px;
	margin-bottom: 18px;
	-webkit-line-clamp: 3;
}

body[data-product-layout="grid2"] .menu-product-card > strong,
body[data-product-layout="featured1"] .menu-product-card > strong {
	color: var(--restaurant-title, #0b1f33) !important;
	font-weight: 850 !important;
}

body[data-product-layout="grid2"] .menu-product-card > span,
body[data-product-layout="featured1"] .menu-product-card > span {
	align-self: flex-start;
	font-size: 11px !important;
	margin-top: 8px !important;
}

body[data-product-layout="grid2"] .menu-product-card > span:empty,
body[data-product-layout="featured1"] .menu-product-card > span:empty {
	display: none !important;
}

body[data-product-layout="grid2"] .menu-product-action,
body[data-product-layout="featured1"] .menu-product-action {
	align-items: center;
	align-self: stretch;
	background: var(--restaurant-button-color, #15ad96);
	border-radius: var(--restaurant-button-radius, 10px);
	color: var(--restaurant-button-text-color, #fff);
	display: flex;
	font-size: 13px;
	font-weight: 800;
	gap: 7px;
	justify-content: center;
	margin: auto 16px 0;
	min-height: 40px;
	padding: 9px 12px;
}

body[data-product-layout="grid2"] .menu-product-action {
	margin: 12px 11px 0 !important;
}

body[data-product-layout="featured1"] .menu-product-action {
	align-self: flex-end;
	margin: 12px 16px 0 auto !important;
	min-width: 132px;
	width: fit-content;
}

@media (max-width: 767px) {
	body[data-product-layout="grid2"] .list_menu section > .row {
		gap: 10px;
	}

	body[data-product-layout="grid2"] .menu-product-card {
		padding-bottom: 12px !important;
	}

	body[data-product-layout="grid2"] .menu-product-card h3,
	body[data-product-layout="grid2"] .menu-product-card > strong,
	body[data-product-layout="grid2"] .menu-product-card > span,
	body[data-product-layout="grid2"] .menu-product-description {
		margin-left: 11px !important;
		margin-right: 11px !important;
	}

	body[data-product-layout="grid2"] .menu-product-card h3 {
		font-size: 15px !important;
	}

	body[data-product-layout="grid2"] .menu-product-description {
		font-size: 12px;
	}

	body[data-product-layout="grid2"] .menu-product-action {
		font-size: 12px;
		margin-left: 11px;
		margin-right: 11px;
		min-height: 37px;
	}

	body[data-product-layout="featured1"] .list_menu section > .row {
		gap: 14px;
	}

	body[data-product-layout="featured1"] .menu-product-card figure {
		aspect-ratio: 1 / 1;
	}

	body[data-product-layout="featured1"] .menu-product-card h3 {
		font-size: 21px !important;
	}
}
