/* Checkout
--------------------------------------------------------------- */
.checkout-preloader {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.checkout-preloader-text {
	margin-top: 1rem;
	text-align: center;
}
main.checkout.checkout--loading .checkout-form {
	overflow: hidden;
	height: 30vh;
	opacity: 0;
	visibility: hidden;
}
main.checkout:not(.checkout--loading) .checkout-preloader {
	display: none;
}

.checkout-wrapper {
	position: relative;
}

.checkout-form {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem 3rem;
}

.checkout-title {
	margin-bottom: 1rem;
	color: var(--c-light-gray);
	font-size: var(--fs-md);
	font-family: var(--font-body);
}

/* Checkout Details */
.checkout-details-section + .checkout-details-section {
	margin-top: 2rem;
}
.checkout-details-fields > input {
	margin-bottom: 1rem;
}
.checkout-details-note {
	max-width: 480px;
	margin-top: 2rem;
	color: var(--c-light-gray);
	font-size: var(--fs-2xs);
}
.checkout-details-note p a {
	--link-color: var(--c-orange);
	--link-hover-color: var(--c-gray);
	text-decoration: underline;
	text-underline-offset: 0.125em;
}

/* Checkout Products */
.checkout-products-item {
	--qty-max-width: 140px;
	--qty-height: 2rem;
	--qty-font-size: var(--fs-2xs);
	position: relative;
	display: grid;
	grid-template-areas: 'details details details'
											 'price-per quantity total-price';
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem 0.25rem;
	justify-content: space-between;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--c-border);
}
.checkout-products-item + .checkout-products-item {
	margin-top: 1rem;
}
.checkout-products-item .details {
	grid-area: details;
	display: flex;
	padding-right: 3rem;
}
.checkout-products-item .details-photo {
	flex: 0 0 auto;
	width: 56px;
	height: 56px;
	border-radius: var(--border-radius);
}
.checkout-products-item .details-meta {
	margin-left: 1rem;
}
.checkout-products-item .details-meta .title {
	font-family: var(--font-body);
	font-size: var(--fs-xs);
	font-weight: var(--fw-bold);
	line-height: 1.15;
}
.checkout-products-item .details-meta .attributes {
	margin-top: 0.25rem;
}
.checkout-products-item .details-meta .attributes > li {
	display: inline-block;
	color: var(--c-light);
	font-size: var(--fs-2xs);
	line-height: 1;
}
.checkout-products-item .details-meta .attributes > li:not(:last-child)::after {
	content: ',';
}
.checkout-products-item .price-per {
	grid-area: price-per;
}
.checkout-products-item .quantity {
	grid-area: quantity;
	justify-self: center;
}
.checkout-products-item .total-price {
	grid-area: total-price;
	align-items: flex-end;
	text-align: right;
}
.checkout-products-item .remove {
	grid-area: remove;
	align-self: center;
	position: absolute;
	top: 0;
	right: 0;
}
.checkout-products-item .price ins {
	font-family: var(--font-body);
	font-size: var(--fs-2xs);
}
.checkout-products-item .price del {
	margin-top: 0.25rem;
}

/* Checkout Summary */
.checkout-summary {
	grid-column: 1/-1;
}
.checkout-summary-total {
	color: var(--c-orange);
	font-family: var(--font-heading);
	font-size: var(--fs-sm);
	font-weight: var(--fw-bold);
	text-align: left;
}
.checkout-summary-total > span {
	color: var(--c-gray);
}
.checkout-summary-total > ins {
	text-decoration: none;
}
.checkout-summary-actions {
	grid-column: 1/-1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	justify-content: center;
	margin-top: 2.5rem;
}
.checkout-summary .checkout-submit {
	order: -1;
}

@media (min-width: 576px) {
	.checkout-products-item .price ins {
		font-size: var(--fs-xs);
	}
	.checkout-summary-total {
		font-size: var(--fs-md);
		text-align: right;
	}
	.checkout-summary-actions {
		grid-template-columns: auto auto;
		justify-content: space-between;
	}
	.checkout-summary .checkout-submit {
		order: initial;
	}
}

@media (min-width: 768px) {
	.checkout-form {
		grid-template-columns: 240px 1fr;
	}
	.checkout-details {
		order: -1;
	}
	.checkout-title {
		margin-bottom: 2rem;
	}
	.checkout-summary-actions {
		margin-top: 4rem;
	}
}

@media (min-width: 992px) {
	.checkout-products-item {
		--qty-height: 2.5rem;
		grid-template-areas: 'details price-per quantity total-price remove';
		grid-template-columns: 1fr 22% auto 22% auto;
	}
	.checkout-products-item .details {
		padding-right: 0;
	}
	.checkout-products-item .details-meta .attributes {
		margin-top: 1rem;
	}
	.checkout-products-item .details-meta .attributes > li {
		display: block;
	}
	.checkout-products-item .details-meta .attributes > li::after {
		display: none;
	}
	.checkout-products-item .details-meta .attributes > li:not(:last-child) {
		margin-bottom: 0.5rem;
	}
	.checkout-products-item .price-per,
	.checkout-products-item .total-price {
		justify-self: center;
		text-align: center;
	}
	.checkout-products-item .quantity {
		align-self: center;
	}
	.checkout-products-item .remove {
		position: static;
	}
}

@media (min-width: 1200px) {
	.checkout-form {
		grid-template-columns: 280px 1fr;
		column-gap: 4.5rem;
	}
	.checkout-products-item {
		--qty-max-width: 160px;
		--qty-height: 3rem;
		--qty-font-size: var(--fs-xs);
	}
	.checkout-products-item .details-photo {
		width: 100px;
		height: 90px;
	}
	.checkout-products-item .details-meta {
		margin-left: 1.5rem;
	}
}