/* ========= PROJECT SETUP ========= */
:root {
	--dark-select-box: #2F3640;
	--dark-select-box-hover: #414B57;
	--dark-scrollbar: #0D141F;
	--dark-scrollbar-thumb: #525861;

	--heart-red: #FF2424;

	--clr-middle: #701CB7;

	--stm-green: #90BD1D;
}

/* highlight text color */
::-moz-selection {
	color: hsl(var(--clr-light));
	background-color: hsl(var(--clr-secondary));
}

::selection {
	color: hsl(var(--clr-light));
	background-color: hsl(var(--clr-secondary));
}

body {
	color: hsl(var(--clr-grey-333));
}

body,
h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--ff-sans-normal);
}

.stm-table {
	border-bottom: 3px solid var(--stm-green);
	box-shadow: var(--table-shadow-stm);
}

.stm-table thead th {
	background-color: var(--stm-green);
	box-shadow: 0px 4px 14px -2px rgb(226, 238, 226);
}

/* ========= END PROJECT SETUP ========= */



/* ========= CORE STYLE ========= */
/* loader style */
.loader {
	position: absolute;
	display: none;
	width: 100%;
	height: 100%;
}

.loader-backdrop {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: var(--z-8);
	background-color: hsla(var(--clr-default-black), 30%);
	-webkit-backdrop-filter: blur(3px);
	backdrop-filter: blur(3px);
}

.loader-backdrop.nigger {
	background-color: hsla(var(--clr-default-black), 90%);
}

.loader-wrapper {
	padding: var(--sp-400);
	position: fixed;
	top: calc(50% - 250px);
	left: 50%;
	transform: translate(-50%, 50%);
	height: 200px;
	max-width: 300px;
	min-width: 220px;
	background-color: hsl(var(--clr-default-white));
	border-radius: 9px !important;
	z-index: var(--z-9);
	text-align: center;
	transition: all .3s ease-in-out;
}

.loader-wrapper img {
	margin: 0 auto;
}

.loader-lottie-json {
	margin: 0 auto;
	height: 150px;
	width: 150px;
}

.loader-text {
	position: relative;
	bottom: -55%;
	font-size: var(--fs-300);
	font-weight: var(--fw-600);
}

.heart {
	position: relative;
	top: 20%;
	left: 43%;
	height: var(--fs-700);
	width: var(--fs-700);
	background: var(--heart-red);
	transform: rotate(45deg) translate(5px, 5px);
	animation: heartbeat 1s linear infinite;
}

.heart::before {
	content: '';
	width: 100%;
	height: 100%;
	background: var(--heart-red);
	position: absolute;
	top: -50%;
	left: 0;
	border-radius: 50%;
}

.heart::after {
	content: '';
	width: 100%;
	height: 100%;
	background: var(--heart-red);
	position: absolute;
	bottom: 0;
	right: 50%;
	border-radius: 50%;
}

/* END loader style */


/* popup style */
.popup-wrapper {
	position: fixed;
	height: 100dvh;
	width: 100%;
	z-index: var(--z-high);
	background-color: hsla(var(--clr-default-black), 30%);
	display: flex;
	justify-content: center;
	align-items: center;
	isolation: isolate;
	opacity: 0;
	pointer-events: none;
	transition: all .3s ease;
	display: none;
	cursor: pointer;
}

.popup-wrapper.active {
	opacity: 1;
	pointer-events: auto;
}

.popup {
	position: relative;
	padding-bottom: var(--sp-300);
	background-color: hsl(var(--clr-light));
	min-height: 380px;
	width: 85dvw;
	max-width: 700px;
	border-bottom: 5px solid hsl(var(--clr-secondary));
	border-radius: var(--sp-100) !important;
	box-shadow: var(--popup-box-shadow);
	overflow: hidden;
	cursor: auto;
}

.popup-bg-blob {
	height: 120%;
	position: absolute;
	top: calc(var(--sp-200) * -1);
	left: 0px;
	z-index: 0;
	border-radius: 20px !important;
}

.popup-close-btn-box {
	padding-top: var(--sp-100);
	text-align: right;
}

.popup-close-btn-box span {
	display: inline-block;
	width: 50px;
	text-align: center;
	font-size: var(--fs-600);
	color: hsl(var(--clr-secondary), 60%);
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
	cursor: pointer;
	transition: color .2s ease;
}

.popup-close-btn-box span:hover {
	color: hsl(var(--clr-secondary));
}

.popup-left-img-box {
	position: absolute;
	z-index: 1;
	top: 10%;
	left: 5%;
}

.popup-left-img-box img {
	width: 50%;
}

.popup-content {
	position: relative;
	padding: 0 var(--sp-600);
	width: 100%;
	z-index: 2;
}

.popup-content .img-box {
	width: 100%;
}

.popup-content .img-box img {
	margin: 0 auto;
	max-width: 230px;
}

/* END popup style */


/* drawer style */
.bottom-drawer {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: var(--z-1);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
	opacity: 0;
	pointer-events: none;
	transition: .1s linear;
}

.bottom-drawer.open {
	opacity: 1;
	pointer-events: auto;
}

.drawer-backdrop {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: var(--z-backdrop);
	background-color: hsla(var(--clr-default-black), 30%);
	-webkit-backdrop-filter: blur(3px);
	backdrop-filter: blur(3px);
	cursor: pointer;
}

.drawer-content {
	width: 100%;
	max-width: 1100px;
	height: 55dvh;
	max-height: 100dvh;
	padding: var(--sp-500) var(--sp-600);
	background-color: hsl(var(--clr-default-white));
	border-radius: var(--sp-200) var(--sp-200) 0 0 !important;
	position: relative;
	transition: .3s ease;
}

.bottom-drawer.open .drawer-content {
	transform: translateY(0);
}

.bottom-drawer.dragging .drawer-content {
	transition: none;
}

.bottom-drawer.fullscreen .drawer-content {
	border-radius: 0 !important;
	overflow-y: hidden;
}

.drawer-header {
	display: flex;
	justify-content: center;
}

.drawer-drag-icon {
	cursor: grab;
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
	padding: var(--sp-default);
	margin-top: calc(var(--sp-default) * -1);
}

.drawer-drag-icon span {
	height: 4px;
	width: 39px;
	display: block;
	background: hsl(var(--clr-grey-ccc));
	border-radius: var(--sp-700) !important;
}

.drawer-body {
	height: calc(100% - 50px);
	padding: var(--sp-default) 0 var(--sp-600);
	padding-top: 0;
	overflow-y: auto;
	scrollbar-width: none;
}

.drawer-body::-webkit-scrollbar {
	width: 0;
}

.drawer-body-content {
	height: 100%;
	overflow-y: scroll;
}

.drawer-close-btn-box {
	width: 100%;
	-webkit-user-select: none;
	user-select: none;
}

.drawer-close-btn {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin-left: auto;
	width: 60px;
	height: 60px;
	font-size: var(--fs-700);
	color: hsl(var(--clr-secondary), 60%);
	text-align: center;
	cursor: pointer;
	transition: color .2s ease;
}

.drawer-close-btn:hover {
	color: hsl(var(--clr-secondary));
}

.drawer-title {
	font-size: var(--fs-600);
	font-weight: var(--fw-600);
}

.drawer-desc {
	font-size: var(-fs-300);
	margin-top: var(--sp-400);
}

/* END drawer style */


/* toast style */
.ctoast-container {
	position: fixed;
	margin: 10px;
	display: flex;
	flex-direction: column;
	gap: var(--sp-200);
	z-index: var(--z-8);
}

.ctoast-container[data-position^="top-"] {
	top: 15px;
}

.ctoast-container[data-position^="bottom-"] {
	bottom: 0;
}

.ctoast-container[data-position$="-left"] {
	left: 0;
}

.ctoast-container[data-position$="-center"] {
	left: 50%;
	transform: translateX(-50%);
}

.ctoast-container[data-position$="-right"] {
	right: 0;
}

.ctoast {
	padding: var(--sp-default);
	padding-right: var(--sp-300);
	background-color: hsl(var(--clr-default-white));
	border-radius: var(--sp-000) !important;
	position: relative;
	min-width: 250px;
	cursor: pointer;
	overflow: hidden;
	box-shadow: 0px 5px 10px hsla(var(--clr-default-black), 30%) !important;
	-webkit-transition: transform 500ms cubic-bezier(0.68, -0.55, 0.265, 1.35);
	-moz-transition: transform 500ms cubic-bezier(0.68, -0.55, 0.265, 1.35);
	-o-transition: transform 500ms cubic-bezier(0.68, -0.55, 0.265, 1.35);
	transition: transform 500ms cubic-bezier(0.68, -0.55, 0.265, 1.35);
}

.ctoast-container[data-position$="-left"] .ctoast {
	transform: translateX(-110%);
}

.ctoast-container[data-position="top-center"] .ctoast {
	transform: translateY(-100dvh);
	-webkit-transition: transform 500ms ease-in-out;
	-moz-transition: transform 500ms ease-in-out;
	-o-transition: transform 500ms ease-in-out;
	transition: transform 500ms ease-in-out;
}

.ctoast-container[data-position="bottom-center"] .ctoast {
	transform: translateY(100dvh);
	-webkit-transition: transform 500ms ease-in-out;
	-moz-transition: transform 500ms ease-in-out;
	-o-transition: transform 500ms ease-in-out;
	transition: transform 500ms ease-in-out;
}

.ctoast-container[data-position$="-right"] .ctoast {
	transform: translateX(110%);
}

.ctoast-container .ctoast.show {
	transform: translate(0, 0);
}

.ctoast.ctoast-progress::before {
	content: '';
	position: absolute;
	height: 5px;
	width: 100%;
	background: var(--clr-rainbow);
	bottom: 0;
	right: calc(100% - 100% * var(--progress));
	/* --progress from javascript */
}

.ctoast.can-close::after {
	content: "\00D7";
	position: absolute;
	top: 2px;
	right: 5px;
}

.ctoast-status {
	display: inline-block;
	padding-left: var(--sp-100);
	border-left: 5px solid hsl(var(--clr-blue-300));
}

.ctoast-status.success {
	border-color: hsl(var(--clr-blue-300));
}

.ctoast-status.failed {
	border-color: hsl(var(--clr-red-500));
}

/* END toast style */


/* dialog style */
.dialog {
	position: fixed;
	top: 0;
	left: -9px;
	width: 100vw;
	height: 100dvh;
	background-color: hsla(var(--clr-default-black), 30%);
	-webkit-backdrop-filter: blur(3px);
	backdrop-filter: blur(3px);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: var(--z-9);
}

.dialog .dialog-container {
	background-color: hsl(var(--clr-default-white));
	border-radius: var(--sp-100) !important;
	height: 80dvh;
	width: 720px;
	padding: 0 var(--sp-400);
}

.dialog .dialog-header {
	border-bottom: 1px solid hsl(var(--clr-grey-eee));
	padding: var(--sp-400) 0 var(--sp-200);
}

.dialog .dialog-header h3 {
	margin: 0;
	font-weight: 600;
	font-size: var(--fs-400);
	color: hsl(var(--clr-primary));
}

.dialog .dialog-content {
	overflow: hidden;
	padding: var(--sp-100) 0;
	height: 80%;
}

.dialog-content-wrapper {
	padding: 0 var(--sp-400) var(--sp-400) 0;
	overflow-y: scroll;
	height: 100%;
	line-height: 150%;
	text-align: left;
}

.dialog .dialog-footer {
	padding: var(--sp-400) 0;
	display: flex;
	justify-content: flex-end;
}

.dialog .dialog-footer button {
	padding: var(--sp-100) var(--sp-200);
	background-color: hsl(var(--clr-default-white));
	border: none;
	border-radius: var(--sp-000) !important;
	border: 1px solid hsl(var(--clr-grey-222));
	font-size: var(--fs-100);
	cursor: pointer;
}

/* END dialog style */


/* step progress style */
.wrapper.step-progress {
	margin-top: var(--sp-300);
	padding: var(--sp-300);
	height: 96px;
	width: 100%;
	background-color: transparent;
}

.step-progress-header {
	width: 100%;
	height: 20px;
	display: flex;
	background-color: hsl(var(--clr-grey-ddd));
	justify-content: space-between;
	align-items: center;
	background:
		linear-gradient(hsl(var(--clr-primary)), hsl(var(--clr-primary))) 0 9px/0% 4px no-repeat,
		linear-gradient(hsl(var(--clr-grey-eee)), hsl(var(--clr-grey-eee))) 0 9px/100% 4px no-repeat;
	transition: background-size .5s ease;
}

.step-progress-header.error {
	background:
		linear-gradient(hsl(var(--clr-red-500)), hsl(var(--clr-red-500))) 0 9px/0% 4px no-repeat,
		linear-gradient(hsl(var(--clr-grey-eee)), hsl(var(--clr-grey-eee))) 0 9px/100% 4px no-repeat;
}

.step-progress-header p {
	position: relative;
	margin: 0;
}

.step-progress-header p strong {
	position: absolute;
	min-width: 100px;
	text-align: center;
	left: 50%;
	top: 110%;
	transform: translateX(-50%);
	font-size: var(--fs-100);
	color: hsl(var(--clr-grey-333));
}

.step-progress-header p .step {
	width: 40px;
	height: 40px;
	border-radius: 50% !important;
	display: flex;
	background-color: hsl(var(--clr-grey-eee));
	justify-content: center;
	align-items: center;
	font-size: var(--fs-300);
	z-index: var(--z-1);
	border: 4px solid hsla(var(--clr-default-white), 20%);
	transition:
		background-color .3s ease .3s,
		color .15s ease .3s
}

.step-progress-header .completed .step {
	background-color: hsl(var(--clr-primary));
	color: hsl(var(--clr-default-white));
}

.step-progress-header .error .step {
	background-color: hsl(var(--clr-red-500));
	color: hsl(var(--clr-default-white));
}

.step-progress-header .warn .step {
	background-color: hsl(var(--clr-orange-500));
	color: hsl(var(--clr-default-white));
}

.stepper-content {
	width: 100%;
}

/* END step progress style */


/* step style */
.step-info-box {
	margin-bottom: var(--sp-400);
}

.step-info {
	font-size: var(--fs-100);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-primary));
}

.step-header-wrapper {
	margin-bottom: var(--sp-800);
	line-height: 18px;
	color: hsl(var(--clr-grey-333));
}

.step-header {
	font-size: var(--fs-700);
	font-weight: var(--fw-700);
	letter-spacing: -2px;
}

.step-desc {
	font-size: var(--fs-200);
}

.step-content {
	display: none;
}

.step-content.active {
	display: block;
}

/* END step style */


/* error container style */
.error-container {
	width: 100%;
	background-color: hsl(var(--clr-red-500), 25%);
	padding: 0;
	border-radius: var(--sp-100) !important;
	box-shadow: var(--red-box-shadow);
	height: 0;
	transition: all .3s ease;
	scroll-margin-top: 90px;
}

.error-content {
	display: none;
	color: hsl(var(--clr-red-500));
	font-size: var(--fs-200);
}

.error-title {
	font-weight: 600;
	font-size: var(--fs-400);
	margin-bottom: var(--sp-100);
	color: inherit;
}

.error-list {
	margin: 0;
	padding-left: var(--fs-300);
	list-style: disc;
}

.error-list li {
	margin-bottom: var(--sp-100);
	line-break: auto;
}

.error-link {
	color: hsl(var(--clr-red-500));
	font-size: var(--fs-200);
	font-weight: var(--fw-600);
	text-decoration: underline;
}

.error-link:hover,
.error-link:active,
.error-link:focus,
.error-link:visited {
	color: hsl(var(--clr-red-500));
	text-decoration: underline;
}

/* END error container style */


/* popup error style */
.error-popup-container {
	width: 100%;
	background: hsl(var(--clr-red-500), 20%);
	margin-bottom: 25px;
	padding: 0;
	border-radius: var(--sp-100) !important;
	box-shadow: var(--red-box-shadow);
	height: 0;
	transition: all .3s ease;
}

.error-popup-content {
	display: none;
	color: hsl(var(--clr-red-500));
	font-size: var(--fs-200);
}

.error-popup-title {
	font-weight: 600;
	font-size: var(--fs-400);
	margin-bottom: var(--sp-100);
}

.error-popup-list {
	margin: 0;
	padding-left: var(--fs-300);
	list-style: disc;
}

.error-popup-list li {
	margin-bottom: var(--sp-100);
}

.error-popup-link {
	color: hsl(var(--clr-red-500));
	font-size: var(--fs-200);
	font-weight: 600;
	text-decoration: underline;
}

.error-popup-link:hover,
.error-popup-link:active,
.error-popup-link:focus,
.error-popup-link:visited {
	color: hsl(var(--clr-red-500));
	text-decoration: underline;
}

/* END popup error style */


/* Custom Radio Button Style */
.custom-radio {
	width: 100%;
}

.custom-radio input {
	display: none;
}

.radio-btn {
	width: 100%;
	height: 60px;
	border: var(--sp-000) solid transparent;
	display: inline-block;
	border: 2px solid hsl(var(--clr-grey-ddd));
	border-radius: var(--sp-100) !important;
	position: relative;
	text-align: center;
	box-shadow: 0px 10px 50px -30px rgba(0, 0, 0, .2), 0px 10px 50px -30px rgba(25, 125, 255, .4);
	cursor: pointer;
}

.radio-btn>i {
	color: hsl(var(--clr-default-white));
	background-color: hsl(var(--clr-primary));
	font-size: var(--fs-200);
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%) scale(4);
	border-radius: 50px !important;
	padding: var(--sp-000);
	transition: 0.2s;
	pointer-events: none;
	opacity: 0;
}

.radio-btn .radio-selection {
	position: absolute;
	top: 39%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.radio-btn .radio-selection h3 {
	width: 100%;
	color: hsl(var(--clr-grey-aaa));
	font-size: var(--fs-300);
	font-weight: 600;
	margin-top: var(--sp-300);
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
	display: inline-flex;
	justify-content: center;
	align-items: center;
}

.custom-radio input:checked+.radio-btn {
	border: 3px solid hsl(var(--clr-primary));
}

.custom-radio input:checked+.radio-btn>i {
	opacity: 1;
	transform: translateX(-50%) scale(1);
}

.custom-radio input:checked+.radio-btn .radio-selection h3 {
	color: hsl(var(--clr-primary));
}

/* Custom Radio Button Style */


/* Custom Toggle Button Style */
.toggle-checkbox.toggle {
	display: none;
}

.toggle-checkbox.toggle+label {
	position: relative;
	display: flex;
	align-items: center;
	cursor: pointer;
	height: 0;
}

.toggle-checkbox.toggle+label::before {
	content: "";
	width: 3rem;
	height: 1.7rem;
	background-color: hsl(var(--clr-grey-ccc));
	border-radius: var(--sp-default);
	margin-right: var(--sp-000);
	transition: background-color 200ms ease-in-out;
}

.toggle-checkbox.toggle+label::after {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	content: "";
	font-size: var(--fs-200);
	font-weight: var(--fw-900);
	left: .2rem;
	width: 1.4em;
	height: 1.3rem;
	background-color: hsl(var(--clr-default-white));
	color: hsl(var(--clr-grey-666));
	border-radius: var(--sp-default);
	transition: background-color 200ms ease-in-out, transform 200ms ease-in-out;
}

.toggle-checkbox.toggle:focus+label::before {
	outline: none;
}

.toggle-checkbox.toggle:checked+label::before {
	background-color: hsl(var(--clr-primary));
}

.toggle-checkbox.toggle:checked+label::after {
	content: "";
	transform: translateX(110%);
	color: hsl(var(--clr-primary));
}

.toggle-checkbox.toggle:disabled+label {
	color: hsl(var(--clr-grey-777));
}

.toggle-checkbox.toggle:disabled+label::before {
	background-color: hsl(var(--clr-grey-ccc));
}

.toggle-checkbox.toggle:disabled+label::after {
	background-color: hsl(var(--clr-grey-777));
}

/* END Custom Toggle Button Style */


/* Terms and Conditions Style */
.terms-box {
	margin-top: var(--sp-700);
}

.important-note-box {
	margin-bottom: var(--sp-500);
	padding: var(--sp-200) var(--sp-300);
	border: 2px dashed hsl(var(--clr-grey-333));
	border-radius: var(--sp-100) !important;
}

.important-note-title {
	margin-bottom: var(--sp-100);
	font-size: var(--fs-300);
	font-weight: var(--fw-700);
	text-decoration: underline;
}

.tnc-alert {
	background: #f7f0ff;
	border-left: 4px solid hsl(var(--clr-primary));
	padding: 10px 14px;
	font-size: 14px;
	margin: 20px 0;
	display: flex;
	align-items: center;
	gap: 8px;
	border-radius: 6px !important;
}

.alert-icon {
	font-size: var(--fs-300);
}

.tnc-section {
	background: #fff;
	border: 1px solid #eee;
	padding: 16px 18px;
	margin-bottom: 20px;
	border-radius: 8px !important;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.tnc-title {
	margin: 0 0 12px 0;
	color: hsl(var(--clr-primary));
	font-size: 1rem;
	font-weight: 600;
}

.doc-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.doc-list li {
	padding: 6px 0;
}

.doc-viewer-read-status {
	display: inline-block;
	padding: 3px 6px;
	font-size: 0.8em;
	font-weight: 600;
	border-radius: 4px !important;
	line-height: 1;
	white-space: nowrap;
	text-transform: uppercase;
}

.doc-viewer-read-status.doc-viewer-text-pending {
	background-color: #f7e099;
	color: #8c7300;
}

.doc-viewer-read-status.doc-viewer-text-read {
	background-color: #d1e7dd;
	color: #0f5132;
}

.doc-viewer-read-status.doc-viewer-text-read:before {
	content: "✔ ";
	font-weight: bold;
}

.grouped-tandc {
	padding-left: var(--sp-500);
}

label.checkbox-box {
	display: inline-flex;
	align-items: flex-start;
	justify-content: flex-end;
	cursor: pointer;
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
}

.checkbox-input {
	display: none;
}

.checkbox-mark {
	width: 1.5rem;
	height: 1.5rem;
	border: 2px solid hsl(var(--clr-grey-ccc));
	border-radius: 50% !important;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background .15s, border-color .15s;
}

.checkbox-mark.small {
	width: 1.2rem;
	height: 1.2rem;
	border-color: hsl(var(--clr-grey-666));
	border-radius: var(--sp-000) !important;
	margin-top: var(--sp-000);
	margin-right: var(--sp-000);
}

.checkbox-mark.boxy {
	width: 1.2rem;
	height: 1.2rem;
	border-color: hsl(var(--clr-grey-666));
	border-radius: var(--sp-000) !important;
	margin-right: var(--sp-100);
}

.checkbox-mark::after {
	content: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20style%3D%22fill%3A%20rgba(255%2C%20255%2C%20255%2C%201)%3Btransform%3A%20%3BmsFilter%3A%3B%22%3E%3Cpath%20d%3D%22m10%2015.586-3.293-3.293-1.414%201.414L10%2018.414l9.707-9.707-1.414-1.414z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E");
	color: hsl(var(--clr-default-white));
	height: 1.55rem;
	transform: scale(0);
	transition: transform .15s;
}

.checkbox-input:checked+.checkbox-mark {
	background: hsl(var(--clr-secondary));
	border-color: hsl(var(--clr-secondary));
}

.checkbox-input:checked+.checkbox-mark::after {
	transform: scale(.8);
}

.modal-link {
	font-weight: var(--fw-600);
	color: hsl(var(--clr-primary));
	text-decoration: underline;
}

.modal-link:hover {
	color: hsl(var(--clr-secondary));
}

/* END Terms and Conditions Style */
/* ========= END CORE STYLE ========= */



/* ========= MAIN APP STYLE ========= */
#app {
	position: relative;
	display: flex;
	width: 100%;
	height: 100%;
	flex-direction: column;
	/* background-color: hsl(var(--clr-light)); */
	background-color: transparent;
}


/* Header Section Style */
.header-container {
	width: 100%;
}

.header-img {
	max-width: 309px;
	width: 100%;
}

.header-promo-img {
	width: 100%;
	border-radius: var(--sp-300) !important;
}

/* END Header Section Style */


.wrapper {
	margin: 0 auto;
	padding: var(--sp-600) var(--sp-400);
	width: 1375px;
}

.wrapper--default {
	margin: var(--sp-400) auto;
	margin-top: 0px;
	padding-top: var(--sp-200);
	padding-bottom: var(--sp-600);
	max-height: fit-content;
	background-color: hsl(var(--clr-default-white));
	background-color: hsl(var(--clr-yellow-phm));
	border-radius: 0 0 var(--sp-default) var(--sp-default) !important;
	box-shadow: var(--blue-box-shadow);
	flex-grow: 1;
}

.small-wrapper {
	max-width: 1100px;
}

.wrapper.footer {
	margin-top: auto;
}


/* ### Form Group Style ### */
.form--group {
	grid-template-columns: 1fr 1fr;
}

.form--row {
	grid-template-columns: 1fr 1fr;
}

.participant-form-group {
	grid-template-columns: 1fr;
}

/* Input Style */
.bmi-input-group {
	display: flex;
	align-items: flex-end;
	gap: var(--sp-000);
}

.input--label {
	width: 100%;
	position: relative;
}

.input--label input {
	height: 65px;
	width: 100%;
	border-radius: var(--sp-100) !important;
	border: 2px solid hsl(var(--clr-grey-ddd));
	transition: border-color .2s ease;
	padding: var(--sp-200);
	padding-top: var(--sp-500);
	font-size: var(--fs-200);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-grey-333));
}

.input--label input::-webkit-placeholder,
.input--label input::-moz-placeholder,
.input--label input::placeholder {
	font-size: var(--fs-200);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-grey-aaa));
}

.input--label .input--icon {
	position: absolute;
	right: var(--fs-200);
	top: 50%;
	transform: translateY(-35%);
	font-size: var(--fs-300);
	color: hsl(var(--clr-grey-aaa));
}

.input--label .input--placeholder,
.selected .select--placeholder {
	display: flex;
	align-items: center;
	column-gap: 3px;
	font-size: var(--fs-100);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-grey-aaa));
	position: absolute;
	top: 9px;
	left: 12px;
	transition: color .2s ease;
}

.input--placeholder sup {
	top: -.2em;
	font-size: var(--fs-100);
}

.select--placeholder.active {
	color: hsl(var(--clr-primary));
}

.select--placeholder sup {
	top: -.2em;
	font-size: var(--fs-100);
}

.input--label input:focus,
.input--label input:valid:not(:placeholder-shown) {
	border-color: hsl(var(--clr-primary));
	transition-delay: .1s;
}

.input--label input.disable:valid~.input--placeholder,
.input--label input.disable:focus~.input--placeholder,
.input--label input.disable:valid~.input--icon,
.input--label input.disable:focus~.input--icon,
.input--label input:valid:not(:placeholder-shown)~.input--placeholder,
.input--label input:focus~.input--placeholder,
.input--label input:valid:not(:placeholder-shown)~.input--icon,
.input--label input:focus~.input--icon {
	color: hsl(var(--clr-primary));
	transition-delay: .1s;
}

.input--label input.error:valid,
.input--label input.error:focus,
.input--label input.error {
	border-color: hsl(var(--clr-red-500));
}

.input--label input.disable {
	border-color: hsl(var(--clr-grey-ddd));
	background-color: hsl(var(--clr-grey-eee));
	cursor: not-allowed;
}

.input--label input:valid~.input--placeholder.error,
.input--label input:focus~.input--placeholder.error,
.input--label input:valid~.input--icon.error,
.input--label input:focus~.input--icon.error,
.input--placeholder.error,
.select--placeholder.error {
	color: hsl(var(--clr-red-500));
}

.input--error-msg span {
	font-size: var(--fs-200);
	background-color: hsl(var(--clr-red-500), 20%);
	padding: 0 var(--sp-100);
	color: hsl(var(--clr-red-500));
	font-style: italic;
	border-radius: var(--sp-000) !important;
}

/* Specific Input Style */
#ins_name,
#ins_id,
#ins_addr_1,
#ins_addr_2,
#ins_addr_3,
#ins_city,
#ins_state {
	text-transform: uppercase;
}

#ins_id_type_options_input {
	position: relative;
	display: flex;
	width: 100%;
}

#ins_id_type_options {
	top: 68px;
	height: max-content;
}

#ins_id_type {
	display: flex;
	align-items: center;
	min-width: 110px;
	border-radius: var(--sp-100) 0px 0px var(--sp-100) !important;
	z-index: 2;
}

#ins_id_label {
	margin-left: -2px;
}

#ins_id {
	border-left: none;
	border-radius: 0px var(--sp-100) var(--sp-100) 0px !important;
}

#ins_id_type_search {
	top: 66px;
	left: 0px;
}

/* END Specific Input Style */
/* END Input Style */


/* Questionnaire Style */
.questionnaire-item {
	border-radius: 9px !important;
	margin-bottom: 18px;
	padding: 18px;
	line-height: 180%;
}

.question-selection {
	margin-top: 12px;
}

.questionnaire-option {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 100px;
	height: 50px;
	border: 2px solid hsl(var(--clr-primary));
	border-radius: 6px !important;
	font-size: var(--fs-400);
	font-weight: var(--fw-700);
	color: hsl(var(--clr-grey-333));
	background-color: hsl(var(--clr-default-white));
	cursor: pointer;
}

.questionnaire-option:nth-child(n + 1) {
	margin-left: 9px;
}

.questionnaire-option input:checked+.questionnaire-option-text {
	color: hsl(var(--clr-primary));
}

.female-question {
	display: none;
}

/* END Questionnaire Style */


/* Custom Select Box Style */
.select--placeholder.active {
	color: hsl(var(--clr-primary));
}

.select--placeholder sup {
	top: -.2em;
	font-size: var(--fs-100);
}

.select--placeholder.error {
	color: hsl(var(--clr-red-500));
}

.select-box {
	position: relative;
	display: flex;
	width: 100%;
	flex-direction: column;
}

.options-container {
	background: var(--dark-select-box);
	max-height: 0;
	opacity: 0;
	width: 100%;
	transition: all .3s;
	border-radius: var(--sp-100) !important;
	overflow: hidden;
	position: absolute;
	z-index: calc(var(--z-top) + 1);
	top: 69px;

	order: 1;
}

.options-container.offset {
	top: 135px;
}

.selected {
	position: relative;
	padding: 28px 12px;
	padding-bottom: 12px;
	padding-right: 25px;
	color: hsl(var(--clr-grey-333));
	font-weight: 600;
	border: 2px solid hsl(var(--clr-grey-ddd));
	border-radius: 9px !important;
	transition: all .3s ease;
	cursor: pointer;
	height: 65px;
	background: hsl(var(--clr-default-white));

	order: 0;
}

.selected.disable {
	border-color: hsl(var(--clr-grey-ddd));
	background-color: hsl(var(--clr-grey-eee));
	cursor: not-allowed;
}

.selected.error {
	border: 2px solid hsl(var(--clr-red-500));
}

.selected::after {
	content: "";
	background: url("data:image/svg+xml, %3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20style%3D%22fill%3A%20rgba(85%2C%2085%2C%2085%2C%201)%3Btransform%3A%20%3BmsFilter%3A%3B%22%3E%3Cpath%20d%3D%22M16.293%209.293%2012%2013.586%207.707%209.293l-1.414%201.414L12%2016.414l5.707-5.707z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	color: hsl(var(--clr-grey-333));
	position: absolute;
	height: 100%;
	width: 18px;
	right: 12px;
	top: 43%;
	transition: all .3s;
}

.selected p {
	font-size: var(--fs-200);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.options-container.active {
	max-height: 275px;
	opacity: 1;
	overflow-y: scroll;
}

.options-container.overflow-y-hidden.active {
	overflow-y: hidden;
}

.selected.active {
	border-color: hsl(var(--clr-primary));
}

.options-container.active+.selected::after {
	transform: rotateX(180deg);
	top: -16px;
}

.options-container::-webkit-scrollbar {
	width: 7px;
}

.options-container::-webkit-scrollbar-track {
	background: var(--dark-select-box);
	border-radius: var(--sp-500) !important;
}

.options-container::-webkit-scrollbar-thumb {
	background: var(--dark-scrollbar-thumb);
	border-radius: var(--sp-500) !important;
}

#occupation_p_options {
	top: 125px;
}

.option {
	padding: var(--sp-400) var(--sp-200);
	cursor: pointer;
	height: fit-content;
	line-height: 30px;
}

.option:hover {
	background: var(--dark-select-box-hover);
}

.option label {
	color: hsl(var(--clr-light));
}

.select-box label {
	cursor: pointer;
}

.option .radio-input {
	display: none;
	pointer-events: none;
}

.option label {
	pointer-events: none;
}


.search-box input {
	width: 100%;
	padding: var(--sp-200) var(--sp-default);
	font-size: var(--fs-default);
	position: absolute;
	top: 69px;
	border-radius: var(--sp-100) var(--sp-100) 0px 0px !important;
	z-index: 9;
	border: var(--sp-100) solid var(--dark-select-box);
	opacity: 0;
	pointer-events: none;
	transition: all .3s;
}

.search-box input:focus {
	outline: none;
}

.options-container.active~.search-box input {
	opacity: 1;
	pointer-events: auto;
}

/* END Custom Select Box Style */


/* Button Style */
.button--group {
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	column-gap: .9rem;
	row-gap: .9rem;
	margin: var(--sp-800) 0 var(--sp-300);
	text-align: right;
}

.popup-button--group {
	position: sticky;
	bottom: 0;
}

.btn--default {
	line-height: 1.42857143;
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	touch-action: manipulation;
	cursor: pointer;
	display: inline-block;
	margin-bottom: 0;
	overflow: hidden;
	transition: width .5s ease;
}

.btn-fill,
.btn-hollow {
	height: 60px;
	min-width: 200px;
	border-radius: 6px !important;
	font-size: var(--fs-400);
	font-weight: var(--fw-600);
	background-color: hsl(var(--clr-primary));
	border: none;
	color: hsl(var(--clr-light));
	cursor: pointer;
}

.btn-hollow {
	color: hsl(var(--clr-primary));
	background-color: transparent;
	border: 2px solid hsl(var(--clr-primary));
}

.btn-refresh {
	height: 60px;
	width: 225px;
	padding: var(--sp-100);
	padding-left: var(--sp-200);
	border-radius: var(--sp-100) !important;
	font-size: var(--fs-default);
	font-weight: var(--fw-600);
	background-color: hsl(var(--clr-red-500));
	border: none;
	color: hsl(var(--clr-light));
	cursor: pointer;
}

.btn-action {
	background-color: hsl(var(--clr-green-500));
}

.btn-alt-action {
	background-color: hsl(var(--clr-secondary));
}

/* Specific Button Style */
.btn-plan {
	width: 100%;
}

.btn--disabled {
	background-color: hsl(var(--clr-grey-aaa)) !important;
}

.btn-label {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: var(--sp-100);
}

.btn-refresh:focus .btn-label.refresh-label i {
	animation: rolling .5s linear infinite;
}

.btn-small {
	height: 45px;
	min-width: 90px;
	max-width: -moz-fit-content;
	max-width: fit-content;
	padding-left: var(--sp-100);
	padding-right: var(--sp-100);
}

.btn-large {
	min-width: 250px;
	padding-left: var(--sp-100);
	padding-right: var(--sp-100);
}

.btn-hollow:hover,
.btn-hollow:focus {
	color: hsl(var(--clr-primary)) !important;
}

.btn-fill:hover,
.btn-fill:focus {
	color: hsl(var(--clr-light)) !important;
}

.btn--default:active {
	transform: scale(.99);
}

/* default those button to display none */
#prev_btn_control,
#next_btn_control,
#calculate_btn_control,
#back_btn_control,
#email_btn_control,
#whatsapp_btn_control,
#submit_btn_control,
#direct_btn_control {
	display: none;
}

/* END Specific Button Style */
/* END Button Style */
/* ### END Form Group Style ### */


/* ### Step Content Style ### */
/* .small-two-cols {
	grid-column: 1/-1;
} */

.relation-checkbox {
	--gap: 0;

	min-height: 80px;
	padding: var(--sp-000);
	border: 3px solid hsl(var(--clr-grey-aaa));
	border-radius: var(--sp-100) !important;
	text-align: center;
	font-size: var(--sp-default);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-grey-333));
	cursor: pointer;
	background-image: radial-gradient(hsl(var(--clr-grey-333)) 0.5px, hsl(var(--clr-default-white)) 0.5px);
	background-size: 20px 20px;
	-webkit-user-select: none;
	user-select: none;
}

.standout-section {
	padding: var(--sp-300);
	border: 3px dashed hsl(var(--clr-primary));
	border-radius: var(--sp-200) !important;
}


/* UW Result Style */
.uw-container {
	padding: var(--sp-500) var(--sp-400);
	border-radius: var(--sp-100) !important;
	font-size: var(--fs-300);
	font-weight: var(--fw-600);
	color: hsl(var(--clr-red-500));
	background: hsl(var(--clr-red-500), 25%);
	text-align: center;
}

.uw-container.success {
	background: hsl(var(--clr-green-200));
	color: hsl(var(--clr-green-600), 80%);
}

/* END UW Result Style */


.summary-box {
	padding: var(--sp-200) var(--sp-300) var(--sp-500);
	border: 1px solid hsl(var(--clr-grey-666));
	border-radius: var(--sp-100) !important;
}

.summary-header {
	padding: var(--sp-300) 0;
}

#payment_method_box {
	scroll-margin-top: 309px;
}

/* ### END Step Content Style ### */
/* ========= END MAIN APP STYLE ========= */



/* ========= ANIMATION ========= */
@-webkit-keyframes heartbeat {
	0% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	25% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	30% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.3);
	}

	50% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.2);
	}

	70% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.3);
	}

	90% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	100% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}
}

@keyframes heartbeat {
	0% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	25% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	30% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.3);
	}

	50% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.2);
	}

	70% {
		transform: rotate(45deg) translate(5px, 5px) scale(1.3);
	}

	90% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}

	100% {
		transform: rotate(45deg) translate(5px, 5px) scale(1);
	}
}


@-webkit-keyframes starburst {
	0% {
		transform: scale(0);
	}

	10% {
		transform: scale(1.3);
	}

	20% {
		transform: scale(0);
	}

	100% {
		transform: scale(0);
	}
}

@keyframes starburst {
	0% {
		transform: scale(0);
	}

	10% {
		transform: scale(1.3);
	}

	20% {
		transform: scale(0);
	}

	100% {
		transform: scale(0);
	}
}


@-webkit-keyframes shake {

	2%,
	20% {
		transform: translate3d(-0.5px, 0, 0);
	}

	5%,
	18% {
		transform: translate3d(1px, 0, 0);
	}

	8%,
	12%,
	16% {
		transform: translate3d(-2px, 0, 0);
	}

	10%,
	14% {
		transform: translate3d(2px, 0, 0);
	}
}

@keyframes shake {

	2%,
	20% {
		transform: translate3d(-0.5px, 0, 0);
	}

	5%,
	18% {
		transform: translate3d(1px, 0, 0);
	}

	8%,
	12%,
	16% {
		transform: translate3d(-2px, 0, 0);
	}

	10%,
	14% {
		transform: translate3d(2px, 0, 0);
	}
}

/* ========= END ANIMATION ========= */



/* ========= UTILITY STYLE ========= */
.one-to-two-grid {
	grid-template-columns: 1fr 2fr;
}

.two-to-one-grid {
	grid-template-columns: 2fr 1fr;
}

.three-cols-grid {
	grid-template-columns: 1fr 1fr 1fr;
}

.four-cols-grid {
	grid-template-columns: 1fr 1fr 1fr 1fr;
}

.small-two-cols {
	grid-template-columns: 1fr 1fr;
}

.full-width {
	grid-column: 1/-1;
}

.full-width-percentage {
	width: 100%;
}

.grid-flow-2-cols {
	grid-column: 1/3;
}

/* ========= END UTILITY STYLE ========= */



/* ========= Media Query ========= */
/* handle for dark mode */
@media (prefers-color-scheme: dark) {
	/* #app {
		background-color: hsl(var(--clr-dark));
	} */
}


@media (prefers-reduced-motion: reduce) {
	.blink-star {
		opacity: 0 !important;
	}
}


/* 1200px - 1440px */
@media screen and (max-width: 1440px) {
	.wrapper {
		width: 98%;
	}

	.two-to-one-grid {
		grid-template-columns: 2fr 1fr;
	}

	.one-to-two-grid {
		grid-template-columns: 1fr 2fr;
	}

	.two-row-box {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 1200px) {

	.two-to-one-grid,
	.one-to-two-grid {
		grid-template-columns: 1fr 1fr;
	}

	.form--row.long-row {
		grid-template-columns: 1fr;
	}

	.table-no-wrap {
		white-space: unset;
	}
}

/* Tablet: 840px - 1024px */
@media screen and (max-width: 1024px) {
	.form--group {
		grid-template-columns: 1fr 1fr;
	}

	.two-to-one-grid,
	.one-to-two-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* Small Tablet: 768px - 840px */
@media screen and (max-width: 840px) {
	.small-two-cols {
		grid-column: 1/-1;
	}

	.two-to-one-grid,
	.one-to-two-grid {
		grid-template-columns: 1fr;
	}

	.four-cols-grid {
		grid-template-columns: 1fr 1fr 1fr;
	}

	.btn--default:is(:not(.flex-no-grow)) {
		flex-grow: 1;
	}

	.popup {
		width: 95dvw;
	}

	.doc-viewer-read-status {
		margin-top: 2px;
	}
}

/* Large Mobile */
@media screen and (max-width: 720px) {
	.form--group {
		grid-template-columns: 1fr;
	}

	.popup {
		width: 85dvw;
	}

	.popup-bg-blob {
		display: none;
	}

	.popup-content {
		margin: 0 auto;
		padding: 0 var(--sp-200);
	}

	.popup-left-img-box {
		display: none;
	}

	.drawer-content {
		padding-left: var(--sp-200);
		padding-right: var(--sp-200);
	}

	.header-img-container {
		align-items: center;
		justify-content: center;
	}
}

/* Medium Mobile */
@media screen and (max-width: 598px) {
	.four-cols-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* Mobile */
@media screen and (max-width: 520px) {
	.popup {
		width: 95dvw;
	}

	.button--group {
		flex-direction: column;
	}

	.btn--default:is(:not(.flex-no-grow)) {
		width: 100%;
	}

	.wrapper.step-progress {
		padding: var(--sp-300) 0 0;
		height: 72px;
	}

	.step-progress-header p strong {
		display: none;
	}
}

/* Small Mobile */
@media screen and (max-width: 480px) {
	.wrapper {
		padding-left: var(--sp-200);
		padding-right: var(--sp-200);
	}

	.form--row {
		grid-template-columns: 1fr;
	}
}

/* Tiny Mobile */
@media screen and (max-width: 412px) {
	.four-cols-grid {
		grid-template-columns: 1fr;
	}

	.small-two-cols {
		grid-template-columns: 1fr;
	}
}

/* SE */
@media screen and (max-width: 375px) {
	/* todo */
}

/* ========= END Media Query ========= */