/**
 * RiversideHiFi - WooCommerce Core Styles
 * Estilos para páginas de checkout, carrito, cuenta y formularios
 * (No duplica estilos de shop.css que ya están en productos)
 */

/* ================================
   NOTICES - Ya están en main.css, solo ajustes específicos
   ================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	padding: 1rem 1.5rem;
	margin-bottom: 1.5rem;
	border-radius: 8px;
	border-left-width: 4px;
	border-left-style: solid;
}

.woocommerce-message {
	border-left-color: #28a745;
}

.woocommerce-info {
	border-left-color: #17a2b8;
}

.woocommerce-error {
	border-left-color: #dc3545;
}

/* ================================
   FORMULARIOS (Checkout, Login, etc.)
   ================================ */
.woocommerce form .form-row {
	margin-bottom: 1rem;
}

.woocommerce form .form-row label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 600;
	color: var(--rh-primary);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--rh-border);
	border-radius: 8px;
	font-size: 0.9375rem;
	background-color: var(--rh-background);
	color: var(--rh-text);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--rh-accent);
	box-shadow: 0 0 0 3px rgba(193, 154, 107, 0.1);
}

/* Validación */
.woocommerce form .form-row .required {
	color: #dc3545;
}

.woocommerce form .form-row.woocommerce-invalid .select2-container,
.woocommerce form .form-row.woocommerce-invalid input.input-text,
.woocommerce form .form-row.woocommerce-invalid select {
	border-color: #dc3545;
}

/* ================================
   TABLAS (Carrito, Pedidos)
   ================================ */
.woocommerce table.shop_table {
	width: 100%;
	border: 1px solid var(--rh-border);
	border-radius: var(--rh-border-radius);
	overflow: hidden;
	margin-bottom: 2rem;
	border-collapse: collapse;
}

.woocommerce table.shop_table th {
	background-color: var(--rh-background-alt);
	padding: 1rem;
	font-weight: 600;
	text-align: left;
	color: var(--rh-primary);
}

.woocommerce table.shop_table td {
	padding: 1rem;
	border-top: 1px solid var(--rh-border);
	color: var(--rh-text);
}

.woocommerce table.shop_table tfoot th {
	border-top: 1px solid var(--rh-border);
}

/* ================================
   CARRITO
   ================================ */
.woocommerce-cart .cart_totals {
	background-color: var(--rh-background-alt);
	padding: 1.5rem;
	border-radius: var(--rh-border-radius);
}

.woocommerce-cart .cart_totals h2 {
	font-size: 1.25rem;
	margin-bottom: 1rem;
}

/* ================================
   CHECKOUT
   ================================ */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
	font-size: 1.25rem;
	margin-bottom: 1.5rem;
}

.woocommerce-checkout .select2-container--default .select2-selection--single {
	height: 45px;
	border: 1px solid var(--rh-border);
	border-radius: 8px;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 45px;
	padding-left: 1rem;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 43px;
}

/* Payment Methods */
.woocommerce-checkout #payment {
	background-color: var(--rh-background-alt);
	border-radius: var(--rh-border-radius);
	padding: 1.5rem;
}

.woocommerce-checkout #payment .payment_methods {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-checkout #payment .payment_methods li {
	margin-bottom: 1rem;
}

.woocommerce-checkout #payment .payment_methods li:last-child {
	margin-bottom: 0;
}

.woocommerce-checkout #payment .payment_box {
	background-color: var(--rh-background);
	padding: 1rem;
	border-radius: 8px;
	margin-top: 0.5rem;
	font-size: 0.875rem;
}

/* ================================
   CUENTA DE USUARIO
   ================================ */
.woocommerce-account .woocommerce-MyAccount-navigation {
	background-color: var(--rh-background-alt);
	border-radius: var(--rh-border-radius);
	padding: 1.5rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin-bottom: 0.5rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 0.5rem;
	color: var(--rh-text);
	text-decoration: none;
	border-radius: 6px;
	transition: var(--rh-transition);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	background-color: var(--rh-background);
	color: var(--rh-primary);
}

.woocommerce-account .woocommerce-MyAccount-content {
	padding: 1.5rem;
	background-color: var(--rh-background);
	border: 1px solid var(--rh-border);
	border-radius: var(--rh-border-radius);
}

/* ================================
   LOGIN/REGISTER
   ================================ */
.woocommerce-form-login,
.woocommerce-form-register {
	max-width: 400px;
	margin: 0 auto;
	padding: 2rem;
	background-color: var(--rh-background);
	border: 1px solid var(--rh-border);
	border-radius: var(--rh-border-radius);
}

.woocommerce-form-login .form-row,
.woocommerce-form-register .form-row {
	margin-bottom: 1.5rem;
}

/* ================================
   BOTONES ESPECÍFICOS DE WOOCOMMERCE
   ================================ */
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button {
	padding: 0.75rem 1.5rem;
	background-color: var(--rh-primary);
	color: #ffffff;
	border: 2px solid var(--rh-primary);
	border-radius: 8px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	cursor: pointer;
	transition: var(--rh-transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover {
	background-color: transparent;
	color: var(--rh-primary);
}

.woocommerce button.button.alt,
.woocommerce a.button.alt,
.woocommerce input.button.alt {
	background-color: var(--rh-accent);
	border-color: var(--rh-accent);
}

.woocommerce button.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce input.button.alt:hover {
	background-color: transparent;
	color: var(--rh-accent);
}

/* Botón de checkout */
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	width: 100%;
	padding: 1rem;
	font-size: 1.125rem;
}


/* ================================
   RELATED PRODUCTS CAROUSEL
   ================================ */

.related-carousel-section {
	margin: 60px 0;
	padding: 0 20px;
}

.related-carousel-container {
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
}

/* Header con navegación */
.related-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 30px;
}

.related-header h2 {
	font-size: 1.8rem;
	font-weight: 600;
	margin: 0;
	color: #1a1a1a;
}

.carousel-nav {
	display: flex;
	gap: 12px;
}

/* 
.carousel-prev,
.carousel-next {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid #e0e0e0;
    background: white;
    color: #666;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    padding: 0;
}

.carousel-prev:hover,
.carousel-next:hover {
    border-color: #000;
    color: #000;
    background: #f5f5f5;
    transform: scale(1.05);
}

.carousel-prev:disabled,
.carousel-next:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    border-color: #e0e0e0;
}

.carousel-prev:focus-visible,
.carousel-next:focus-visible {
    outline: 2px solid #000;
    outline-offset: 2px;
} */

/* Swiper personalización */
.related-products-swiper {
	padding: 10px 5px 40px;
	margin: -10px -5px;
}

.related-products-swiper .swiper-slide {
	height: auto;
}

/* Ajustes para productos dentro del slide */
.related-products-swiper .product {
	height: 100%;
	display: flex;
	flex-direction: column;
}

/* Paginación */
.swiper-pagination {
	position: relative;
	margin-top: 20px;
}

.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	background: #e0e0e0;
	opacity: 1;
	transition: all 0.3s ease;
}

.swiper-pagination-bullet-active {
	width: 24px;
	border-radius: 4px;
	background: #000;
}

/* Responsive */
@media (max-width: 768px) {
	.related-header {
		flex-direction: column;
		gap: 15px;
		align-items: flex-start;
	}

	.carousel-nav {
		align-self: flex-end;
	}
}

@media (max-width: 480px) {
	.related-header h2 {
		font-size: 1.5rem;
	}

	.carousel-prev,
	.carousel-next {
		width: 38px;
		height: 38px;
	}
}

/* Reduced motion accessibility */
@media (prefers-reduced-motion: reduce) {

	.carousel-prev,
	.carousel-next,
	.swiper-pagination-bullet {
		transition: none !important;
	}

	.carousel-prev:hover,
	.carousel-next:hover {
		transform: none !important;
	}
}


/* ================================
   RESPONSIVE
   ================================ */
@media (max-width: 768px) {
	.woocommerce table.shop_table {
		display: block;
		overflow-x: auto;
	}

	.woocommerce form .form-row input.input-text,
	.woocommerce form .form-row textarea {
		font-size: 16px;
		/* Prevent zoom on iOS */
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 2rem;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-wrap: wrap;
		gap: 0.5rem;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li {
		flex: 1 1 auto;
		margin-bottom: 0;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
		text-align: center;
	}
}

@media (max-width: 480px) {

	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last {
		float: none;
		width: 100%;
	}
}