/**
 * EWCW – Modern WooCommerce Cart Widget
 * Overrides Hello Elementor / CSS resets
 * Design: Editorial luxury – dark ink, cream whites, Elementor primary accent
 */

/* =====================================================================
   CSS Custom Properties (overrideable via Elementor controls)
   ===================================================================== */
.ewcw-cart {
	--ewcw-accent:      var(--e-global-color-primary, #0a0a0a);
	--ewcw-accent-rgb:  10,10,10;
	--ewcw-gold:        var(--e-global-color-primary, #c9a84c);
	--ewcw-gold-light:  #f0dfa0;
	--ewcw-bg:          #ffffff;
	--ewcw-surface:     #f7f6f4;
	--ewcw-border:      #e8e8e4;
	--ewcw-text:        #1a1a1a;
	--ewcw-muted:       #888880;
	--ewcw-danger:      #d94f4f;
	--ewcw-success:     #3a9b6e;
	--ewcw-radius:      16px;
	--ewcw-radius-sm:   8px;
	--ewcw-shadow:      0 4px 32px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
	--ewcw-shadow-hover:0 8px 48px rgba(0,0,0,.13), 0 2px 8px rgba(0,0,0,.07);
	--ewcw-transition:  0.25s cubic-bezier(.4,0,.2,1);
	--ewcw-thumb-size:  88px;

	/* Fonts */
	--ewcw-font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;
	--ewcw-font-body:    'DM Sans', system-ui, -apple-system, sans-serif;

	/* Z-index stack */
	--ewcw-z-loader:  10;
	--ewcw-z-toast:   20;
}

/* =====================================================================
   Google Fonts Import
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* =====================================================================
   Reset & base – forcefully override Hello Elementor zero-specificity
   ===================================================================== */
.ewcw-cart,
.ewcw-cart *,
.ewcw-cart *::before,
.ewcw-cart *::after {
	box-sizing: border-box !important;
	margin: 0;
	padding: 0;
	font-family: var(--ewcw-font-body) !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.ewcw-cart ul,
.ewcw-cart ol {
	list-style: none !important;
}

.ewcw-cart a {
	color: inherit;
	text-decoration: none;
}

.ewcw-cart button {
	background: none;
	border: none;
	cursor: pointer;
	line-height: 1;
}

.ewcw-cart input[type="number"] {
	-moz-appearance: textfield;
}
.ewcw-cart input[type="number"]::-webkit-outer-spin-button,
.ewcw-cart input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

/* =====================================================================
   Root container
   ===================================================================== */
.ewcw-cart {
	position: relative;
	background: var(--ewcw-bg);
	border-radius: var(--ewcw-radius);
	box-shadow: var(--ewcw-shadow);
	overflow: hidden;
	font-family: var(--ewcw-font-body) !important;
	color: var(--ewcw-text);
}

/* =====================================================================
   Loader overlay
   ===================================================================== */
.ewcw-loader {
	position: absolute;
	inset: 0;
	background: rgba(255,255,255,.75);
	backdrop-filter: blur(4px);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: var(--ewcw-z-loader);
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--ewcw-transition);
}

.ewcw-cart.is-loading .ewcw-loader {
	opacity: 1;
	pointer-events: all;
}

.ewcw-spinner {
	width: 28px;
	height: 28px;
	border: 2.5px solid var(--ewcw-border);
	border-top-color: var(--ewcw-accent);
	border-radius: 50%;
	animation: ewcw-spin .7s linear infinite;
}

@keyframes ewcw-spin {
	to { transform: rotate(360deg); }
}

/* =====================================================================
   Header
   ===================================================================== */
.ewcw-header {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 24px 28px 20px !important;
	border-bottom: 1px solid var(--ewcw-border) !important;
	background: var(--ewcw-bg) !important;
}

.ewcw-title {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	font-family: var(--ewcw-font-display) !important;
	font-size: 1.45rem !important;
	font-weight: 600 !important;
	letter-spacing: -.02em !important;
	color: var(--ewcw-text) !important;
	line-height: 1.2 !important;
}

.ewcw-title svg {
	width: 22px !important;
	height: 22px !important;
	flex-shrink: 0 !important;
	color: var(--ewcw-gold) !important;
}

.ewcw-count-badge {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 26px !important;
	height: 26px !important;
	padding: 0 7px !important;
	background: var(--ewcw-accent) !important;
	color: #fff !important;
	font-size: .72rem !important;
	font-weight: 600 !important;
	letter-spacing: .04em !important;
	border-radius: 100px !important;
	font-family: var(--ewcw-font-body) !important;
	transition: transform var(--ewcw-transition) !important;
}

.ewcw-count-badge.bump {
	animation: ewcw-bump .3s cubic-bezier(.4,0,.2,1);
}

@keyframes ewcw-bump {
	0%   { transform: scale(1); }
	50%  { transform: scale(1.35); }
	100% { transform: scale(1); }
}

/* =====================================================================
   Body
   ===================================================================== */
.ewcw-body {
	display: grid !important;
	grid-template-columns: 1fr 340px !important;
	gap: 0 !important;
	align-items: start !important;
}

@media (max-width: 900px) {
	.ewcw-body {
		grid-template-columns: 1fr !important;
	}
}

/* =====================================================================
   Empty state
   ===================================================================== */
.ewcw-empty {
	grid-column: 1 / -1 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 64px 32px !important;
	gap: 20px !important;
	text-align: center !important;
}

.ewcw-empty__icon svg {
	width: 64px !important;
	height: 64px !important;
	color: var(--ewcw-border) !important;
}

.ewcw-empty__text {
	font-size: 1rem !important;
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
}

/* =====================================================================
   Items list
   ===================================================================== */
.ewcw-items {
	padding: 8px 0 !important;
	border-right: 1px solid var(--ewcw-border) !important;
}

@media (max-width: 900px) {
	.ewcw-items {
		border-right: none !important;
		border-bottom: 1px solid var(--ewcw-border) !important;
	}
}

/* ---- Single item ---- */
.ewcw-item {
	position: relative !important;
	display: flex !important;
	align-items: flex-start !important;
	gap: 16px !important;
	padding: 20px 28px !important;
	border-bottom: 1px solid var(--ewcw-border) !important;
	transition: background var(--ewcw-transition) !important;
}

.ewcw-item:last-child {
	border-bottom: none !important;
}

.ewcw-item:hover {
}

.ewcw-item.is-removing {
	opacity: .4;
	pointer-events: none;
	transition: opacity .4s ease;
}

/* Thumbnail */
.ewcw-item__thumb-wrap {
	flex-shrink: 0 !important;
	width: var(--ewcw-thumb-size) !important;
	height: var(--ewcw-thumb-size) !important;
	border-radius: var(--ewcw-radius-sm) !important;
	overflow: hidden !important;
	display: block !important;
	background: var(--ewcw-surface) !important;
}

.ewcw-item__thumb {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
	transition: transform .4s var(--ewcw-transition) !important;
}

.ewcw-item__thumb-wrap:hover .ewcw-item__thumb {
	transform: scale(1.06) !important;
}

/* Info block */
.ewcw-item__info {
	flex: 1 !important;
	min-width: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
}

.ewcw-item__name {
	font-weight: 500 !important;
	font-size: .95rem !important;
	line-height: 1.4 !important;
	color: var(--ewcw-text) !important;
	display: -webkit-box !important;
	-webkit-line-clamp: 2 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	transition: color var(--ewcw-transition) !important;
}

.ewcw-item__name:hover {
	color: var(--ewcw-gold) !important;
}

.ewcw-item__sku {
	font-size: .72rem !important;
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
	letter-spacing: .04em !important;
}

/* Variations */
.ewcw-item__variations {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 4px 10px !important;
	margin-top: 2px !important;
}

.ewcw-item__variation {
	display: inline-flex !important;
	align-items: center !important;
	gap: 3px !important;
	font-size: .72rem !important;
	background: var(--ewcw-surface) !important;
	border: 1px solid var(--ewcw-border) !important;
	border-radius: 100px !important;
	padding: 2px 9px !important;
	line-height: 1.5 !important;
}

.ewcw-item__variation-label {
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
}

.ewcw-item__variation-value {
	color: var(--ewcw-text) !important;
	font-weight: 500 !important;
}

/* Price per unit */
.ewcw-item__price-unit {
	display: flex !important;
	align-items: baseline !important;
	gap: 4px !important;
	font-size: .82rem !important;
	color: var(--ewcw-muted) !important;
}

.ewcw-item__price-unit .woocommerce-Price-amount,
.ewcw-item__price-unit .amount {
	font-size: .82rem !important;
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
}

.ewcw-item__price-label {
	font-size: .72rem !important;
}

/* Line total */
.ewcw-item__line-total {
	font-size: 1rem !important;
	font-weight: 600 !important;
	color: var(--ewcw-text) !important;
	letter-spacing: -.01em !important;
	margin-top: 4px !important;
}

.ewcw-item__line-total .woocommerce-Price-amount,
.ewcw-item__line-total .amount {
	font-size: 1rem !important;
	font-weight: 600 !important;
	color: var(--ewcw-text) !important;
}

/* Quantity controls */
.ewcw-item__qty-wrap {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0 !important;
	border: 1.5px solid var(--ewcw-border) !important;
	border-radius: 100px !important;
	overflow: hidden !important;
	height: 36px !important;
	width: fit-content !important;
	max-width: 130px !important;
	background: var(--ewcw-bg) !important;
	flex-shrink: 0 !important;
}

.ewcw-qty-btn {
	width: 36px !important;
	height: 34px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: var(--ewcw-text) !important;
	transition: background var(--ewcw-transition), color var(--ewcw-transition) !important;
	flex-shrink: 0 !important;
}

.ewcw-qty-btn svg {
	width: 14px !important;
	height: 14px !important;
}

.ewcw-qty-btn:hover {
	background: var(--ewcw-accent) !important;
	color: #fff !important;
}

.ewcw-qty-btn:active {
	background: #333 !important;
}

.ewcw-qty-input {
	width: 44px !important;
	height: 34px !important;
	text-align: center !important;
	border: none !important;
	border-left: 1.5px solid var(--ewcw-border) !important;
	border-right: 1.5px solid var(--ewcw-border) !important;
	font-size: .88rem !important;
	font-weight: 500 !important;
	color: var(--ewcw-text) !important;
	background: var(--ewcw-bg) !important;
	outline: none !important;
	padding: 0 4px !important;
	font-family: var(--ewcw-font-body) !important;
}

.ewcw-qty-input:focus {
	background: var(--ewcw-surface) !important;
}

/* Remove button */
.ewcw-item__remove {
	position: absolute !important;
	top: 16px !important;
	right: 16px !important;
	width: 28px !important;
	height: 28px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border-radius: 50% !important;
	color: var(--ewcw-muted) !important;
	opacity: 0 !important;
	transition: opacity var(--ewcw-transition), background var(--ewcw-transition), color var(--ewcw-transition) !important;
}

.ewcw-item__remove svg {
	width: 14px !important;
	height: 14px !important;
}

.ewcw-item:hover .ewcw-item__remove {
	opacity: 1 !important;
}

.ewcw-item__remove:hover {
	background: #ffe8e8 !important;
	color: var(--ewcw-danger) !important;
}

@media (pointer: coarse) {
	.ewcw-item__remove {
		opacity: 1 !important;
	}
}

/* =====================================================================
   Summary sidebar
   ===================================================================== */
.ewcw-summary {
	padding: 28px 28px 28px !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	background: var(--ewcw-bg) !important;
	position: sticky !important;
	top: 0 !important;
}

.ewcw-summary__rows {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	padding-bottom: 20px !important;
	border-bottom: 1.5px solid var(--ewcw-border) !important;
	margin-bottom: 20px !important;
}

.ewcw-summary__row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	font-size: .88rem !important;
	color: var(--ewcw-muted) !important;
	gap: 12px !important;
}

.ewcw-summary__row--discount .ewcw-summary__value {
	color: var(--ewcw-success) !important;
}

.ewcw-summary__row--tax {
	font-size: .8rem !important;
	padding-top: 4px !important;
	border-top: 1px dashed var(--ewcw-border) !important;
}

.ewcw-summary__value {
	font-weight: 500 !important;
	color: var(--ewcw-text) !important;
	text-align: right !important;
}

.ewcw-summary__value .woocommerce-Price-amount,
.ewcw-summary__value .amount {
	font-size: inherit !important;
	font-weight: 500 !important;
}

/* Total row */
.ewcw-summary__total {
	display: flex !important;
	justify-content: space-between !important;
	align-items: baseline !important;
	margin-bottom: 8px !important;
}

.ewcw-summary__total > span:first-child {
	font-family: var(--ewcw-font-display) !important;
	font-size: 1.05rem !important;
	font-weight: 600 !important;
	letter-spacing: -.01em !important;
	color: var(--ewcw-text) !important;
}

.ewcw-total,
.ewcw-total .woocommerce-Price-amount,
.ewcw-total .amount {
	font-family: var(--ewcw-font-display) !important;
	font-size: 1.45rem !important;
	font-weight: 600 !important;
	color: var(--ewcw-text) !important;
	letter-spacing: -.03em !important;
}

/* Tax note */
.ewcw-tax-note {
	font-size: .72rem !important;
	color: var(--ewcw-muted) !important;
	text-align: right !important;
	margin-bottom: 20px !important;
	font-style: italic !important;
}

/* CTA area */
.ewcw-summary__cta {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	margin-top: 8px !important;
}

/* =====================================================================
   Buttons
   ===================================================================== */
.ewcw-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	border-radius: 100px !important;
	font-weight: 500 !important;
	font-size: .88rem !important;
	letter-spacing: .01em !important;
	padding: 14px 28px !important;
	transition: background var(--ewcw-transition),
	            color var(--ewcw-transition),
	            box-shadow var(--ewcw-transition),
	            transform var(--ewcw-transition) !important;
	cursor: pointer !important;
	border: 2px solid transparent !important;
	text-align: center !important;
	width: 100% !important;
	white-space: nowrap !important;
}

.ewcw-btn svg {
	width: 16px !important;
	height: 16px !important;
	flex-shrink: 0 !important;
	transition: transform var(--ewcw-transition) !important;
}

.ewcw-btn:hover svg {
	transform: translateX(3px) !important;
}

/* Primary */
.ewcw-btn--primary {
	background: var(--ewcw-accent) !important;
	color: #fff !important;
	box-shadow: 0 4px 20px rgba(var(--ewcw-accent-rgb), .25) !important;
}

.ewcw-btn--primary:hover {
	background: #222 !important;
	box-shadow: 0 6px 28px rgba(var(--ewcw-accent-rgb), .35) !important;
	transform: translateY(-1px) !important;
}

.ewcw-btn--primary:active {
	transform: translateY(0) !important;
}

/* Outline */
.ewcw-btn--outline {
	border-color: var(--ewcw-accent) !important;
	color: var(--ewcw-accent) !important;
	background: transparent !important;
}

.ewcw-btn--outline:hover {
	background: var(--ewcw-accent) !important;
	color: #fff !important;
}

/* Ghost */
.ewcw-btn--ghost {
	background: var(--ewcw-surface) !important;
	color: var(--ewcw-muted) !important;
	border-color: transparent !important;
}

.ewcw-btn--ghost:hover {
	background: var(--ewcw-border) !important;
	color: var(--ewcw-text) !important;
}

/* =====================================================================
   Toast notification
   ===================================================================== */
.ewcw-toast {
	position: absolute !important;
	bottom: 20px !important;
	left: 50% !important;
	transform: translateX(-50%) translateY(12px) !important;
	background: var(--ewcw-accent) !important;
	color: #fff !important;
	padding: 10px 20px !important;
	border-radius: 100px !important;
	font-size: .82rem !important;
	font-weight: 500 !important;
	z-index: var(--ewcw-z-toast) !important;
	opacity: 0 !important;
	pointer-events: none !important;
	transition: opacity .25s ease, transform .25s ease !important;
	white-space: nowrap !important;
}

.ewcw-toast.is-visible {
	opacity: 1 !important;
	transform: translateX(-50%) translateY(0) !important;
}

.ewcw-toast.is-error {
	background: var(--ewcw-danger) !important;
}

/* =====================================================================
   Engraving S.R.A checkbox
   ===================================================================== */
.ewcw-engraving-label {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	cursor: pointer !important;
	margin-top: 6px !important;
	padding: 7px 12px !important;
	border-radius: var(--ewcw-radius-sm) !important;
	border: 1.5px dashed var(--ewcw-border) !important;
	background: var(--ewcw-surface) !important;
	transition: border-color var(--ewcw-transition), background var(--ewcw-transition) !important;
	width: fit-content !important;
}

.ewcw-engraving-label:hover {
	border-color: var(--ewcw-accent) !important;
	background: #fff !important;
}

.ewcw-engraving-checkbox {
	appearance: none !important;
	-webkit-appearance: none !important;
	width: 16px !important;
	height: 16px !important;
	border: 1.5px solid var(--ewcw-border) !important;
	border-radius: 4px !important;
	flex-shrink: 0 !important;
	cursor: pointer !important;
	position: relative !important;
	transition: border-color var(--ewcw-transition), background var(--ewcw-transition) !important;
	background: #fff !important;
}

.ewcw-engraving-checkbox:checked {
	background: var(--ewcw-accent) !important;
	border-color: var(--ewcw-accent) !important;
}

.ewcw-engraving-checkbox:checked::after {
	content: '' !important;
	position: absolute !important;
	left: 3px !important;
	top: 0px !important;
	width: 5px !important;
	height: 9px !important;
	border: 2px solid #fff !important;
	border-top: none !important;
	border-left: none !important;
	transform: rotate(45deg) !important;
}

.ewcw-engraving-label:has(.ewcw-engraving-checkbox:checked) {
	border-color: var(--ewcw-accent) !important;
	border-style: solid !important;
	background: color-mix(in srgb, var(--ewcw-accent) 5%, white) !important;
}

.ewcw-engraving-text {
	font-size: .78rem !important;
	color: var(--ewcw-text) !important;
	line-height: 1.4 !important;
}

.ewcw-engraving-text strong {
	font-weight: 700 !important;
}

.ewcw-engraving-price {
	color: var(--ewcw-muted) !important;
	font-size: .72rem !important;
	margin-left: 2px !important;
}

/* =====================================================================
   Fees rows in summary
   ===================================================================== */
.ewcw-summary__row--fee {
	padding-top: 4px !important;
}

.ewcw-summary__fee-name {
	font-size: .78rem !important;
	color: var(--ewcw-muted) !important;
	max-width: 160px !important;
	line-height: 1.3 !important;
}

.ewcw-summary__row--fee .ewcw-summary__value {
	font-size: .82rem !important;
	font-weight: 500 !important;
	color: var(--ewcw-text) !important;
}

/* =====================================================================
   Shipping note (deferred to checkout)
   ===================================================================== */
.ewcw-summary__row--shipping-note {
	border-top: 1px dashed var(--ewcw-border) !important;
	padding-top: 10px !important;
	margin-top: 4px !important;
}

.ewcw-shipping-note {
	font-style: italic !important;
	color: var(--ewcw-muted) !important;
	font-size: .75rem !important;
	font-weight: 400 !important;
}

/* =====================================================================
   Carte grise note (deferred to checkout)
   ===================================================================== */
.ewcw-summary__row--carte-grise-note {
	padding-top: 6px !important;
}

.ewcw-carte-grise-note {
	font-style: italic !important;
	color: var(--ewcw-muted) !important;
	font-size: .75rem !important;
	font-weight: 400 !important;
	font-family: inherit !important;
}

/* =====================================================================
   Item line total – TTC + TVA breakdown
   ===================================================================== */
.ewcw-item__line-tax {
	display: block !important;
	font-size: .72rem !important;
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
	margin-top: 2px !important;
}

.ewcw-item__line-tax .woocommerce-Price-amount,
.ewcw-item__line-tax .amount {
	font-size: .72rem !important;
	color: var(--ewcw-muted) !important;
	font-weight: 400 !important;
}

.ewcw-item {
	animation: ewcw-fade-in .3s ease both;
}

@keyframes ewcw-fade-in {
	from {
		opacity: 0;
		transform: translateY(6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.ewcw-subtotal,
.ewcw-total,
.ewcw-tax,
.ewcw-discount,
.ewcw-shipping {
	transition: color .3s ease, opacity .3s ease !important;
}

.ewcw-cart.is-loading .ewcw-subtotal,
.ewcw-cart.is-loading .ewcw-total,
.ewcw-cart.is-loading .ewcw-tax {
	opacity: .4 !important;
}

/* =====================================================================
   Responsive tweaks
   ===================================================================== */
@media (max-width: 600px) {
	.ewcw-header {
		padding: 16px 18px 14px !important;
	}

	.ewcw-item {
		padding: 16px 18px !important;
	}

	.ewcw-summary {
		padding: 20px 18px !important;
	}

	--ewcw-thumb-size: 68px;

	.ewcw-title {
		font-size: 1.2rem !important;
	}
}

/* =====================================================================
   WooCommerce price override (ensures consistency)
   ===================================================================== */
.ewcw-cart .woocommerce-Price-amount bdi,
.ewcw-cart .amount bdi {
	font-weight: inherit !important;
	font-size: inherit !important;
	font-family: inherit !important;
}

.ewcw-cart .woocommerce-Price-currencySymbol {
	font-family: inherit !important;
	font-size: .85em !important;
	vertical-align: super !important;
}
