body {
	background-color: #f5f7fa;
	font-family: "Poppins", sans-serif;
}

.cursor-pointer {
	cursor: pointer;
}

.d-wrapper {
	max-width: 425px;
	min-height: 100vh;
}

.icon-eltari {
	width: 90px;
	height: auto;
}

.login-btn {
	width: 245px;
	background: #ea4620;
	color: #ffffff;
	border-radius: 15px;
	padding-top: 7px;
	padding-bottom: 7px;
}

.register-btn {
	width: 245px;
	background: #9facdc;
	color: #ffffff;
	border-radius: 15px;
	padding-top: 7px;
	padding-bottom: 7px;
}

.login-btn:hover {
	background: #cb310e;
	color: #ffffff !important;
}

.login-btn:disabled {
	background: #9facdc;
	color: #ffffff !important;
	border-color: #9facdc;
}

.register-btn:hover {
	background: #6d85da;
	color: #ffffff !important;
}

.text-btn {
	font-family: "Poppins", sans-serif;
	font-size: 20px;
	font-weight: 500;
}

/* login page */

/* .back-container {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: #ea4620;
	border-radius: 5px;

	position: absolute;
	top: 30px;
	left: 30px;
	cursor: pointer;
} */

.back-container {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: #ea4620;
	border-radius: 5px;
}

.text-back {
	font-size: 14px;
	font-weight: 500;
	color: #000;
}

.arrow-back {
	width: 24px;
	height: 24px;
}

.edit-ico {
	width: 14px;
	height: 14px;
}

.welcome-text {
	font-family: "Poppins", sans-serif;
	font-weight: 700;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: 0%;
}

.normal-text {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
}

.fs-10 {
	font-size: 10px;
}

.fs-11 {
	font-size: 11px;
}

.fs-13 {
	font-size: 13px;
}

.fs-20 {
	font-size: 20px;
}

.fs-24 {
	font-size: 24px;
}

.fs-30 {
	font-size: 30px;
}

.mt-30 {
	margin-top: 30px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.custom-form-label {
	font-family: "Poppins", sans-serif;
	font-weight: 500;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
}

.custom-form-input {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-size: 10px;
	padding-top: 10px;
	padding-bottom: 10px;
	border-radius: 15px;
	border: 1px solid #9facdc !important;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.custom-form-input:focus {
	box-shadow: none;
}

.custom-form-input::placeholder {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #9facdc;
}

.custom-form-select {
	width: 20px !important;
	height: 20px !important;
	border-radius: 5px !important;
	border: 1px solid #9facdc !important;
	box-shadow: -7px 7px 25px 0px #9facdc80 !important;
}

.divider {
	display: flex;
	align-items: center;
	text-align: center;
	color: #343434;
}

.divider::before,
.divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: #343434;
}

.divider:not(:empty)::before {
	margin-right: 0.75em;
}

.divider:not(:empty)::after {
	margin-left: 0.75em;
}

.btn-social {
	border-radius: 15px;
	border-width: 1px;
	border: 1px solid #9facdc;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.btn-social:hover {
	background: #9facdc80;
	color: #ffffff;
}

.icon-social {
	width: 20px !important;
	height: 20px !important;
	margin-right: 10px;
	margin-bottom: 5px;
}

/* login page */

/* register */

.input-group.custom-shadow {
	box-shadow: -7px 7px 25px 0px #9facdc80;
	border-radius: 15px;
	overflow: hidden;
	/* agar radius tidak bocor */
	border: 1px solid #9facdc;
}

.input-group .form-control {
	border: none;
	/* karena border sudah di wrapper */
	font-size: 10px;
	padding-top: 10px;
	padding-bottom: 10px;
}

.input-group .form-control::placeholder {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #9facdc;
}

.input-group .input-group-text {
	background-color: transparent;
	border: none;
}

.input-group .form-control:focus,
.input-group .input-group-text:focus {
	outline: none !important;
	box-shadow: none !important;
}

.input-pw-wrapper {
	position: relative;
}

.show-hide-pw {
	position: absolute;
	top: 2px;
	right: 15px;
	z-index: 10;
}

.pw-visibility {
	width: 22px;
	height: auto;
}

.validation-list {
	list-style: none;
	padding-left: 0;
	margin-top: 10px;
}

.validation-list li {
	font-size: 11px;
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 6px;
}

.validation-list li.valid {
	color: #00d26a;
}

.validation-list li.invalid {
	color: red;
}

.validation-list .dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: currentColor;
	/* mengikuti warna teks (valid/invalid) */
	display: inline-block;
}

/* register */

.bottom-nav {
	border-top: 1px solid #e0e0e0;
	border-radius: 16px 16px 0 0;
	background: white;
	padding: 10px 20px;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.bottom-nav a {
	color: #c4c4c4;
}

.bottom-nav a.active {
	color: #fd5c2c;
}

/* navigation */

/* homepage */

.img-banner {
	max-width: 435px;
	width: 100%;
	height: 145px;
	box-shadow: -7px 7px 25px 0px #9facdc80;
	position: relative;
}

.bg-image {
	/* background-image: url('assets/images/banner1.png'); */
	background-size: cover;
	background-position: center;
	background-position-x: -40px;
	position: absolute;
	top: 0;
	left: 0;
	width: 500px;
	height: 100%;
	z-index: 1;
}

.overlay {
	background: linear-gradient(180deg,
			rgba(0, 0, 0, 0) 0%,
			rgba(0, 0, 0, 0.66) 100%);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

.text-overlay {
	top: 50%;
	transform: translateY(-50%);
	font-family: "Gotham", sans-serif;
	font-weight: 700;
	font-size: 30px !important;
	line-height: 30px;
	z-index: 3;
}

.btn-search {
	width: 37;
	height: 37;
	border-width: 1px;
	border-radius: 15px;
	background: #ffffff;
	border: 1px solid #9facdc;
	color: #9facdc;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.btn-search:hover {
	background: #9facdc;
	border: 1px solid #9facdc;
	color: #ffffff;
}

.pb-80 {
	padding-bottom: 80px;
}

.search-bar {
	border-radius: 12px;
}

.category-list {
	font-family: "Poppins", sans-serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: 0%;
}

.category-scroll {
	overflow-x: auto;
	flex-wrap: nowrap;
	-webkit-overflow-scrolling: touch;
	cursor: grab;
	user-select: none;
	scroll-behavior: smooth;
}

.category-scroll::-webkit-scrollbar {
	display: none;
}

.category-btn {
	border-radius: 20px;
	padding: 6px 16px;
	background: #ffffff;
	border: 1px solid #9facdc;
	white-space: nowrap;
}

.category-text {
	font-family: "Poppins", sans-serif;
	font-weight: 500;
	font-size: 14px;
	text-align: center;
}

.category-btn.active {
	background-color: #fd5c2c;
	color: #fff;
	border: none;
}

.product-card {
	border-radius: 16px;
	overflow: hidden;
	box-shadow: -7px 7px 25px 0px #9facdc80;
	padding-bottom: 5px;
}

.product-card-title {
	font-weight: 500;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.product-card-price {
	font-weight: 500;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #959595;
}

@keyframes shimmer {
	0% {
		background-position: -300px 0;
	}

	100% {
		background-position: 300px 0;
	}
}

.skeleton-index-img {
	background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
	background-size: 1000px 100%;
	/* Besar agar shimmer terlihat */
	/* background-repeat: no-repeat; */
	box-shadow: -7px 4px 25px 0px #9facdcb2;
	animation: shimmer 1.5s infinite linear;
	border-radius: 4px;
}

.skeleton-index-img {
	width: 100%;
	max-width: 324px;
	height: 513px;
	border-radius: 15px;
}

.skeleton-img,
.skeleton-name,
.skeleton-price {
	background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
	background-size: 1000px 100%;
	/* Besar agar shimmer terlihat */
	/* background-repeat: no-repeat; */
	animation: shimmer 1.5s infinite linear;
	border-radius: 4px;
}

.skeleton-img {
	width: 100%;
	height: 95px;
}

.skeleton-name {
	width: 100px;
	height: 20px;
	margin-top: 10px;
}

.skeleton-price {
	width: 80px !important;
	height: 20px;
	margin-top: 5px;
}

.card-img-top {
	background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
	background-size: 1000px 100%;
	/* background-repeat: no-repeat; */
	animation: shimmer 1.5s infinite linear;
	width: 100%;
}

.skeleton-detail-img,
.skeleton-detail-name,
.skeleton-detail-qty,
.skeleton-detail-price,
.skeleton-detail-text,
.skeleton-detail-btn {
	background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
	background-size: 1000px 100%;
	/* Besar agar shimmer terlihat */
	/* background-repeat: no-repeat; */
	animation: shimmer 1.5s infinite linear;
}

.skeleton-detail-img {
	width: 100%;
	height: 205px;
	border-radius: 30px;
}

.skeleton-detail-name {
	width: 80%;
	height: 30px;
}

.skeleton-detail-qty {
	width: 30%;
	height: 35px;
}

.skeleton-detail-price {
	width: 30%;
	height: 20px;
}

.skeleton-detail-btn {
	width: 309;
	height: 54;
	border-radius: 127px;
	padding: 25px;
}

.skeleton-detail-text {
	width: 100%;
	height: 50px;
}

.skeleton-cart {
	background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
	background-size: 1000px 100%;
	/* Besar agar shimmer terlihat */
	/* background-repeat: no-repeat; */
	animation: shimmer 1.5s infinite linear;
}

.skeleton-cart {
	width: 100%;
	height: 125px;
	border-radius: 16px;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.product-img {
	width: 100%;
	height: 205px;
	border-radius: 30px;
}

.lh-15 {
	line-height: 15px;
}

/* homepage */

/* product detail */

.btn-outline-title {
	border: 1px solid #ea4620;
	width: 157px;
	padding-top: 5px;
	padding-bottom: 5px;
	border-radius: 5px;
	border-width: 1px;
}

.btn-outline-title:hover {
	background: #ffffff;
	color: #ea4620;
	border: 1px solid #ea4620;
}

.outline-title-text {
	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-size: 12px;
	text-align: center;
	vertical-align: middle;
	color: #ea4620;
}

.button-circle {
	width: 32px;
	height: 32px;
	border: 1px solid #d32f2f;
	/* warna merah */
	color: #ffffff;
	background-color: #ea4620;
	border-radius: 50%;
	/* bikin bulat */
	text-align: center;
	font-size: 18px;
	cursor: pointer;
	line-height: 30px;
	/* vertikal centering */
	margin: 0 5px;
	transition: background-color 0.3s ease;
}

.button-circle:hover {
	background-color: #ea4620;
	/* efek hover */
}

.product-title {
	font-family: "Poppins", sans-serif;
	font-weight: 700;
	font-size: 26px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.price-info {
	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-size: 15px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.add-to-cart-btn {
	width: 309;
	height: 54;
	border-radius: 127px;
	background: #00e243;
	padding: 20px;

	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-size: 24px;
	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;
	color: #ffffff;
}

.add-to-cart-btn:hover {
	background: #00e243 !important;
	color: #ffffff !important;
}

.text-description {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-size: 12px;
	text-align: justify;
	color: #505050;
}

/* navigation */

.bottom-nav {
	border-top: 1px solid #e0e0e0;
	border-radius: 16px 16px 0 0;
	background: white;
	padding: 10px 20px;
	box-shadow: -7px 7px 25px 0px #9facdc80;
}

.bottom-nav a {
	color: #c4c4c4;
}

.bottom-nav a.active {
	color: #fd5c2c;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
	display: none;
}

.btn-to-cart-alert,
.btn-ok-alert {
	width: 80px;
	height: 35px;
	border-radius: 127px;
	padding: 2px;

	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;
	margin: 0 5px;
}

.btn-to-cart-alert {
	background: #ea4620;
	color: #ffffff;
	border: 1px solid #ea4620;
}

.btn-to-cart-alert:hover {
	background: #ffffff;
	color: #ea4620;
	border: 1px solid #ea4620;
}

.btn-ok-alert {
	background: #c4c4c4;
	color: #ffffff;
	border: 1px solid #c4c4c4;
}

.btn-ok-alert:hover {
	background: #ffffff;
	color: #c4c4c4;
	border: 1px solid #c4c4c4;
}

/* checkout */

.checkout-header {
	text-align: center;
	padding: 20px;
}

.checkout-header button {
	border: 1px solid #f44336;
	background-color: white;
	color: #f44336;
	border-radius: 8px;
	padding: 6px 20px;
	font-weight: 500;
}

.checkout-section {
	padding: 20px;
	border-radius: 12px;
	margin-bottom: 1.5rem;
}

.section-title {
	font-weight: 600;
	margin-bottom: 8px;
}

.info-box {
	border: 1px solid #eee;
	border-radius: 12px;
	padding: 12px 16px;
	display: flex;
	align-items: center;
	background-color: #f9f9fc;
}

.info-box i {
	margin-right: 12px;
	font-size: 18px;
	color: #0d6efd;
}

.change-btn {
	font-size: 14px;
	color: #EA4620;
	font-weight: 500;
	text-decoration: none;

	font-family: 'Poppins', sans-serif;
	font-weight: 400;
	font-size: 10px;
	line-height: 100%;
	letter-spacing: 0%;
	text-decoration: underline;
	text-decoration-style: solid;

}

.total-section {
	padding: 60px 20px 20px 20px;
	border-top: 1px solid #959595;
}

.pay-section {
	padding: 30px 20px 30px 20px;
	border-bottom: 1px solid #959595;
}

.pay-btn {
	background-color: #EA4620;
	width: 185px;
	padding: 10px;
	border: none;
	border-radius: 25px;

	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;
	vertical-align: middle;
	color: white;

}

.price-label {
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 11px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.price-value {
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 11px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.total-label {
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 13px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.total-value {
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 13px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #343434;
}

.modal-checkout .modal-title {
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 18px;
	letter-spacing: 0%;
	color: #343434;
}

.modal-checkout .modal-desc {
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 10px;
	line-height: 18px;
	letter-spacing: 0%;
	color: #343434;
}

.btn-modal-tracking {
	background-color: #EA4620;
	border-radius: 25px;
	max-width: 185px;
	padding: 10px 0;
	border: none;

	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: 0%;
	color: white;
}

.btn-modal-tracking:hover {
	background-color: #EA4620 !important;
	color: #ffffff !important;
}

.btn-modal-continue {
	background-color: #C9D4F8;
	border-radius: 25px;
	max-width: 185px;
	padding: 10px 0;
	border: none;

	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: 0%;
	color: white;
}

.btn-modal-continue:hover {
	background-color: #C9D4F8 !important;
	color: #ffffff !important;
}

/* checkout */

/* cart */

.address-card .card.active {
	border: 2px solid #02eb48;
	box-shadow: 0 0 10px rgba(2, 235, 72, 0.4);
}


.address-card .card.empty {
	border: 2px dotted #02eb48;
	box-shadow: 0 0 10px rgba(2, 235, 72, 0.4);
}

.address-name {
	font-size: 10px;
	font-weight: 500;
}

.addresses {
	font-size: 11px;
	font-weight: 600;
}

.modal-title-checkout {
	font-size: 18px;
	font-weight: 600;
}


.payment-card .card.active {
	border: 2px solid #02eb48;
	box-shadow: 0 0 10px rgba(2, 235, 72, 0.4);
}


.payment-card .card.empty {
	border: 2px dotted #02eb48;
	box-shadow: 0 0 10px rgba(2, 235, 72, 0.4);
}

.payment-name {
	font-size: 10px;
	font-weight: 500;
}

.payment-code {
	font-size: 11px;
	font-weight: 600;
}


.courier-price {
	font-size: 10px;
	font-weight: 500;
}

.courier-name {
	font-size: 11px;
	font-weight: 600;
}

.shadow {
	box-shadow: -7px 7px 25px 0px #9FACDC80;
}