/**
 * Carrito cotizador — OZ Cotizador / MYG.
 * Paleta: #004674 (azul oscuro) + #f7d022 (amarillo) + #ffffff (superficie).
 */

/* ════════════════════════════════════════════════
   AISLAMIENTO DE LAYOUT (WooCommerce overrides)
   ════════════════════════════════════════════════ */
.woocommerce.ozc-quote-cart,
.woocommerce-page .woocommerce.ozc-quote-cart,
.woocommerce-cart .woocommerce.ozc-quote-cart,
.entry-content .woocommerce.ozc-quote-cart,
.wp-block-post-content .woocommerce.ozc-quote-cart {
	float: none;
	clear: both;
	width: 100%;
	box-sizing: border-box;
}

form.woocommerce-cart-form.ozc-quote-cart__form {
	float: none !important;
	width: 100% !important;
	max-width: 100% !important;
	clear: both !important;
	box-sizing: border-box;
}

/* ════════════════════════════════════════════════
   TOKENS DE DISEÑO
   ════════════════════════════════════════════════ */
.ozc-quote-cart {
	--ozc-bg:           #edf1f7;
	--ozc-surface:      #ffffff;
	--ozc-border:       rgba(0, 70, 116, 0.13);
	--ozc-border-soft:  rgba(0, 70, 116, 0.07);
	--ozc-text:         #0f172a;
	--ozc-muted:        #64748b;
	--ozc-accent:       #004674;
	--ozc-accent-dark:  #003356;
	--ozc-accent-line:  #004674;
	--ozc-yellow:       #f7d022;
	--ozc-yellow-dark:  #e8c010;
	--ozc-wa:           #25d366;
	--ozc-wa-dark:      #1fbc59;
	--ozc-shadow:       0 1px 4px rgba(0, 70, 116, 0.07), 0 6px 20px rgba(0, 70, 116, 0.04);
	--ozc-radius:       12px;
	--ozc-radius-sm:    8px;

	max-width: 1100px;
	margin: 0 auto;
	padding: 1.5rem clamp(0.75rem, 2.5vw, 2rem) 3rem;
	box-sizing: border-box;
	background: var(--ozc-bg);
	color: var(--ozc-text);
}

/* ════════════════════════════════════════════════
   CABECERA
   ════════════════════════════════════════════════ */
.ozc-quote-cart__header {
	margin-bottom: 1.5rem;
	padding: 1.1rem 1.5rem;
	background: var(--ozc-accent);
	border-radius: var(--ozc-radius);
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.ozc-quote-cart__header::before {
	content: '';
	flex-shrink: 0;
	width: 0.25rem;
	height: 2.25rem;
	border-radius: 4px;
	background: var(--ozc-yellow);
}

.ozc-quote-cart__intro {
	margin: 0;
	font-size: clamp(0.9rem, 2vw, 1rem);
	line-height: 1.55;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.9);
}

/* ════════════════════════════════════════════════
   ESTADO VACÍO
   ════════════════════════════════════════════════ */
.ozc-quote-cart__empty {
	text-align: center;
	padding: 3rem 1.5rem;
	background: var(--ozc-surface);
	border-radius: var(--ozc-radius);
	box-shadow: var(--ozc-shadow);
}

.ozc-quote-cart__empty p {
	margin: 0 0 1.25rem;
	font-size: 1rem;
	color: var(--ozc-muted);
}

/* ════════════════════════════════════════════════
   MENSAJE DE FEEDBACK
   ════════════════════════════════════════════════ */
.ozc-quote-cart__form-feedback {
	margin: 0 0 1rem;
	padding: 0.875rem 1.125rem;
	border-radius: var(--ozc-radius-sm);
	background: #fffbeb;
	border-left: 3px solid #f59e0b;
	color: #78350f;
	font-size: 0.9375rem;
}

.ozc-quote-cart__form-feedback--success {
	background: #ecfdf5;
	border-left-color: #10b981;
	color: #065f46;
}

.ozc-quote-cart__form-feedback--error {
	background: #fef2f2;
	border-left-color: #ef4444;
	color: #991b1b;
}

/* ════════════════════════════════════════════════
   BLOQUES / TARJETAS DE SECCIÓN
   ════════════════════════════════════════════════ */
.ozc-quote-cart__block {
	margin-bottom: 1.125rem;
	padding: clamp(1.25rem, 2.5vw, 1.75rem) clamp(1rem, 2.8vw, 1.875rem);
	background: var(--ozc-surface);
	border: 1px solid var(--ozc-border-soft);
	border-radius: var(--ozc-radius);
	box-shadow: 0 1px 3px rgba(0, 70, 116, 0.05);
}

.ozc-quote-cart__block:last-of-type {
	margin-bottom: 0;
}

/* Encabezado de bloque */
.ozc-quote-cart__block-head {
	margin-bottom: 1.25rem;
}

.ozc-quote-cart__block-head--tight {
	margin-bottom: 0.875rem;
}

.ozc-quote-cart__block-title {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	margin: 0 0 0.35rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--ozc-text);
	letter-spacing: -0.01em;
}

/* Badge de paso */
.ozc-step {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 1.5rem;
	height: 1.5rem;
	border-radius: 50%;
	background: var(--ozc-yellow);
	color: var(--ozc-text);
	font-size: 0.6875rem;
	font-weight: 800;
	line-height: 1;
}

.ozc-quote-cart__hint {
	margin: 0;
	font-size: 0.8125rem;
	color: var(--ozc-muted);
	line-height: 1.5;
}

/* ════════════════════════════════════════════════
   SECCIÓN DATOS DEL CLIENTE
   ════════════════════════════════════════════════ */
.ozc-quote-cart__block.ozc-quote-cart__customer {
	border-left: 3px solid var(--ozc-accent);
}

.ozc-quote-cart__customer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.875rem 1.25rem;
}

@media (min-width: 600px) {
	.ozc-quote-cart__customer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 960px) {
	.ozc-quote-cart__customer-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

/* Campos */
.ozc-quote-cart__field {
	margin: 0;
}

.ozc-quote-cart__field label {
	display: block;
	margin-bottom: 0.375rem;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ozc-text);
	letter-spacing: 0.005em;
}

.ozc-quote-cart__field--wide {
	grid-column: 1 / -1;
}

.ozc-quote-cart__field input,
.ozc-quote-cart__field select {
	width: 100%;
	box-sizing: border-box;
	padding: 0.6rem 0.875rem;
	border: 1.5px solid rgba(0, 70, 116, 0.18);
	border-radius: var(--ozc-radius-sm);
	font-size: 0.9375rem;
	line-height: 1.4;
	color: var(--ozc-text);
	background: #f8fafd;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
	min-height: 2.75rem;
}

.ozc-quote-cart__field input:focus,
.ozc-quote-cart__field select:focus {
	outline: none;
	border-color: var(--ozc-accent);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(0, 70, 116, 0.11);
}

.ozc-quote-cart__field input::placeholder {
	color: #b0bec5;
}

.ozc-quote-cart__customer input,
.ozc-quote-cart__customer select {
	-webkit-text-fill-color: currentColor;
}

.ozc-quote-cart__req {
	color: #dc2626;
	font-weight: 700;
	margin-left: 0.1em;
}

/* ════════════════════════════════════════════════
   SECCIÓN PRODUCTOS
   ════════════════════════════════════════════════ */
.ozc-quote-cart__block.ozc-quote-cart__items {
	border-left: 3px solid var(--ozc-yellow);
	margin-bottom: 1.75rem; /* Más separación antes de la sección 3 */
}

.ozc-quote-cart__item-list {
	display: flex;
	flex-direction: column;
	gap: 0; /* Sin gap: las filas se separan con border-bottom */
}

/* Fila de producto — estilo tabla (sin cards) */
.ozc-quote-cart__item {
	display: grid;
	grid-template-columns: 1.75rem 4.5rem minmax(0, 1fr);
	gap: 0 0.875rem;
	align-items: center;
	padding: 0.625rem 0;
	border: none;
	border-bottom: 1px solid rgba(0, 70, 116, 0.07);
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	transition: background 0.12s ease;
}

.ozc-quote-cart__item:first-child {
	padding-top: 0.25rem;
}

.ozc-quote-cart__item:last-child {
	border-bottom: none;
	padding-bottom: 0.25rem;
}

.ozc-quote-cart__item:hover {
	background: rgba(0, 70, 116, 0.025);
	border-color: rgba(0, 70, 116, 0.07);
	box-shadow: none;
}

@media (max-width: 520px) {
	.ozc-quote-cart__item {
		grid-template-columns: 1.5rem 3.5rem minmax(0, 1fr);
		gap: 0 0.5rem;
	}
}

/* Botón eliminar */
.ozc-quote-cart__item-remove {
	display: flex;
	align-items: center;
	justify-content: center;
}

.ozc-quote-cart__remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	background: none;
	border: none;
	border-radius: 4px;
	color: #cbd5e1;
	text-decoration: none;
	padding: 0;
	transition: color 0.15s ease;
	cursor: pointer;
}

.ozc-quote-cart__remove:hover,
.ozc-quote-cart__remove:focus {
	background: none;
	border: none;
	color: #dc2626;
}

/* Thumbnail */
.ozc-quote-cart__item-thumb {
	border-radius: 6px;
	overflow: hidden;
	background: #f8fafd;
	border: 1px solid rgba(0, 70, 116, 0.08);
	align-self: center;
}

.ozc-quote-cart__item-thumb img {
	width: 100%;
	display: block;
}

/* Cuerpo del ítem: nombre a la izquierda, meta (cantidad) a la derecha */
.ozc-quote-cart__item-body {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem 1rem;
	min-width: 0;
}

.ozc-quote-cart__item-name {
	flex: 1 1 auto;
	font-weight: 600;
	font-size: 0.9375rem;
	line-height: 1.35;
	word-break: break-word;
	color: var(--ozc-text);
	min-width: 0;
}

.ozc-quote-cart__item-name a {
	text-decoration: none;
	color: inherit;
}

.ozc-quote-cart__item-name a:hover {
	color: var(--ozc-accent);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.ozc-quote-cart__item-name .variation {
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--ozc-muted);
	margin-top: 0.2rem;
}

/* Fila meta: precio | cantidad | subtotal */
.ozc-quote-cart__item-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 1.25rem;
	flex: 0 0 auto;
}

/* Cuando hay precios visibles: meta va debajo del nombre (volver a columna) */
.ozc-quote-cart:not(.ozc-quote-cart--hide-prices) .ozc-quote-cart__item-body {
	flex-direction: column;
	align-items: stretch;
}

.ozc-quote-cart:not(.ozc-quote-cart--hide-prices) .ozc-quote-cart__item-meta {
	flex: 0 0 auto;
	padding-top: 0.5rem;
	border-top: 1px solid rgba(0, 70, 116, 0.06);
}

.ozc-quote-cart__item-price,
.ozc-quote-cart__item-qty,
.ozc-quote-cart__item-subtotal {
	flex: 0 0 auto;
	min-width: 4.5rem;
}

.ozc-quote-cart__meta-label {
	display: block;
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.065em;
	font-weight: 700;
	color: var(--ozc-muted);
	margin-bottom: 0.3rem;
}

.ozc-quote-cart__meta-value {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--ozc-text);
	line-height: 1.3;
}

.ozc-quote-cart__meta-value--emphasis {
	font-weight: 700;
	color: var(--ozc-accent);
}

/* ════════════════════════════════════════════════
   CONTROL DE CANTIDAD
   ════════════════════════════════════════════════ */
.ozc-quote-cart__item-qty {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.25rem;
}

.ozc-quote-cart__qty-wrap .quantity {
	display: inline-flex;
	align-items: stretch;
	border: 1.5px solid rgba(0, 70, 116, 0.18);
	border-radius: 6px;
	overflow: hidden;
	background: var(--ozc-surface);
	min-height: 2.125rem;
	vertical-align: middle;
}

.ozc-quote-cart__qty-wrap .qty.ozc-quote-cart__qty-input,
.ozc-quote-cart__qty-wrap .qty {
	width: 2.75rem;
	min-width: 2.25rem;
	max-width: 4rem;
	text-align: center;
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--ozc-accent);
	border: 0 !important;
	border-left: 1px solid rgba(0, 70, 116, 0.12) !important;
	border-right: 1px solid rgba(0, 70, 116, 0.12) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	margin: 0 !important;
	padding: 0 0.25rem !important;
	line-height: 1.3;
	-moz-appearance: textfield;
	appearance: textfield;
	background: transparent;
}

/* Ocultar spinner nativo — reemplazado por botones JS */
.ozc-quote-cart__qty-wrap .qty::-webkit-outer-spin-button,
.ozc-quote-cart__qty-wrap .qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Botones +/- inyectados por JS */
.ozc-qty-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 1.875rem;
	min-height: 100%;
	padding: 0;
	background: var(--ozc-accent);
	color: #ffffff;
	border: none;
	font-size: 1.1rem;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	-webkit-user-select: none;
	user-select: none;
	transition: background 0.15s ease;
}

.ozc-qty-btn:hover,
.ozc-qty-btn:focus {
	background: var(--ozc-accent-dark);
	outline: none;
}

.ozc-qty-btn--minus {
	border-radius: 4px 0 0 4px;
}

.ozc-qty-btn--plus {
	border-radius: 0 4px 4px 0;
}

/* Mobile: item-body apila en columna si el nombre es muy largo */
@media (max-width: 480px) {
	.ozc-quote-cart__item-body {
		flex-wrap: wrap;
	}

	.ozc-quote-cart__item-name {
		flex: 1 1 100%;
	}

	.ozc-quote-cart__item-meta {
		flex: 0 0 auto;
		margin-left: auto;
	}
}

/* ════════════════════════════════════════════════
   CUPÓN (oculto)
   ════════════════════════════════════════════════ */
.ozc-quote-cart__coupon {
	display: none;
}

/* ════════════════════════════════════════════════
   SECCIÓN ACCIONES (ENVIAR COTIZACIÓN)
   ════════════════════════════════════════════════ */
.ozc-quote-cart__block.ozc-quote-cart__actions {
	border-top: 3px solid var(--ozc-yellow);
	border-left: none;
	background: linear-gradient(160deg, #fffef5 0%, #ffffff 60%);
}

.ozc-quote-cart__actions {
	display: grid;
	grid-template-columns: auto 1fr auto;
	grid-template-areas:
		"label  label  label"
		"primary gap   secondary";
	gap: 0.875rem 1.25rem;
	align-items: center;
}

.ozc-quote-cart__actions-label {
	grid-area: label;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--ozc-muted);
}

.ozc-quote-cart__actions-primary {
	grid-area: primary;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.625rem;
}

.ozc-quote-cart__actions-secondary {
	grid-area: secondary;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.5rem;
}

/* ════════════════════════════════════════════════
   BOTONES — BASE
   ════════════════════════════════════════════════ */
.ozc-quote-cart a.ozc-quote-cart__btn,
.ozc-quote-cart button.ozc-quote-cart__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 2.75rem;
	padding: 0 1.25rem;
	border-radius: var(--ozc-radius-sm);
	font-size: 0.9375rem;
	font-weight: 700;
	text-decoration: none;
	box-sizing: border-box;
	cursor: pointer;
	line-height: 1.25;
	border: 1.5px solid transparent;
	transition:
		background-color 0.18s ease,
		border-color 0.18s ease,
		color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

.ozc-quote-cart a.ozc-quote-cart__btn:hover,
.ozc-quote-cart button.ozc-quote-cart__btn:hover {
	transform: translateY(-1px);
}

.ozc-quote-cart a.ozc-quote-cart__btn:active,
.ozc-quote-cart button.ozc-quote-cart__btn:active {
	transform: translateY(0);
}

.ozc-quote-cart a.ozc-quote-cart__btn:disabled,
.ozc-quote-cart button.ozc-quote-cart__btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	pointer-events: none;
	transform: none;
}

/* WhatsApp — CTA principal (amarillo de marca) */
.ozc-quote-cart a.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--whatsapp,
.ozc-quote-cart button.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--whatsapp {
	background: var(--ozc-yellow);
	color: var(--ozc-text);
	border-color: var(--ozc-yellow-dark);
	min-height: 3rem;
	padding: 0 1.625rem;
	font-size: 1rem;
	box-shadow: 0 4px 14px rgba(247, 208, 34, 0.32);
}

.ozc-quote-cart a.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--whatsapp:hover,
.ozc-quote-cart button.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--whatsapp:hover {
	background: var(--ozc-yellow-dark);
	border-color: #d0ac00;
	box-shadow: 0 6px 20px rgba(247, 208, 34, 0.42);
}

/* Email — botón secundario (azul oscuro de marca) */
.ozc-quote-cart a.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--email,
.ozc-quote-cart button.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--email {
	background: var(--ozc-accent);
	color: #ffffff;
	border-color: var(--ozc-accent-dark);
	box-shadow: 0 2px 8px rgba(0, 70, 116, 0.2);
}

.ozc-quote-cart a.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--email:hover,
.ozc-quote-cart button.ozc-quote-cart__btn--primary.ozc-quote-cart__btn--email:hover {
	background: var(--ozc-accent-dark);
	border-color: #002540;
	box-shadow: 0 4px 14px rgba(0, 70, 116, 0.28);
}

/* Ghost — volver a la tienda (selectores dobles para ganar al .button del tema) */
.ozc-quote-cart a.ozc-quote-cart__btn.ozc-quote-cart__btn--ghost,
.ozc-quote-cart a.ozc-quote-cart__btn--ghost,
.ozc-quote-cart button.ozc-quote-cart__btn.ozc-quote-cart__btn--ghost,
.ozc-quote-cart button.ozc-quote-cart__btn--ghost {
	background: transparent;
	color: var(--ozc-accent);
	border: 1.5px solid rgba(0, 70, 116, 0.28);
	font-weight: 600;
}

.ozc-quote-cart a.ozc-quote-cart__btn.ozc-quote-cart__btn--ghost:hover,
.ozc-quote-cart a.ozc-quote-cart__btn--ghost:hover,
.ozc-quote-cart button.ozc-quote-cart__btn.ozc-quote-cart__btn--ghost:hover,
.ozc-quote-cart button.ozc-quote-cart__btn--ghost:hover {
	background: rgba(0, 70, 116, 0.06);
	border-color: rgba(0, 70, 116, 0.38);
	color: var(--ozc-accent);
}

/* Outline — actualizar carrito (ídem, selectores reforzados) */
.ozc-quote-cart a.ozc-quote-cart__btn.ozc-quote-cart__btn--outline,
.ozc-quote-cart a.ozc-quote-cart__btn--outline,
.ozc-quote-cart button.ozc-quote-cart__btn.ozc-quote-cart__btn--outline,
.ozc-quote-cart button.ozc-quote-cart__btn--outline {
	background: #f0f4f8;
	color: var(--ozc-text);
	border: 1.5px solid rgba(0, 70, 116, 0.18);
	font-weight: 600;
}

.ozc-quote-cart a.ozc-quote-cart__btn.ozc-quote-cart__btn--outline:hover,
.ozc-quote-cart a.ozc-quote-cart__btn--outline:hover,
.ozc-quote-cart button.ozc-quote-cart__btn.ozc-quote-cart__btn--outline:hover,
.ozc-quote-cart button.ozc-quote-cart__btn--outline:hover {
	background: #dce8f2;
	border-color: rgba(0, 70, 116, 0.32);
	color: var(--ozc-accent);
}

/* Botones secundarios: más compactos que los primarios */
.ozc-quote-cart__actions-secondary .ozc-quote-cart__btn {
	min-height: 2.375rem;
	padding: 0 1rem;
	font-size: 0.875rem;
}

/* Botones full-width en mobile */
@media (max-width: 640px) {
	.ozc-quote-cart__actions {
		grid-template-columns: 1fr;
		grid-template-areas:
			"label"
			"primary"
			"secondary";
	}

	.ozc-quote-cart__actions-secondary {
		justify-content: flex-start;
	}
}

@media (max-width: 480px) {
	.ozc-quote-cart a.ozc-quote-cart__btn,
	.ozc-quote-cart button.ozc-quote-cart__btn {
		width: 100%;
		justify-content: center;
	}

	.ozc-quote-cart__actions-primary,
	.ozc-quote-cart__actions-secondary {
		flex-direction: column;
		align-items: stretch;
	}
}

/* ════════════════════════════════════════════════
   TOTALES
   ════════════════════════════════════════════════ */
.ozc-quote-cart__totals-wrap {
	clear: both;
	float: none;
	width: 100%;
	margin-top: 1.125rem;
}

.ozc-quote-cart__totals-inner.cart-collaterals {
	width: 100%;
	max-width: min(34rem, 100%);
	margin-left: auto;
	float: none;
}

.ozc-quote-cart__totals-inner .cart_totals {
	width: 100%;
	float: none;
	background: var(--ozc-surface);
	border: 1px solid var(--ozc-border-soft);
	border-radius: var(--ozc-radius-sm);
	padding: 1.25rem 1.5rem;
}

.ozc-quote-cart__totals-inner .cart_totals h2 {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	color: var(--ozc-text);
}

.ozc-quote-cart__totals-inner .shop_table {
	margin: 0;
	font-size: 0.9375rem;
}

.ozc-quote-cart__totals-inner .shop_table th,
.ozc-quote-cart__totals-inner .shop_table td {
	padding: 0.5rem 0;
	border-color: var(--ozc-border-soft);
}
