/* Cart shortcode [ohoche_cart] — layout per design reference */

.ohoche-cart {
	position: relative !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 24px 20px 28px !important;
	background: #ffffff !important;
	box-sizing: border-box !important;
	font-family: inherit !important;
	color: #403e3c !important;
}

/* ——— Filled ——— */
.ohoche-cart__header {
	margin-bottom: 20px !important;
}

.ohoche-cart__title {
	margin: 0 !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	color: #403e3c !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
}

.ohoche-cart__badge {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 22px !important;
	height: 22px !important;
	padding: 0 6px !important;
	border-radius: 999px !important;
	background: #6fa57c !important;
	color: #ffffff !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
}

.ohoche-cart__badge--muted {
	background: #e8e8e8 !important;
	color: #ffffff !important;
}

.ohoche-cart__items {
	list-style: none !important;
	margin: 0 0 24px !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

.ohoche-cart__item {
	display: grid !important;
	grid-template-columns: 72px 1fr auto !important;
	gap: 12px !important;
	align-items: start !important;
}

.ohoche-cart__item-thumb img {
	width: 72px !important;
	height: 72px !important;
	object-fit: cover !important;
	border-radius: 12px !important;
	display: block !important;
}

.ohoche-cart__item-title {
	font-size: 14px !important;
	font-weight: 600 !important;
	color: #403e3c !important;
	line-height: 1.35 !important;
	margin-bottom: 6px !important;
}

.ohoche-cart__item-price-row {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	gap: 8px !important;
	font-size: 14px !important;
}

.ohoche-cart__price {
	font-weight: 700 !important;
	color: #403e3c !important;
}

.ohoche-cart__price .woocommerce-Price-amount {
	font-weight: inherit !important;
	color: inherit !important;
}

.ohoche-cart__price--sale,
.ohoche-cart__price--sale .woocommerce-Price-amount {
	color: #6fa57c !important;
}

.ohoche-cart__price--old,
.ohoche-cart__price--old .woocommerce-Price-amount {
	color: #b0b0b0 !important;
	font-weight: 400 !important;
	text-decoration: line-through !important;
}

.ohoche-cart__discount {
	display: inline-flex !important;
	align-items: center !important;
	padding: 2px 6px !important;
	border-radius: 6px !important;
	background: #6fa57c !important;
	color: #ffffff !important;
	font-size: 11px !important;
	font-weight: 700 !important;
}

.ohoche-cart__item-meta {
	margin-top: 6px !important;
	font-size: 12px !important;
	color: #9a9a9a !important;
}

.ohoche-cart__item-actions {
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-end !important;
	gap: 10px !important;
}

.ohoche-cart__qty {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0 !important;
	background: #f3f3f3 !important;
	border-radius: 999px !important;
	padding: 4px 6px !important;
}

.ohoche-cart__qty-btn {
	width: 28px !important;
	height: 28px !important;
	border: 0 !important;
	border-radius: 50% !important;
	background: #ffffff !important;
	color: #403e3c !important;
	font-size: 16px !important;
	line-height: 1 !important;
	cursor: pointer !important;
	padding: 0 !important;
	box-shadow: none !important;
}

.ohoche-cart__qty-btn:hover,
.ohoche-cart__qty-btn:focus,
.ohoche-cart__qty-btn:active {
	background: #ffffff !important;
	color: #403e3c !important;
	transform: none !important;
	box-shadow: none !important;
}

.ohoche-cart__qty-val {
	min-width: 22px !important;
	text-align: center !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: #403e3c !important;
}

.ohoche-cart__remove {
	width: 22px !important;
	height: 22px !important;
	font-size: 18px !important;
	line-height: 1 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: #c4c4c4 !important;
	cursor: pointer !important;
	box-shadow: none !important;
}

.ohoche-cart__remove:hover,
.ohoche-cart__remove:focus,
.ohoche-cart__remove:active {
	color: #9a9a9a !important;
	background: transparent !important;
	transform: none !important;
}

/* Upsell */
.ohoche-cart__upsell {
	margin-bottom: 24px !important;
}

.ohoche-cart__upsell-head {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	margin-bottom: 12px !important;
}

.ohoche-cart__upsell-title {
	font-size: 14px !important;
	font-weight: 600 !important;
	color: #403e3c !important;
}

.ohoche-cart__upsell-nav {
	display: flex !important;
	gap: 8px !important;
}

.ohoche-cart__upsell-arrow {
	width: 32px !important;
	height: 32px !important;
	border-radius: 50% !important;
	border: 0 !important;
	padding: 0 !important;
	font-size: 18px !important;
	line-height: 1 !important;
	cursor: pointer !important;
	background: #f0f0f0 !important;
	color: #403e3c !important;
	box-shadow: none !important;
}

.ohoche-cart__upsell-arrow.is-next {
	background: #6fa57c !important;
	color: #ffffff !important;
}

.ohoche-cart__upsell-arrow:hover,
.ohoche-cart__upsell-arrow:focus,
.ohoche-cart__upsell-arrow:active {
	opacity: 0.9 !important;
	transform: none !important;
}

.ohoche-cart__upsell-viewport {
	overflow-x: auto !important;
	overflow-y: hidden !important;
	-webkit-overflow-scrolling: touch !important;
	scrollbar-width: none !important;
	margin: 0 -4px !important;
	padding: 0 4px !important;
}

.ohoche-cart__upsell-viewport::-webkit-scrollbar {
	display: none !important;
}

.ohoche-cart__upsell-track {
	display: flex !important;
	gap: 12px !important;
	padding-bottom: 4px !important;
}

.ohoche-cart__upsell-card {
	flex: 0 0 260px !important;
	display: flex !important;
	gap: 10px !important;
	align-items: stretch !important;
	background: #f6f6f6 !important;
	border-radius: 14px !important;
	padding: 10px !important;
	box-sizing: border-box !important;
}

.ohoche-cart__upsell-thumb img {
	width: 64px !important;
	height: 64px !important;
	object-fit: cover !important;
	border-radius: 10px !important;
	display: block !important;
}

.ohoche-cart__upsell-info {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
	min-width: 0 !important;
}

.ohoche-cart__upsell-name {
	font-size: 12px !important;
	font-weight: 600 !important;
	color: #403e3c !important;
	line-height: 1.3 !important;
}

.ohoche-cart__upsell-prices {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	gap: 6px !important;
	font-size: 12px !important;
}

.ohoche-cart__upsell-add {
	margin-top: auto !important;
	align-self: flex-start !important;
	padding: 8px 18px !important;
	border: 0 !important;
	border-radius: 999px !important;
	background: #f4d77a !important;
	color: #403e3c !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	box-shadow: none !important;
}

.ohoche-cart__upsell-add:hover,
.ohoche-cart__upsell-add:focus,
.ohoche-cart__upsell-add:active {
	background: #efd166 !important;
	color: #403e3c !important;
	transform: none !important;
	box-shadow: none !important;
}

/* Footer */
.ohoche-cart__footer {
	border-top: 0 !important;
	padding-top: 8px !important;
}

.ohoche-cart__total-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-bottom: 16px !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	color: #403e3c !important;
}

.ohoche-cart__total-row .woocommerce-Price-amount {
	font-weight: 700 !important;
	color: #403e3c !important;
}

.ohoche-cart__checkout {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	padding: 16px 20px !important;
	border-radius: 999px !important;
	background: #f4d77a !important;
	color: #403e3c !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	box-sizing: border-box !important;
	box-shadow: none !important;
	border: 0 !important;
}

.ohoche-cart__checkout:hover,
.ohoche-cart__checkout:focus,
.ohoche-cart__checkout:active {
	background: #efd166 !important;
	color: #403e3c !important;
	text-decoration: none !important;
	transform: none !important;
	box-shadow: none !important;
}

.ohoche-cart__payments {
	display: flex !important;
	justify-content: center !important;
	flex-wrap: wrap !important;
	gap: 8px !important;
	margin-top: 16px !important;
}

.ohoche-cart__pay {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 52px !important;
	height: 28px !important;
	padding: 0 8px !important;
	border-radius: 8px !important;
	background: #f0f0f0 !important;
	color: #9a9a9a !important;
	font-size: 9px !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
}

/* Empty — illustration + typography like mockup (not a full-page screenshot) */
.ohoche-cart__empty {
	text-align: center !important;
}

.ohoche-cart__empty-visual {
	margin: 0 auto 24px !important;
}

.ohoche-cart__empty-img {
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	display: block !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.ohoche-cart__empty-title {
	margin: 0 0 12px !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	color: #403e3c !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	flex-wrap: wrap !important;
}

.ohoche-cart__empty-text {
	margin: 0 0 24px !important;
	font-size: 14px !important;
	line-height: 1.45 !important;
	color: #403e3c !important;
	max-width: 320px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.ohoche-cart__btn--catalog {
	display: inline-block !important;
	padding: 14px 32px !important;
	border-radius: 999px !important;
	background: #7da082 !important;
	color: #ffffff !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border: 0 !important;
	box-shadow: none !important;
}

.ohoche-cart__btn--catalog:hover,
.ohoche-cart__btn--catalog:focus,
.ohoche-cart__btn--catalog:active {
	background: #6d9272 !important;
	color: #ffffff !important;
	text-decoration: none !important;
	transform: none !important;
	box-shadow: none !important;
}
