@import url("https://fonts.googleapis.com/css2?family=Playfair:ital,opsz,wght@0,5..1200,300..900;1,5..1200,300..900&display=swap");

.qodef-page-title {
	display: none;
	height: 0;
}

.footer-width-fixer {
	width: 100%;
	display: none;
}

#qodef-page-inner {
	position: relative;
	padding: 0;
	width: 100%;
}

.wizardSection .siteContainer {
	width: 100%;
	max-width: 1318px;
	margin: 0 auto;
}

#wizard-intro {
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/wizard-intro-bg.png");
	background-position: bottom;
	background-size: contain;
	background-repeat: no-repeat;
}

.wizardWrapper {
	text-align: center;
}

.wizard-title-wrapper {
	width: 100%;
	max-width: 835px;
	margin: 0 auto;
	position: relative;
	padding: 76px 0 222px;
}

.wizard-title-wrapper::after {
	content: "";
	position: absolute;
	top: 84px;
	left: -300px;
	width: 315px;
	height: 143px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/Group-1.png");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizard-title-wrapper::before {
	content: "";
	position: absolute;
	top: 84px;
	right: -300px;
	width: 335px;
	height: 158px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/Group-2.png");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizard-title-wrapper h1 {
	font-weight: 400;
	font-style: Italic;
	font-size: 45px;
	line-height: 54px;
	letter-spacing: 0.9px;
	text-align: center;
	vertical-align: middle;
	color: #000000;
	margin: 0 0 0;
	padding: 0 30px 92px 30px;
	position: relative;
}

.wizard-title-wrapper h1::after {
	content: "";
	position: absolute;
	bottom: 45px;
	left: 0;
	right: 0;
	margin: 0 auto;
	width: 97px;
	height: 29px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/SVG_mask-group.png");
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
}

.wizard-title-wrapper p {
	font-weight: 300;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
	color: #7a7a7a;
	margin: 0 0 79px;
}

#wizardStart {
	font-family: "Playfair", serif;
	font-weight: 500;
	font-style: Italic;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: 0.9px;
	text-align: center;
	vertical-align: middle;
	color: #000;
}

.wizardPage {
	display: none;
}

.wizardPage.is-active {
	display: block;
}

.wizardSteps {
	display: flex;
	justify-content: center;
	gap: 108px;
	margin-bottom: 50px;
}

.wizardStep {
	width: 40px;
	height: 40px;
	cursor: not-allowed;
	opacity: 0.4;
	transition: 0.3s;
	font-weight: 400;
	font-size: 26px;
	line-height: 100%;
	letter-spacing: 0.9px;
	text-align: center;
	vertical-align: middle;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/step-num-bg.png");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.wizardStep:not(:last-child)::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: -104px;
	width: 97px;
	height: 29px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/SVG_mask-group.png");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizardStep.is-active {
	opacity: 1;
	cursor: pointer;
}

.wizardStep.is-completed {
	opacity: 1;
	cursor: pointer;
}

/* STEP CONTENT */

.wizardStepContent1 {
	width: 100%;
	max-width: 590px;
	margin: 0 auto 109px;
}

.relationship {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	padding: 0 0 50px;
}

.relationship-wrapper {
	width: 100%;
	max-width: 500px;
	margin: 75px auto 0;
}

.relationship-wrapper h3 {
	font-family: Roboto;
	font-weight: 400;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000000;
	margin: 0 0 16px;
	font-style: normal;
}

/* Card style label */
.relationship-item {
	border: 1px solid #82828280;
	padding: 6px 10px;
	text-align: center;
	cursor: pointer;
	border-radius: 4px;
	transition: 0.25s;
	margin: 0;
}

.relationship-item span {
	font-family: Roboto;
	font-weight: 300;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
	color: #000;
	font-style: normal;
}

/* Hide actual radio */
.relationship-item input {
	display: none;
}

/* Hover */
.relationship-item:hover {
	background: #ececec;
}

/* Checked state */
.relationship-item:has(input:checked) {
	background: #ececec;
}

.wizardStepContent input {
	width: 100%;
	padding: 6px 0 16px 0;
	margin: 0;
	border-bottom: 1px solid #ccc;
	font-family: Roboto;
	font-weight: 300;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
}

.relationshipContent {
	max-width: 700px;
	margin: 0 auto;
	margin-bottom: 45px;
}

.wizardStepContent {
	display: none;
}

.wizardStepContent.is-active {
	display: block;
}

div#wizard-main {
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/Frame-2.png");
	background-position: bottom;
	background-size: contain;
	background-repeat: no-repeat;
}

/* NAVIGATION */
.wizardNav {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: 760px;
	margin: 44px auto 0;
	border: none;
	padding-bottom: 68px;
}

.wizardNav #wizardStart {
	display: none;
}

.wizardNav a {
	padding: 10px 28px;
	background: transparent;
	cursor: pointer;
	font-family: "Playfair", serif;
	font-weight: 500;
	font-style: Italic;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: 0.9px;
	text-align: center;
	vertical-align: middle;
	color: #000;
	border: none;
	position: relative;
}

.wizardNav a#wizardPrev::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left: 0px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/prev-arrow.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizardNav a#wizardNext::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/next-arrow.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizardNav a#wizardConfirm::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/next-arrow.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

/*  */

/* hide checkbox UI */
.occasion-check {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	position: absolute;
	opacity: 0;
	top: 12px;
	left: 12px;

	width: 18px !important;
	height: 18px !important;

	margin: 0;
	padding: 0;

	z-index: 2;
}

/* card */
.occasion-card {
	position: relative;
	overflow: hidden;
	/* safety */
	border: 1px solid #828282;
	border-radius: 4px;
	padding: 12px;
	cursor: pointer;
}

.occasion-card.is-selected {
	cursor: default;
}

.occasion-card .occasion-toggle-icon {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 16px;
	height: 15px;
	/* background: #000; */
	background-image: url(/wp-content/themes/emeline-child/modules/bouquet-wizard/images/card-uncheck.png);
	background-repeat: no-repeat;
	background-size: cover;
	cursor: pointer;
}

.occasion-card.is-selected .occasion-toggle-icon {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 16px;
	height: 15px;
	/* background: #000; */
	background-image: url(/wp-content/themes/emeline-child/modules/bouquet-wizard/images/card-check.png);
	background-repeat: no-repeat;
	background-size: cover;
	cursor: pointer;
}

/* clickable label */
.occasion-label {
	display: block;
	cursor: pointer;
	margin: 0;
}

/* active border */
.occasion-card:has(.occasion-check:checked) {
	border: 2px solid #828282;
	box-shadow: 0px 14px 14px 0px #0000001a;
}

.occasion-card {
	position: relative;
}

/* 
.occasion-card::before {
	content: "";
	position: absolute;
	top: 13px;
	right: 13px;
	font-size: 30px;
	width: 20px;
	height: 20px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/check-box.png");
	background-repeat: no-repeat;
	background-size: contain;
} */

.occasion-card.is-selected::before {
	display: none;
}

/* .occasion-card.is-selected::after {
	content: "+";
	position: absolute;
	top: 8px;
	right: 10px;
	font-size: 35px;
	width: 20px;
	height: 20px;
	transform: rotate(45deg);
} */

.wizard-layout {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	margin: 40px 0 120px;
}

p.wizard-subtitle {
	margin: 0;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 27px;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
	color: #000000b2;
}

.wizard-left {
	width: 73%;
}

.wizard-right {
	width: 25%;
	margin-top: 34px;
}

.occasion-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

.occasion-label .card-title {
	font-family: Roboto;
	font-weight: 400;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	text-align: left;
	color: #000;
	margin: 0 0 12px;
	padding-right: 30px;
}

body .occasion-grid input {
	font-family: Roboto;
	font-weight: 300;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	padding: 6px 0 12px 0;
	color: #828282;
	border-top: none;
	border-left: none;
	border-right: none;
	border-bottom: 1px solid #828282;
	font-style: normal;
}

body .occasion-grid input.occ-label {
	margin: 0 0 20px;
}

.progress-wrapper {
	margin: 28px 0;
}

.progress-wrapper span.progress-label {
	font-family: Roboto;
	font-weight: 400;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000;
	font-style: normal;
}

.progress-wrapper span {
	font-family: Roboto;
	font-weight: 400;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000000cc;
	font-style: normal;
}

.progress-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 14px;
	color: #333;
	margin-bottom: 8px;
}

.progress-top span:last-child {
	color: #666;
}

/* progress bar background */
.progress-bar {
	width: 100%;
	height: 15px;
	background: #ffffff;
	border-radius: 5px;
	overflow: hidden;
	border: 1px solid #828282;
}

/* filled bar */
.progress-fill {
	height: 100%;
	width: 0;
	background: #d9d9d9;
	border-radius: 5px;
	transition: width 0.3s ease;
}

.wizard-right-wrapper {
	border: 1px solid #828282;
	padding: 0;
	border-radius: 8px;
}

.wizard-right-wrapper h3 {
	font-family: Roboto;
	font-weight: 500;
	font-size: 24px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000;
	text-align: center;
	padding: 12px 10px;
	background: #d9d9d94d;
	margin: 0 0 10px;
	font-style: normal;
}

.summary-block {
	padding: 0px 16.5px;
	text-align: left;
}

.summary-block .custom-radio {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	position: absolute;
	opacity: 0;
}

.summary-block .radio-label {
	display: flex;
	align-items: center;
	cursor: pointer;
	padding: 9px 0 9px 33px;
	margin: 2px 0;
	position: relative;
	font-family: Roboto;
	font-weight: 400;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	font-style: normal;
}

.summary-block .radio-label::before {
	content: "";
	position: absolute;
	left: 0;
	top: 10px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radion-unchecked.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.summary-block .custom-radio:checked + .radio-label::before {
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radio-checked.svg");
}

.summary-block h4 {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	margin: 0;
}

h3.section-title {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	text-align: left;
	margin: 0 0 14px;
}

.price-cut {
	font-family: Roboto;
	font-weight: 500;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000000;
	text-align: center;
	margin: 0;
	padding: 8px 0;
}

.price-cut del {
	color: #00000099;
}

.occasions-selected {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 17px 0;
	border-top: 1px solid #00000033;
	border-bottom: 1px solid #00000033;
	margin: 10px 0;
}

p.saving {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000;
	margin: 0;
	padding: 0 0 18px;
	text-align: center;
	border-bottom: 1px solid #00000033;
}

.summary-total {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px;
}

.summary-total h2 {
	font-family: Roboto;
	font-weight: 500;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000000;
	margin: 0;
}

.continue-btn {
	padding: 8px;
	width: 93%;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
	background: #ececec;
	border: 1px solid #828282b2;
	border-radius: 4px;
	margin: 0 0 12px;
	cursor: pointer;
}

.note-summary {
	font-family: "Playfair", serif;
	font-weight: 400;
	font-style: Italic;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
	margin: 16px 0 0;
}

.note-summary span {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
}

/* =========================
   STEP 3 – RECIPIENT DETAILS
========================= */

.wizardStepContent3 h2 {
	margin-bottom: 25px;
}

/* -------- Fields -------- */
.wizardStepContent3 .wizard-field {
	margin: 50px 0;
}

.wizardStepContent3 .wizard-field h3 {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	text-align: center;
	margin: 0 0 14px;
}

/* -------- Select -------- */
.wizardStepContent3 select {
	width: 100%;
	border: 1px solid #828282;
	padding: 7.5px 16px;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000;
	border-radius: 4px;
	background: transparent;
}

/* -------- Selected Personality Tags -------- */
.selected-personality {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 20px;
}

.selected-personality .tag {
	background: transparent;
	padding: 8px 12px;
	border-radius: 20px;
	display: inline-flex;
	align-items: center;
	border: 1px dashed #828282;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 14px;
	line-height: 100%;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
}

.selected-personality .tag span {
	margin-left: 12px;
	cursor: pointer;
	font-weight: 300;
	font-size: 20px;
}

.wizardStepContent3 .flower-grid.preference-grid {
	grid-template-columns: repeat(6, 1fr);
	display: grid;
	grid-gap: 14px;
}

.flower-grid.favourite-colour-grid .flower-card {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.wizardStepContent3 .flower-card input {
	display: none;
}

.wizardStepContent3 .flower-label {
	cursor: pointer;
	text-align: center;
	margin: 0;
}

.wizardStepContent3 .flower-label img {
	width: 100%;
	border-radius: 4px;
	display: block;
}

.wizardStepContent3 .flower-label p {
	margin: 12px 0 0;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.32px;
	text-align: left;
	vertical-align: middle;
	color: #000000;
}

.wizardStepContent3 .flower-card input:checked + .flower-label {
	border: 2px solid #828282;
	box-shadow: 0px 14px 14px 0px #0000001a;
}

/* Checked State */
.wizardStepContent3 .flower-card .flower-label {
	border-radius: 4px;
	padding: 12px;
	border: 1px solid #828282;
	height: 100%;
	max-height: -webkit-fill-available;
}

/* -------- Inputs -------- */
.wizardStepContent3 input[type="text"] {
	width: 100%;
	padding: 6px 0 16px;
	border-radius: 0;
	border-bottom: 1px solid #dcdcdc;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
}

.wizardStepContent3 .other-selections {
	position: relative;
}

.wizardStepContent3 .other-selections::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 16px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/enter.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.wizardStepContent.wizardStepContent3 {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.wizardStepContent3 .favourite-colour-grid {
	grid-template-columns: repeat(4, 1fr);
	display: grid;
	grid-gap: 14px;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}

.other-selections h3 {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	text-align: left;
	margin: 0 0 14px;
}

.favourite-colour-wizard-fiels {
	margin: 0 0 18px;
}

.other-selections-wrapper {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	gap: 45px;
}

.other-selections:first-child {
	width: 100%;
}

.other-selections {
	width: 47%;
}

/* ====== GENERAL ====== */
.step-title {
	font-size: 36px;
	font-style: italic;
	text-align: center;
	margin-bottom: 40px;
}

.delivery-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px 40px;
}

.delivery-field label {
	font-size: 14px;
	color: #555;
}

.delivery-field input {
	width: 100%;
	border: none;
	border-bottom: 1px solid #bbb;
	padding: 8px 0;
	outline: none;
}

.delivery-field.full {
	grid-column: 1 / -1;
	position: relative;
}

.delivery-field.full::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 16px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/enter.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

/* ====== DELIVERY TIME ====== */
.delivery-time {
	margin: 50px 0;
	text-align: center;
}

.delivery-time h4 span {
	font-style: italic;
	color: #777;
}

.time-options {
	display: flex;
	justify-content: center;
	gap: 16px;
	margin-top: 25px;
}

/* hide radio */
.time-options input {
	display: none;
}

.time-options label {
	padding: 6px 30px;
	cursor: pointer;
	transition: 0.3s;
	border: 1px solid #8282824d;
	border-radius: 4px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 20px;
	letter-spacing: -0.32px;
	text-align: center;
	vertical-align: middle;
}

/* active */
.time-options input:checked + label {
	background: #ececec;
	border: 1px solid #828282;
}

/* ====== SURPRISE RADIO ====== */
.surprise-section {
	text-align: center;
}

.surprise-section .custom-radio {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
	cursor: pointer;
	width: 100%;
	max-width: 316px;
	margin: 0 auto 15px;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000;
}

/* hide native radio */
.surprise-section .custom-radio input {
	appearance: none;
	position: absolute;
	border: none;
	padding: 0;
}

/* custom image holder */
.surprise-section .radio-img {
	width: 20px;
	height: 20px;
	background: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radion-unchecked.svg")
		no-repeat center / contain;
}

/* checked image */
.surprise-section .custom-radio input:checked + .radio-img {
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radio-checked.svg");
}

.wizardStepContent.wizardStepContent4 {
	width: 100%;
	max-width: 793px;
	margin: 0 auto 98px;
}

.delivery-time h3,
.time-options h3,
.surprise-section h3 {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #000;
	text-align: center;
	margin: 0 0 14px;
}

.delivery-time h3 span {
	font-family: "Playfair", serif;
	font-style: Italic;
}

/* ====== STEP TITLE ====== */
.step-title {
	font-size: 36px;
	font-style: italic;
	text-align: center;
	margin-bottom: 20px;
}

.step-desc {
	text-align: center;
	font-size: 15px;
	margin-bottom: 35px;
}

/* ====== RADIO OPTIONS ====== */
.card-options {
	max-width: 700px;
	margin: 0 auto 40px;
}

/* hide native radio */
.card-options input[type="radio"] {
	appearance: none;
	position: absolute;
	border: none;
}

/* label layout */
.custom-radio {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 15px;
	cursor: pointer;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000;
}

.custom-radio em {
	font-style: italic;
	font-family: "Playfair", serif;
}

/* radio image */
.radio-img {
	width: 18px;
	height: 18px;
	background: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radion-unchecked.svg")
		no-repeat center / contain;
}

/* checked image */
.card-options input[type="radio"]:checked + label .radio-img {
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/radio-checked.svg");
}

/* ====== MESSAGE INPUT ====== */
.message-box {
	max-width: 700px;
	margin: 0 auto;
	position: relative;
}

.message-box textarea {
	width: 100%;
	border: none;
	border-bottom: 1px solid #828282;
	padding: 10px 30px 10px 0;
	outline: none;
	font-family: Roboto;
	font-weight: 300;
	font-style: normal;
	font-size: 16px;
	line-height: 27px;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000000;
	margin: 0;
}

.message-box::after {
	content: "";
	position: absolute;
	right: 0;
	top: 35px;
	width: 24px;
	height: 24px;
	background-image: url("/wp-content/themes/emeline-child/modules/bouquet-wizard/images/enter.svg");
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.enter-icon {
	position: absolute;
	right: 0;
	bottom: 8px;
	font-size: 18px;
	color: #000;
}

.card-options {
	width: 100%;
	max-width: 552px;
	margin: 50px auto 16px;
	padding-bottom: 16px;
	border-bottom: 1px solid #828282;
}

.card-options h3 {
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	margin: 0 0 16px;
}

.wizardStepContent.wizardStepContent5 {
	width: 100%;
	max-width: 552px;
	margin: 0 auto 148px;
}

/* step 6 */

/* ===== TITLE ===== */
.step-title {
	text-align: center;
	font-size: 36px;
	font-style: italic;
	margin-bottom: 40px;
}

/* ===== LAYOUT ===== */
.review-wrapper {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	justify-content: space-between;
}

/* IMAGE */
.review-image img {
	width: 100%;
	display: block;
	border-radius: 4px;
}

/* CONTENT */
.review-content {
	display: flex;
	flex-direction: column;
	gap: 6px;
	background: #efefef;
	padding: 12px;
	border-radius: 6px;
	width: 60%;
}

/* CARD BOX */
.review-card {
	background: #ffffff;
	padding: 5px 8px;
	border-radius: 4px;
}

/* KEY VALUE ROWS */
.review-row span {
	padding: 6px 0;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #646464;
	margin: 0;
}

.review-row {
	color: #000;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.review-row strong {
	font-weight: 500;
	text-align: left;
}

.review-row ul {
	list-style: none;
	padding-left: 0;
	margin: 0;
}

.review-row li {
	margin-bottom: 4px;
}

/* HEADINGS */
.review-card h4 {
	margin: 0;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: -0.1px;
	text-align: left;
	vertical-align: middle;
	padding-top: 6px;
	color: #646464;
}

/* PARAGRAPHS */
.review-card p {
	color: #000;
	font-family: Roboto;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	margin: 0 0;
	padding: 6px 0;
	text-align: left;
}

.wizardStepContent.wizardStepContent6 {
	width: 100%;
	max-width: 929px;
	margin: 0 auto 88px;
}

.colorcodeInner {
	width: 165px;
	height: 117px;
	border-radius: 6px;
}

.occasion-card.is-selected {
	border-color: #2c783a;
	background: #f4faf6;
}

.occasion-check {
	pointer-events: none;
}

.price-cut,
.saving,
.summary-total {
	display: none;
}

.wizardSection.has-summary .price-cut,
.wizardSection.has-summary .saving {
	display: block;
}

.wizardSection.has-summary .summary-total {
	display: flex;
}

.message-box {
	display: none;
}

/* =========================
   FULL SCREEN OVERLAY
========================= */
.page-loader {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.35);
	/* grey overlay */
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 99999;
}

/* =========================
   SPINNER (YOUR CODE)
========================= */
.loader {
	width: 50px;
	aspect-ratio: 1;
	display: grid;
	border-radius: 50%;
	background:
		linear-gradient(
				0deg,
				rgb(0 0 0 / 50%) 30%,
				#0000 0 70%,
				rgb(0 0 0 / 100%) 0
			)
			50% / 8% 100%,
		linear-gradient(
				90deg,
				rgb(0 0 0 / 25%) 30%,
				#0000 0 70%,
				rgb(0 0 0 / 75%) 0
			)
			50% / 100% 8%;
	background-repeat: no-repeat;
	animation: l23 1s infinite steps(12);
}

.loader::before,
.loader::after {
	content: "";
	grid-area: 1 / 1;
	border-radius: 50%;
	background: inherit;
	opacity: 0.915;
	transform: rotate(30deg);
}

.loader::after {
	opacity: 0.83;
	transform: rotate(60deg);
}

@keyframes l23 {
	100% {
		transform: rotate(1turn);
	}
}

p.error {
	margin: 0;
	font-size: 16px;
	font-weight: 400;
	color: red;
	text-align: start;
}

.favourite-colour-wizard-fiels p.error {
	max-width: 800px;
	margin: auto;
}

/* --------------------------------------------------------------------------------- */

body .wizardStepContent.wizardStepContent6.wizardStepContentNew6 {
	width: 100%;
	max-width: 1018px;
	margin: 0 auto 88px;
}

.review-top-wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-radius: 12px;
	/* background: linear-gradient(135deg, #FFFFFF 0%, #FFF1F2 100%); */
	border: 1px solid #ffe4e6;
	box-shadow: 0px 25px 20px -18px #0000001a;
	padding: 24px;
	margin-bottom: 20px;
	border: 1px solid #828282;
}

.review-order-summry-title {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 16px;
	margin: 0 0 32px;
}

.review-order-summry-title-wrapper h3 {
	margin: 0;
}

.review-order-summry-title-wrapper p {
	margin: 0;
	text-align: left;
	color: #4a5565;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.2;
}

.review-image {
	width: 37%;
	padding-right: 20px;
}

.review-order-summry-wrapper {
	width: 63%;
}

.review-order-summry-col {
	background: #fff;
	padding: 24px;
	border: 1px solid #8282824d;
	border-radius: 12px;
	text-align: left;
	width: 50%;
}

.review-order-summry-col p.review-bouquets-title,
.review-order-summry-col p.review-occasion-title {
	margin: 0 0 12px;
	font-family: "Playfair", serif;
	font-weight: 700;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: 0px;
}

.review-order-summry-col p.review-bouquets,
.review-order-summry-col p.review-occasion {
	margin: 0;
	font-weight: 400;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000000;
}

body .review-image img {
	width: 100%;
	display: block;
	height: auto;
	object-fit: cover;
	min-height: 220px;
	border: 1px solid #ffe4e6;
	border-radius: 12px;
}

.review-order-summry-col p img {
	margin-right: 12px;
}

.review-order-summry-row {
	gap: 24px;
	display: flex;
	align-items: flex-start;
	width: 100%;
}

.review-bottom-row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}

.review-bottom-card.review-bottom-card-style-preference {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}

.review-bottom-col {
	width: 49%;
}

.review-bottom-card {
	background: #fff;
	border: 1px solid #8282824d;
	border-radius: 12px;
	padding: 24px;
	margin-bottom: 20px;
	text-align: left;
}

.review-bottom-card-title {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
	margin-bottom: 18px;
}

.review-bottom-card-title-wrapper h3 {
	margin: 0;
	font-family: "Playfair", serif;
	font-weight: 700;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: 0px;
	font-style: normal;
}

.review-bottom-card-title-wrapper p {
	margin: 0;
	font-family: Roboto;
	font-weight: 400;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	color: #646464;
}

.review-bottom-card-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.review-bottom-card-colore {
	display: flex;
	align-items: center;
	gap: 8px;
}

.review-colours,
.review-style,
.review-address-name {
	margin: 0;
	font-family: Roboto;
	font-weight: 400;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000000;
}

.review-allergies {
	font-family: Roboto;
	font-weight: 400;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000000;
}

.review-bottom-card-content.review-bottom-card-content2 {
	flex-direction: column;
	align-items: flex-start;
}

.review-bottom-card-inner-image img {
	width: 100%;
	max-width: 100px;
}

p.review-occasion {
	width: 75%;
}

p.review-message {
	background: #efefef66;
	padding: 16px;
	border-radius: 8px;
	font-family: Roboto;
	font-weight: 400;
	font-style: Italic;
	font-size: 16px;
	line-height: 26px;
	color: #364153;
	margin: 0;
	width: 100%;
}

p.review-address {
	background: #efefef66;
	padding: 16px;
	border-radius: 8px;
	width: 100%;
	font-family: Roboto;
	font-weight: 400;
	font-size: 16px;
	line-height: 28px;
	letter-spacing: 0px;
	color: #364153;
	margin: 16px 0 0;
}

.review-colours ul li {
	height: 32px;
	display: flex;
	align-items: center;
}

.review-bottom-card-colore-wrapper {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.wizardStepContentNew6 ul {
	margin: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 5px;
}

/* .review-occasion ul li {
	display: none;
}

.review-occasion ul li:first-child {
	display: list-item;
}

.review-occasion.expanded ul li {
	display: list-item;
} */

.review-occasion-wrapper {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	position: relative;
}

.review-occasion-wrapper .see-all-btn {
	font-family: "Playfair", serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.2;
	letter-spacing: -0.32px;
	vertical-align: middle;
	text-decoration: underline;
	color: #000000;
	width: 20%;
	text-align: right;
}

.review-occasion ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.review-occasion ul li {
	display: none;
}

.review-occasion ul li:first-child {
	display: list-item;
}

.review-occasion ul li {
	font-size: 16px;
}

.occasion-popup {
	position: absolute;
	top: 150%;
	right: -23px;
	background: #fff;
	border: 1px solid #828282;
	border-radius: 8px;
	padding: 14px 18px;
	width: 290px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all 0.25s ease;
	z-index: 20;
}
.occasion-popup.show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.occasion-popup ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.occasion-popup li {
	margin-bottom: 12px;
	font-weight: 400;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: -0.32px;
	vertical-align: middle;
	color: #000000;
}

.occasion-popup li:last-child {
	margin-bottom: 0;
}

.review-occasion ul li:first-child span.occasion-date {
	display: none;
}

.occasion-popup ul li span.occasion-date {
	display: block;
	font-weight: 400;
	font-size: 13px;
	line-height: 100%;
	letter-spacing: -0.1px;
	vertical-align: middle;
	margin-top: 5px;
	color: #646464;
}

/* --------------------------------------------------------------------------------- */
.review-style {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.review-style-item {
	text-align: center;
	width: 80px;
}
