/* 
 * use meal-card-page = mcp  class to overwrite some bootstrap styles & variables etc.
*/
.meal-card-page {
	--semantic-neutral-800: #27272a;
	--semantic-brand-500: #e40505;
	--semantic-neutral-300: #d4d4d8;
	--semantic-neutral-0: #fff;
	--semantic-neutral-400: #a1a1aa;
	--semantic-neutral-100: #f4f4f5;
	--semantic-neutral-200: #e4e4e7;
	--semantic-brand-50: #fff5f5;
	--semantic-neutral-600: #52525b;
	--text-placeholder: #71717a;
	--border-border-primary: #d4d4d8;
	--semantic-sky-600: #0284c7;

	color: #000;
	font-size: 0.9375rem;
	font-weight: 400;
	line-height: 150%;
}

.meal-card-page p,
h1,
h2,
h3,
h4,
ol,
ul {
	margin: 0;
}

.meal-card-hero {
	text-align: center;
}

.meal-card-hero-ctr {
	padding-bottom: 7.5rem;
	max-width: 1052px;
	margin: 0 auto;
	border-radius: 1rem;
	box-shadow: 0 100px 100px 0 rgba(228, 5, 5, 0.05) inset;
}

.meal-card-hero-wrapper {
	padding: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2rem;
}

.mcp-hero-img {
	display: block;
	max-width: 100%;
	height: auto;
	/* aspect-ratio: 310 / 237; */
}

.mcp-hero-content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	max-width: 600px;
}

.mcp-hero-meta {
	color: var(--semantic-neutral-800);
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 120%;
}

.mcp-hero-title {
	color: var(--semantic-brand-500);
	font-size: 1.875rem;
	font-weight: 600;
	line-height: 126.667%;
}

.mcp-hero-cta {
	width: clamp(145px, 100%, 222px);
}

.mcp-btn {
	background: var(--semantic-brand-500);
	color: #fff;
	display: flex;
	padding: 14px 20px;
	justify-content: center;
	align-items: center;
	gap: 8px;
	border-radius: 8px;
	-webkit-font-smoothing: inherit;
	-moz-osx-font-smoothing: inherit;
	-webkit-appearance: none;
	cursor: pointer;
	font: inherit;
	border: none;
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 150%;
}

.mcp-btn:hover {
	opacity: 0.9;
}

.mcp-btn:focus {
	outline: none;
}

/* * Steps */

.mcp-embla-viewport {
	overflow: hidden;
}

.mcp-embla-container {
	display: flex;
	touch-action: pan-y pinch-zoom;
	margin-inline-start: -1rem;
}

.mcp-embla-slide {
	flex: 0 0 80%;
	min-width: 0;
	padding-inline-start: 1rem;
	display: flex;
}

.mcp-steps-item {
	width: 100%;
	/* min-height: 355px; */
	border-radius: 0.75rem;
	border: 1px solid var(--semantic-neutral-300);
	background: var(--semantic-neutral-0);
	display: flex;
	padding: 1.5rem;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.mcp-steps-item-title {
	color: var(--semantic-neutral-400);
	text-align: center;
	font-size: 1.0625rem;
	font-weight: 600;
	line-height: 150%;
	margin-block-end: 2rem;
}

.mcp-steps-item-img {
	max-width: 100%;
	width: 88px;
	height: auto;
	margin-block-end: 1.5rem;
}

.mcp-item-desc {
	margin-block-start: auto !important;
}

/* * Corporate */

.meal-card-corporate {
	transform: translateY(-1.5rem);
}

.meal-card-corporate-ctr {
	max-width: 1052px;
	margin: 0 auto;
	position: relative;
	height: 644px;
	border-radius: 1rem;
	background: url("/web/img/meal-card/corporate-bg.webp");
	background-repeat: no-repeat;
	background-size: cover;
	color: var(--semantic-neutral-0);
	text-align: center;
	padding-block-start: 7.5rem;
	padding-inline: 1rem;
}

.mcp-corporate-img {
	position: absolute;
	left: 50%;
	top: 0;
	transform: translate(-50%, -50%);
}

.mcp-corporate-title {
	font-size: 1.875rem;
	font-weight: 600;
	line-height: 126%;
	margin-block-end: 2rem;
}

.mcp-corporate-tabs {
	display: flex;
}

.mcp-corporate-tabs-btn {
	margin-block-end: 1.5rem;
	flex: 1;
	border: 0.853px solid var(--semantic-brand-500);
	background: transparent;
	-webkit-font-smoothing: inherit;
	-moz-osx-font-smoothing: inherit;
	-webkit-appearance: none;
	cursor: pointer;
	font: inherit;
	color: inherit;
	padding: 10.2px;
}

.mcp-corporate-tabs-btn.active {
	background: var(--semantic-brand-500);
}

.mcp-corporate-tabs-btn:first-child {
	border-right: 0;
	border-top-left-radius: 13.7px;
	border-bottom-left-radius: 13.7px;
}

.mcp-corporate-tabs-btn:last-child {
	border-left: 0;
	border-top-right-radius: 13.7px;
	border-bottom-right-radius: 13.7px;
}

.mcp-corporate-tabs-content {
	display: none;
	padding-block: 1.25rem;
}

.mcp-corporate-tabs-content.active {
	display: block;
}

.mcp-tabs-icon {
	margin-block-end: 1.5rem;
}

.mcp-tabs-content-items {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.mcp-tabs-content-item {
	text-align: center;
	padding: 12px 26px;
	border-radius: 43px;
	border: 1px solid var(--semantic-neutral-100);
}

.mcp-tabs-content-title {
	display: none;
	font-size: 1.875rem;
	font-weight: 500;
	line-height: 126.667%;
}

/* * Mobile App */
.meal-card-mobile {
	padding: 37px 20px 62px;
	text-align: center;
}

.meal-card-mobile-ctr {
	max-width: 600px;
	margin: 0 auto;
}

.mcp-mobile-img {
	display: block;
	max-width: 100%;
	height: auto;
	margin: 0 auto 2rem;
}

.mcp-mobile-title {
	margin-block-end: 1rem;
	font-size: 1.875rem;
	font-weight: 600;
	line-height: 126.667%;
}

.mcp-mobile-title span {
	color: var(--semantic-brand-500);
}

p.mcp-mobile-desc {
	margin-block-end: 62px;
}

/* * Form */

.meal-card-form {
	display: flex;
	padding: 20px;
	flex-direction: column;
	gap: 24px;
	border-radius: 12px;
	border: 1px solid var(--semantic-neutral-200);
	background: linear-gradient(0deg, #fff 53.45%, var(--semantic-brand-50) 100%);
	text-align: left;
}

.mcf-title {
	display: flex;
	align-items: center;
	gap: 12px;
	color: var(--semantic-brand-500);
	font-size: 1.0625rem;
	font-weight: 600;
	line-height: 150%;
}

.mcf-fields {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	column-gap: 1.25rem;
	row-gap: 1rem;
}

.mcf-consent {
	display: grid;
	gap: 1.5rem;
}

.mcf-fields .spanned {
	grid-column-start: span 2;
}

.mcf-required-sign {
	color: var(--semantic-brand-500);
}

/* 
* Overwrite bootstrap form elements
*/
.meal-card-form .form-control::placeholder,
.form-select:invalid,
.form-label,
.form-check-label {
	font-weight: 400;
	font-size: 0.9375rem;
	line-height: 150%;
	opacity: 1;
}

.meal-card-form .form-control::placeholder {
	color: var(--text-placeholder);
}

.career-detail-form .form-select:invalid {
	color: var(--text-placeholder);
}

.meal-card-form .form-label {
	color: var(--semantic-neutral-600);
	margin-block-end: 0.75rem;
}

.meal-card-form .form-control,
.form-select {
	--bs-border-radius: 0.5rem;
	--bs-border-color: var(--border-border-primary);
	padding: 13px 16px;
}

.meal-card-form .form-check {
	margin-bottom: 0;
}

.meal-card-form .form-check .invalid-feedback {
	margin-inline-start: 0.75rem;
}

.meal-card-form .form-check-label {
	margin-inline-start: 0.75rem;
}

.meal-card-form .form-check-label a {
	color: var(--semantic-sky-600);
}
.meal-card-form .form-check-input {
	--bs-border-color: var(--border-border-primary);
	border-radius: 6px;
	width: 1.25rem;
	height: 1.25rem;
	margin-top: 2px;
}
.meal-card-form .form-check-input:checked {
	background-color: var(--semantic-brand-500);
}

/* * DESKTOP */

@media (min-width: 992px) {
	.mcp-hero-meta {
		font-size: 1.25rem;
	}

	.mcp-hero-title {
		font-size: 2.25rem;
	}

	.meal-card-page {
		font-size: 17px;
	}

	.meal-card-steps {
		padding-inline: 2rem;
		padding-block-end: 7.5rem;
	}

	.mcp-steps-item-img {
		width: 124px;
	}

	.mcp-hero-img {
		/* aspect-ratio: 780 / 383; */
		width: 780px;
	} 

	.mcp-embla-viewport {
		padding-inline: 2rem;
	}

	.mcp-embla-slide {
		flex: 0 0 calc(100% / 3);
	}

	.meal-card-corporate-ctr {
		height: 675px;
	}

	.mcp-corporate-tabs {
		display: none;
	}

	.mcp-corporate-tabs-content {
		display: block;
	}

	.mcp-tabs-content-title {
		display: block;
		margin-block-end: 1.5rem;
	}

	.mcp-tabs-separator {
		padding-inline: 72px;
		position: relative;
	}

	.mcp-separator-line {
		background: #fff;
		width: 1px;
		height: 100%;
	}

	.mcp-separator-icon {
		position: absolute;
		top: 117px;
		transform: translateX(-50%);
	}
}
