/* =========================================================
   MODAL CARRITO CUSTOM
   - Estilos para la estructura limpia del carrito modal
   - Afecta solo #modal-cart
   ========================================================= */

#modal-cart .modal-dialog {
	max-width: 460px;
	width: calc(100% - 24px);
	margin: 16px auto;
}

#modal-cart .modal-content {
	border: 0;
	border-radius: 28px;
	overflow: hidden;
	background: linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%);
	box-shadow: 0 28px 80px rgba(17, 26, 56, 0.20);
}

#modal-cart .modal-body {
	padding: 76px 24px 24px;
}

#modal-cart .close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 34px;
	height: 34px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(20, 58, 123, 0.10);
	color: #143a7b;
	font-size: 19px;
	line-height: 1;
	opacity: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 18px rgba(12, 30, 66, 0.08);
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
	z-index: 20;
}

#modal-cart .close:hover {
	transform: rotate(90deg);
	box-shadow: 0 14px 26px rgba(12, 30, 66, 0.12);
	background: #ffffff;
}

#modal-cart .imecapi-cart-modal-title {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 20px;
	color: #16376f;
	font-size: 22px;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.015em;
}

#modal-cart .imecapi-cart-modal-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 28px;
	height: 28px;
	padding: 0 8px;
	border-radius: 999px;
	background: rgba(0, 131, 255, 0.10);
	color: #0083ff;
	font-size: 14px;
	font-weight: 800;
}

#modal-cart .imecapi-cart-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

#modal-cart .imecapi-cart-item {
	position: relative;
	display: grid;
	grid-template-columns: 92px 1fr;
	gap: 18px;
	padding: 18px;
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid rgba(20, 58, 123, 0.06);
	box-shadow: 0 14px 30px rgba(19, 55, 117, 0.08);
}

#modal-cart .imecapi-cart-remove {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 24px;
	height: 24px;
	border-radius: 999px;
	background: #ff3b30;
	color: #fff;
	font-size: 16px;
	line-height: 24px;
	text-align: center;
	text-decoration: none;
	box-shadow: 0 8px 16px rgba(255, 59, 48, 0.22);
}

#modal-cart .imecapi-cart-remove:hover {
	background: #e22d23;
	color: #fff;
}

#modal-cart .imecapi-cart-thumb a,
#modal-cart .imecapi-cart-thumb img {
	display: block;
	width: 92px;
	height: 92px;
	border-radius: 18px;
}

#modal-cart .imecapi-cart-thumb img {
	object-fit: cover;
	box-shadow: 0 10px 20px rgba(19, 55, 117, 0.10);
}

#modal-cart .imecapi-cart-info {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
}

#modal-cart .imecapi-cart-product-title {
	margin: 0 0 12px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.55;
	letter-spacing: -0.01em;
	max-width: 230px;
}

#modal-cart .imecapi-cart-product-title a {
	color: #16376f;
	text-decoration: none;
}

#modal-cart .imecapi-cart-product-title a:hover {
	color: #0083ff;
}

#modal-cart .imecapi-cart-meta {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 10px;
	color: #5f6f8f;
	font-size: 14px;
	font-weight: 700;
}

#modal-cart .imecapi-cart-qty {
	color: #7c8aa5;
	font-size: 13px;
	font-weight: 700;
}

#modal-cart .imecapi-cart-price {
	color: #0083ff;
	font-size: 17px;
	font-weight: 900;
	letter-spacing: -0.01em;
}

#modal-cart .imecapi-cart-footer {
	margin-top: 22px;
	padding-top: 20px;
	border-top: 1px solid rgba(20, 58, 123, 0.08);
}

#modal-cart .imecapi-cart-subtotal {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 18px;
	color: #5b6d8d;
	font-size: 15px;
	font-weight: 700;
}

#modal-cart .imecapi-cart-subtotal strong {
	color: #16376f;
	font-size: 20px;
	font-weight: 900;
	letter-spacing: -0.015em;
}

#modal-cart .imecapi-cart-actions {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}

#modal-cart .imecapi-cart-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 54px;
	padding: 12px 18px;
	border-radius: 18px;
	text-align: center;
	text-decoration: none;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.01em;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

#modal-cart .imecapi-cart-btn:hover {
	transform: translateY(-1px);
}

#modal-cart .imecapi-cart-btn-secondary {
	background: linear-gradient(180deg, rgba(232, 242, 255, 0.92), rgba(220, 235, 255, 0.92));
	color: #16376f;
	border: 1px solid rgba(0, 131, 255, 0.10);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

#modal-cart .imecapi-cart-btn-secondary:hover {
	background: linear-gradient(180deg, rgba(238, 246, 255, 1), rgba(225, 238, 255, 1));
	box-shadow: 0 10px 20px rgba(0, 131, 255, 0.08);
}

#modal-cart .imecapi-cart-btn-primary {
	background: linear-gradient(135deg, #005fcc 0%, #0083ff 100%);
	color: #ffffff;
	box-shadow: 0 16px 30px rgba(0, 131, 255, 0.20);
}

#modal-cart .imecapi-cart-btn-primary:hover {
	box-shadow: 0 18px 34px rgba(0, 131, 255, 0.24);
}

#modal-cart .imecapi-cart-empty {
	padding: 8px 0 4px;
	text-align: center;
}

#modal-cart .imecapi-cart-empty p {
	margin: 0 0 16px;
	color: #16376f;
	font-size: 15px;
	font-weight: 700;
}

@media (max-width: 575px) {
	#modal-cart .modal-dialog {
		width: calc(100% - 14px);
		margin: 7px auto;
	}

	#modal-cart .modal-content {
		border-radius: 22px;
		min-height: calc(100vh - 14px);
	}

	#modal-cart .modal-body {
		padding: 70px 16px 16px;
	}

	#modal-cart .imecapi-cart-modal-title {
		font-size: 20px;
		margin-bottom: 16px;
	}

	#modal-cart .imecapi-cart-item {
		grid-template-columns: 82px 1fr;
		gap: 14px;
		padding: 16px;
		border-radius: 20px;
	}

	#modal-cart .imecapi-cart-thumb a,
	#modal-cart .imecapi-cart-thumb img {
		width: 82px;
		height: 82px;
		border-radius: 16px;
	}

	#modal-cart .imecapi-cart-product-title {
		font-size: 14px;
		line-height: 1.5;
		margin-bottom: 8px;
		max-width: none;
	}

	#modal-cart .imecapi-cart-price {
		font-size: 16px;
	}

	#modal-cart .imecapi-cart-subtotal {
		font-size: 14px;
	}

	#modal-cart .imecapi-cart-subtotal strong {
		font-size: 18px;
	}

	#modal-cart .imecapi-cart-btn {
		min-height: 50px;
		border-radius: 16px;
		font-size: 13px;
	}
}
/* Ajustes finos finales del modal carrito */
#modal-cart .close {
	width: 30px;
	height: 30px;
	font-size: 17px;
	top: 16px;
	right: 16px;
}

#modal-cart .imecapi-cart-remove {
	top: 10px;
	right: 10px;
	width: 22px;
	height: 22px;
	font-size: 15px;
	line-height: 22px;
}

@media (max-width: 575px) {
	#modal-cart .close {
		width: 28px;
		height: 28px;
		font-size: 15px;
		top: 14px;
		right: 14px;
	}

	#modal-cart .imecapi-cart-item {
		grid-template-columns: 76px 1fr;
		gap: 12px;
		padding: 16px 18px 16px 16px;
	}

	#modal-cart .imecapi-cart-thumb a,
	#modal-cart .imecapi-cart-thumb img {
		width: 76px;
		height: 76px;
	}

	#modal-cart .imecapi-cart-product-title {
		padding-right: 24px;
		font-size: 13px;
		line-height: 1.45;
	}

	#modal-cart .imecapi-cart-remove {
		top: 8px;
		right: 8px;
		width: 21px;
		height: 21px;
		font-size: 14px;
		line-height: 21px;
	}
}
