﻿/**
 * Cart shortcodes styles.
 *
 * @package Kadence_Child
 */

/* Notices
-------------------------------------------------------------- */
.kc-cart-notices:empty {
	display: none;
}

.kc-cart-notices .woocommerce-notices-wrapper:empty {
	display: none;
}

.kc-cart-notices .woocommerce-message,
.kc-cart-notices .woocommerce-info,
.kc-cart-notices .woocommerce-error,
.kc-cart-notices ul.woocommerce-error {
	border-radius: 12px;
	padding: 14px 18px;
	margin: 0 0 16px;
	font-size: 15px;
	border: 1px solid transparent;
	list-style: none;
}

.kc-cart-notices .woocommerce-message {
	background: color-mix(in srgb, var(--global-palette1, #091a3d) 10%, transparent);
	border-color: color-mix(in srgb, var(--global-palette1, #091a3d) 30%, transparent);
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart-notices .woocommerce-info {
	background: var(--global-palette8, #f6f7f9);
	border-color: var(--global-palette6, #e5e7eb);
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart-notices .woocommerce-error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #991b1b;
}

.kc-cart-notices .button {
	margin-left: 12px;
}

/* Items
-------------------------------------------------------------- */
.kc-cart__form {
	margin: 0;
}

.kc-cart__items {
	list-style: none;
	margin: 0 0 20px !important;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.kc-cart__item {
	display: flex;
	gap: 18px;
	padding: 18px;
	background: var(--global-palette9, #fff);
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 16px;
}

.kc-cart__item-thumb {
	flex: 0 0 96px;
	width: 96px;
}

.kc-cart__item-thumb img {
	width: 100%;
	height: auto;
	border-radius: 10px;
	display: block;
	object-fit: cover;
	aspect-ratio: 1 / 1;
}

.kc-cart__item-body {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-width: 0;
}

.kc-cart__item-head {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	justify-content: space-between;
}

.kc-cart__item-title {
	margin: 0;
	font-size: 17px;
	font-weight: 600;
	line-height: 1.3;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__item-title a {
	color: inherit;
	text-decoration: none;
}

.kc-cart__item-title a:hover {
	color: var(--global-palette1, #091a3d);
}

.kc-cart__item-remove {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: transparent;
	color: var(--global-palette5, #2b2f3a);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
	padding: 0;
}

.kc-cart__item-remove:hover {
	background: var(--global-palette2, #0f274f);
	color: var(--global-palette9, #fff);
}

.kc-cart__item-meta {
	font-size: 13px;
	color: var(--global-palette6, #6b7280);
}

.kc-cart__item-meta dl,
.kc-cart__item-meta p {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px 12px;
}

.kc-cart__item-meta dt {
	font-weight: 600;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__item-meta dd {
	margin: 0;
}

.kc-cart__item-meta dd p {
	margin: 0;
	display: inline;
}

.kc-cart__item-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: auto;
}

/* Quantity
-------------------------------------------------------------- */
.kc-cart__item-qty {
	display: inline-flex;
	align-items: stretch;
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 10px;
	overflow: hidden;
	background: var(--global-palette9, #fff);
}

.kc-cart__qty-btn {
	width: 36px;
	border: 0;
	background: transparent;
	color: var(--global-palette5, #2b2f3a);
	cursor: pointer;
	font-size: 18px;
	line-height: 1;
	padding: 0;
	transition: background 0.15s;
}

.kc-cart__qty-btn:hover:not(:disabled) {
	background: var(--global-palette2, #0f274f);
	color: var(--global-palette9, #fff);
}

.kc-cart__qty-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.kc-cart__qty-input {
	width: 48px;
	border: 0 !important;
	background: transparent !important;
	text-align: center;
	font-size: 15px;
	font-weight: 600;
	color: var(--global-palette5, #2b2f3a) !important;
	-moz-appearance: textfield;
	padding: 6px 0;
}

.kc-cart__qty-input::-webkit-outer-spin-button,
.kc-cart__qty-input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.kc-cart__qty-input:focus {
	outline: none;
}

/* Item prices
-------------------------------------------------------------- */
.kc-cart__item-prices {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 4px;
	text-align: right;
}

.kc-cart__item-price,
.kc-cart__item-subtotal {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
}

.kc-cart__item-price {
	font-size: 13px;
	color: var(--global-palette6, #6b7280);
}

.kc-cart__item-price-label,
.kc-cart__item-subtotal-label {
	font-size: 12px;
	font-weight: 500;
	color: var(--global-palette6, #6b7280);
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.kc-cart__item-price-value {
	font-weight: 500;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__item-subtotal {
	font-size: 17px;
	font-weight: 700;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__item-subtotal-value {
	font-weight: 700;
}

/* Item loading state while AJAX runs */
.kc-cart__item.is-loading {
	opacity: 0.5;
	pointer-events: none;
	transition: opacity 0.15s;
}

.kc-cart__coupon.is-loading,
.kc-cart__totals.is-loading {
	opacity: 0.6;
	pointer-events: none;
}

/* Remove-coupon button inside totals */
.kc-cart__coupon-remove {
	background: transparent;
	border: 0;
	padding: 0 0 0 4px;
	margin: 0;
	color: var(--global-palette6, #6b7280);
	cursor: pointer;
	font-size: 16px;
	line-height: 1;
	vertical-align: middle;
	transition: color 0.15s;
}

.kc-cart__coupon-remove:hover {
	color: #dc2626;
}

/* Actions
-------------------------------------------------------------- */
.kc-cart__actions {
	display: flex;
	justify-content: flex-end;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 24px;
}

/* Coupon
-------------------------------------------------------------- */
.kc-cart__coupon {
	padding: 18px;
	background: var(--global-palette9, #fff);
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 16px;
	margin-bottom: 20px;
}

.kc-cart__coupon-label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--global-palette5, #2b2f3a);
	margin-bottom: 10px;
}

.kc-cart__coupon-row {
	display: flex;
	gap: 8px;
}

.kc-cart__coupon-input {
	flex: 1 1 auto;
	min-width: 0;
	padding: 10px 14px;
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 10px;
	font-size: 15px;
	background: var(--global-palette9, #fff);
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__coupon-input:focus {
	outline: none;
	border-color: var(--global-palette1, #091a3d);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--global-palette1, #091a3d) 20%, transparent);
}

.kc-cart__coupon-btn {
	flex: 0 0 auto;
}

.kc-cart__coupon-btn:hover,
.kc-cart__coupon-btn:focus {
	box-shadow: none;
}

/* Totals
-------------------------------------------------------------- */
.kc-cart__totals {
	padding: 24px;
	background: var(--global-palette9, #fff);
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 16px;
	position: sticky;
	top: 24px;
}

.kc-cart__totals-title {
	margin: 0 0 18px;
	font-size: 20px;
	font-weight: 700;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart__totals-rows {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 20px;
}

.kc-cart__totals-row {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	font-size: 15px;
	color: var(--global-palette6, #6b7280);
}

.kc-cart__totals-row > span:last-child {
	color: var(--global-palette5, #2b2f3a);
	font-weight: 500;
}

.kc-cart__totals-row--coupon > span:last-child {
	color: var(--global-palette1, #091a3d);
}

.kc-cart__totals-row--total {
	padding-top: 14px;
	border-top: 1px solid var(--global-palette6, #e5e7eb);
	font-size: 17px;
}

.kc-cart__totals-row--total > span {
	color: var(--global-palette5, #2b2f3a) !important;
	font-weight: 700 !important;
}

.kc-cart__totals-row--total .amount {
	font-size: 20px;
}

.kc-cart__checkout-btn {
	display: block;
	width: 100%;
	text-align: center;
}

.kc-cart__checkout-btn:hover,
.kc-cart__checkout-btn:focus {
	box-shadow: none;
}

/* Empty state
-------------------------------------------------------------- */
.kc-cart-empty {
	text-align: center;
	padding: 60px 24px;
	background: var(--global-palette9, #fff);
	border: 1px solid var(--global-palette6, #e5e7eb);
	border-radius: 16px;
}

.kc-cart-empty__icon {
	color: var(--global-palette5, #9ca3af);
	margin-bottom: 18px;
}

.kc-cart-empty__title {
	margin: 0 0 10px;
	font-size: 24px;
	font-weight: 700;
	color: var(--global-palette5, #2b2f3a);
}

.kc-cart-empty__text {
	margin: 0 0 24px;
	font-size: 16px;
	color: var(--global-palette6, #6b7280);
}

/* Cross-sells
-------------------------------------------------------------- */
.kc-cart-cross-sells {
	margin-top: 40px;
}

.kc-cart-cross-sells__title {
	margin: 0 0 20px;
	font-size: 22px;
	font-weight: 700;
	color: var(--global-palette5, #2b2f3a);
}

/* Mobile
-------------------------------------------------------------- */
@media (max-width: 600px) {
	.kc-cart__item {
		padding: 14px;
		gap: 12px;
	}

	.kc-cart__item-thumb {
		flex-basis: 72px;
		width: 72px;
	}

	.kc-cart__item-title {
		font-size: 15px;
	}

	.kc-cart__item-foot {
		gap: 10px;
	}

	.kc-cart__item-subtotal {
		font-size: 15px;
	}

	.kc-cart__totals {
		position: static;
	}

	.kc-cart__actions {
		justify-content: stretch;
	}

	.kc-cart__update {
		width: 100%;
	}
}
