/* =========================================================
   LOVA CHECKOUT CSS - CLEAN / NO CONFLICT VERSION
   Chỉ áp dụng cho template checkout có class .lova-checkout-form
   ========================================================= */

/* reset conflict từ css cũ */
.woocommerce-checkout form.checkout.lova-checkout-form {
	display: block !important;
	width: 100%;
	margin: 0;
	padding: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form::before,
.woocommerce-checkout form.checkout.lova-checkout-form::after {
	content: "";
	display: table;
	clear: both;
}

.woocommerce-checkout form.checkout.lova-checkout-form > .col2-set,
.woocommerce-checkout form.checkout.lova-checkout-form > #order_review_heading,
.woocommerce-checkout form.checkout.lova-checkout-form > #order_review {
	float: none !important;
	width: auto !important;
	margin: 0 !important;
}

.woocommerce-checkout form.checkout.lova-checkout-form #customer_details,
.woocommerce-checkout form.checkout.lova-checkout-form #order_review,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table {
	float: none !important;
	width: 100% !important;
}

/* page */
.woocommerce-checkout .site-main,
.woocommerce-order-received .site-main {
	padding-top: 24px;
	padding-bottom: 40px;
}

.woocommerce-checkout h1.entry-title,
.woocommerce-order-received h1.entry-title {
	margin-bottom: 20px;
}

/* notice */
.woocommerce-checkout .woocommerce-notices-wrapper,
.woocommerce-checkout form.checkout.lova-checkout-form > .woocommerce-NoticeGroup,
.woocommerce-checkout form.checkout.lova-checkout-form > .woocommerce-error,
.woocommerce-checkout form.checkout.lova-checkout-form > .woocommerce-info,
.woocommerce-checkout form.checkout.lova-checkout-form > .woocommerce-message {
	width: 100%;
	margin: 0 0 20px;
}

.woocommerce-checkout .woocommerce-NoticeGroup ul,
.woocommerce-checkout ul.woocommerce-error,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
	margin: 0;
	padding: 14px 16px;
	border: 1px solid #e5e5e5;
	background: #fff;
	box-shadow: none;
	font-size: 15px;
	line-height: 1.6;
}

.woocommerce-checkout ul.woocommerce-error,
.woocommerce-checkout .woocommerce-info {
	border-left: 3px solid #f47e20;
}

/* coupon */
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout .checkout_coupon {
	width: 100%;
}

.woocommerce-checkout .woocommerce-form-coupon-toggle {
	margin-bottom: 20px;
}

.woocommerce-checkout .checkout_coupon {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	padding: 18px;
	border: 1px solid #e8e8e8;
	background: #fff;
	margin-bottom: 24px;
}

.woocommerce-checkout .checkout_coupon .form-row-first {
	flex: 1 1 260px;
	margin-bottom: 0;
}

.woocommerce-checkout .checkout_coupon .form-row-last {
	flex: 0 0 auto;
	margin-bottom: 0;
}

/* main layout */
.lova-checkout-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 380px);
	gap: 28px;
	align-items: start;
	width: 100%;
}

.lova-checkout-main,
.lova-checkout-sidebar {
	min-width: 0;
}

.lova-checkout-box {
	background: #fff;
	border: 1px solid #e8e8e8;
	padding: 22px;
	margin-bottom: 22px;
}

.lova-checkout-box--order {
	position: sticky;
	top: 20px;
}

/* section title */
.lova-checkout-box h3,
#order_review_heading,
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields > h3,
.woocommerce-additional-fields > h3 {
	margin: 0 0 18px;
	font-size: 18px;
	line-height: 1.4;
	font-weight: 600;
	color: #222;
}

/* fields */
.woocommerce-checkout form.checkout.lova-checkout-form .form-row {
	margin: 0 0 16px;
	padding: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form .form-row label {
	display: block;
	margin: 0 0 8px;
	font-size: 14px;
	font-weight: 500;
	color: #333;
}

.woocommerce-checkout form.checkout.lova-checkout-form .required {
	color: #f47e20;
	text-decoration: none;
}

.woocommerce-checkout form.checkout.lova-checkout-form .input-text,
.woocommerce-checkout form.checkout.lova-checkout-form select,
.woocommerce-checkout form.checkout.lova-checkout-form textarea,
.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default .select2-selection--single {
	width: 100%;
	height: 46px;
	padding: 0 14px;
	border: 1px solid #dcdcdc;
	border-radius: 0;
	background: #fff;
	font-size: 15px;
	color: #222;
	box-shadow: none;
	transition: border-color .2s ease, box-shadow .2s ease;
}

.woocommerce-checkout form.checkout.lova-checkout-form textarea {
	height: 110px;
	padding-top: 12px;
	padding-bottom: 12px;
	resize: vertical;
}

.woocommerce-checkout form.checkout.lova-checkout-form .input-text:focus,
.woocommerce-checkout form.checkout.lova-checkout-form select:focus,
.woocommerce-checkout form.checkout.lova-checkout-form textarea:focus,
.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default.select2-container--open .select2-selection--single {
	border-color: #f47e20;
	outline: none;
	box-shadow: 0 0 0 1px rgba(244, 126, 32, .08);
}

.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default .select2-selection--single {
	display: flex;
	align-items: center;
}

.woocommerce-checkout form.checkout.lova-checkout-form .select2-container .select2-selection--single .select2-selection__rendered {
	padding-left: 0;
	padding-right: 26px;
	line-height: 44px;
	color: #222;
}

.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 44px;
	right: 10px;
}

/* billing/shipping fields 2 cột desktop */
@media (min-width: 768px) {
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-billing-fields__field-wrapper,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-shipping-fields__field-wrapper {
		display: flex;
		flex-wrap: wrap;
		column-gap: 18px;
	}

	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-billing-fields__field-wrapper .form-row-first,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-billing-fields__field-wrapper .form-row-last,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row-first,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row-last {
		width: calc(50% - 9px);
	}

	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-billing-fields__field-wrapper .form-row-wide,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row-wide {
		width: 100%;
	}
}

/* review order */
.lova-review-order-table,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
	background: #fff;
}

.lova-review-order-table th,
.lova-review-order-table td,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table th,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table td {
	padding: 14px 0;
	border-bottom: 1px solid #ededed;
	text-align: left;
	vertical-align: top;
	font-size: 14px;
	line-height: 1.5;
}

.lova-review-order-table thead th,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table thead th {
	padding-top: 0;
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: #666;
}

.lova-review-order-table td.product-total,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table td.product-total,
.lova-review-order-table tfoot td,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table tfoot td {
	text-align: right;
}

.lova-review-order__name {
	display: inline-block;
	font-weight: 500;
	color: #222;
}

.woocommerce-checkout form.checkout.lova-checkout-form .product-quantity {
	display: inline-block;
	margin-left: 6px;
	font-weight: 600;
	color: #666;
}

.lova-review-order-table tfoot th,
.lova-review-order-table tfoot td,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table tfoot td {
	font-weight: 600;
}

.lova-review-order-table tr.order-total th,
.lova-review-order-table tr.order-total td,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table tr.order-total th,
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table tr.order-total td {
	border-bottom: 0;
	padding-bottom: 0;
	font-size: 16px;
	color: #222;
}

/* payment */
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-payment,
.woocommerce-checkout form.checkout.lova-checkout-form .lova-payment {
	margin-top: 24px;
	padding-top: 22px;
	border-top: 1px solid #ececec;
	background: transparent;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods {
	list-style: none;
	margin: 0 0 18px;
	padding: 0;
	border: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .wc_payment_method {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #ededed;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .wc_payment_method:last-child {
	border-bottom: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .wc_payment_method > label {
	/*display: flex;
	align-items: center;
	gap: 8px;*/
	padding: 14px 0;
	margin: 0;
	font-size: 15px;
	font-weight: 500;
	color: #222;
	cursor: pointer;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .input-radio {
	margin: 0;
	position: relative;
	top: -1px;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .payment_box {
	margin: 0 0 14px 24px;
	padding: 14px 16px;
	background: #fafafa;
	border: 1px solid #ebebeb;
	font-size: 14px;
	line-height: 1.7;
	color: #444;
}

.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .payment_box::before {
	display: none;
}

/* terms */
.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-terms-and-conditions-wrapper {
	margin: 14px 0 16px;
	font-size: 14px;
	line-height: 1.6;
	color: #444;
}

.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-terms-and-conditions-wrapper .form-row {
	margin-bottom: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-form__label-for-checkbox {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
}

.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-form__label-for-checkbox input[type="checkbox"] {
	margin-top: 3px;
}

.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-invalid-required-field .woocommerce-terms-and-conditions-wrapper,
.woocommerce-checkout form.checkout.lova-checkout-form .validate-required.woocommerce-invalid .woocommerce-terms-and-conditions-wrapper {
	padding: 12px;
	border: 1px solid #e24c4b;
	background: #fff8f8;
}

/* button */
.woocommerce-checkout form.checkout.lova-checkout-form button.button,
.woocommerce-checkout form.checkout.lova-checkout-form input.button,
.woocommerce-checkout form.checkout.lova-checkout-form #payment #place_order,
.woocommerce-checkout form.checkout.lova-checkout-form .lova-payment__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 22px;
	border: 0;
	border-radius: 0;
	background: #f47e20;
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	line-height: 1;
	text-align: center;
	box-shadow: none;
	transition: opacity .2s ease;
}

.woocommerce-checkout form.checkout.lova-checkout-form #payment #place_order,
.woocommerce-checkout form.checkout.lova-checkout-form .lova-payment__submit {
	width: 100%;
}

.woocommerce-checkout form.checkout.lova-checkout-form button.button:hover,
.woocommerce-checkout form.checkout.lova-checkout-form input.button:hover,
.woocommerce-checkout form.checkout.lova-checkout-form #payment #place_order:hover {
	background: #f47e20;
	color: #fff;
	opacity: .92;
}

.woocommerce-checkout form.checkout.lova-checkout-form #payment .place-order,
.woocommerce-checkout form.checkout.lova-checkout-form .lova-payment__footer {
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
}

/* shipping method */
.woocommerce-checkout form.checkout.lova-checkout-form #shipping_method {
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce-checkout form.checkout.lova-checkout-form #shipping_method li {
	margin: 0 0 8px;
}

/* mobile */
@media (max-width: 991px) {
	.lova-checkout-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.lova-checkout-box {
		padding: 18px;
		margin-bottom: 18px;
	}

	.lova-checkout-box--order {
		position: static;
		top: auto;
	}
}

@media (max-width: 767px) {
	.woocommerce-checkout .site-main,
	.woocommerce-order-received .site-main {
		padding-top: 16px;
		padding-bottom: 28px;
	}

	.woocommerce-checkout h1.entry-title,
	.woocommerce-order-received h1.entry-title {
		margin-bottom: 14px;
		font-size: 30px;
		line-height: 1.2;
	}

	.lova-checkout-box {
		padding: 16px;
	}

	.lova-checkout-box h3,
	#order_review_heading,
	.woocommerce-billing-fields > h3,
	.woocommerce-shipping-fields > h3,
	.woocommerce-additional-fields > h3 {
		font-size: 20px;
		margin-bottom: 14px;
	}

	.woocommerce-checkout form.checkout.lova-checkout-form .input-text,
	.woocommerce-checkout form.checkout.lova-checkout-form select,
	.woocommerce-checkout form.checkout.lova-checkout-form textarea,
	.woocommerce-checkout form.checkout.lova-checkout-form .select2-container--default .select2-selection--single {
		height: 44px;
		font-size: 14px;
	}

	.woocommerce-checkout form.checkout.lova-checkout-form textarea {
		height: 96px;
	}

	.woocommerce-checkout .checkout_coupon {
		display: block;
	}

	.woocommerce-checkout .checkout_coupon .form-row-first,
	.woocommerce-checkout .checkout_coupon .form-row-last {
		width: 100%;
	}

	.woocommerce-checkout .checkout_coupon .form-row-last {
		margin-top: 10px;
	}

	.woocommerce-checkout form.checkout.lova-checkout-form .wc_payment_methods .payment_box {
		margin-left: 0;
	}

	.lova-review-order-table th,
	.lova-review-order-table td,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table th,
	.woocommerce-checkout form.checkout.lova-checkout-form .woocommerce-checkout-review-order-table td {
		font-size: 13px;
		padding: 12px 0;
	}
}

/* thankyou */
.lova-order-received {
	background: #fff;
	border: 1px solid #e8e8e8;
	padding: 24px;
}

.lova-order-received__heading {
	margin: 0 0 12px;
	font-size: 28px;
	line-height: 1.2;
}

.woocommerce-order-overview.order_details {
	list-style: none;
	margin: 20px 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

.woocommerce-order-overview.order_details li {
	flex: 1 1 220px;
	margin: 0;
	padding: 14px 16px;
	border: 1px solid #ececec;
	background: #fff;
	font-size: 14px;
	line-height: 1.6;
}

.lova-bank-box {
	margin-top: 20px;
	padding: 18px;
	border: 1px solid #ececec;
	background: #fafafa;
}

.lova-bank-box h3 {
	margin: 0 0 10px;
	font-size: 18px;
}

@media (max-width: 767px) {
	.lova-order-received {
		padding: 16px;
	}

	.lova-order-received__heading {
		font-size: 24px;
	}

	.woocommerce-order-overview.order_details {
		display: block;
	}

	.woocommerce-order-overview.order_details li {
		margin-bottom: 10px;
	}
}
