/* -------------------------------------------------------------------------- */
/*                             RESETS GLOBALES Y ESTILOS BASE                 */
/* -------------------------------------------------------------------------- */

/*
 * Reseteo universal y configuración del modelo de caja a border-box.
 * Esto significa que el padding y el border se incluyen en el ancho y alto total del elemento,
 * facilitando el cálculo de dimensiones.
 */
*,
*::before, /* Aplica también a los pseudo-elementos ::before */
*::after {  /* Aplica también a los pseudo-elementos ::after */
    box-sizing: border-box; /* El modelo de caja preferido por muchos desarrolladores */
    margin: 0; /* Elimina todos los márgenes por defecto */
    padding: 0; /* Elimina todos los paddings por defecto */
}

/* Estilos base para el elemento HTML */
html {
    font-size: 16px; /* Establece el tamaño de fuente base. 1rem equivaldrá a 16px. */
    line-height: 1.6; /* Altura de línea base para mejorar la legibilidad. Ligeramente aumentada. */
    -webkit-font-smoothing: antialiased; /* Mejora el renderizado de fuentes en WebKit (Chrome, Safari) */
    -moz-osx-font-smoothing: grayscale; /* Mejora el renderizado de fuentes en Firefox en macOS */
    scroll-behavior: smooth; /* Habilita el desplazamiento suave para anclas (#) */
}

/* Estilos base para el BODY */
body {
    font-family: 'Roboto', 'Poppins', sans-serif; /* Define la pila de fuentes principal. Roboto es sólida, Poppins para títulos/énfasis. */
    color: #333; /* Color de texto principal, un gris oscuro en lugar de negro puro para menor fatiga visual. */
    background-color: #f8f9fa; /* Un gris muy claro y neutro para el fondo general, común en diseños modernos. */
    display: flex; /* Permite usar flexbox para el layout general */
    flex-direction: column; /* Apila los hijos directos (header, main, footer) verticalmente */
    min-height: 100vh; /* Asegura que el body ocupe al menos toda la altura de la ventana gráfica (viewport height), útil para footers pegajosos. */
}

/* Estilos base para imágenes */
img {
    max-width: 100%; /* Asegura que las imágenes no se desborden de su contenedor */
    height: auto; /* Mantiene la proporción de la imagen al escalar el ancho */
    display: block; /* Elimina el espacio extra debajo de las imágenes (comportamiento inline por defecto) */
    object-fit: cover; /* Asegura que la imagen cubra su contenedor, puede recortar si las proporciones no coinciden. Útil para imágenes de fondo o tarjetas. */
}

/* Estilos base para enlaces */
a {
    text-decoration: none; /* Elimina el subrayado por defecto de los enlaces */
    color: #0072c6; /* Un azul Samsung más corporativo y moderno. */
    transition: color 0.25s ease-out; /* Transición suave para el cambio de color al pasar el ratón. */
}

a:hover, a:focus { /* :focus es importante para accesibilidad con teclado */
    text-decoration: none; /* Mantenemos sin subrayado en hover para un look más limpio, el color indica interactividad. */
    color: #005ba1; /* Azul Samsung más oscuro para el estado hover/focus. */
}

/* Elimina los estilos de lista por defecto para <ul> */
ul {
    list-style: none;
}

/* Clase de utilidad para contenedores principales */
.container {
    width: 90%; /* Usa un porcentaje del ancho de la ventana */
    max-width: 1280px; /* Límite máximo de ancho para el contenido, un poco más generoso. */
    margin-left: auto; /* Centra el contenedor horizontalmente */
    margin-right: auto; /* Centra el contenedor horizontalmente */
    padding-left: 20px; /* Padding horizontal para evitar que el contenido toque los bordes en pantallas pequeñas. */
    padding-right: 20px;
}

/* -------------------------------------------------------------------------- */
/*                             ENCABEZADO Y NAVEGACIÓN                        */
/* -------------------------------------------------------------------------- */

/* ----- ESTILOS PARA MENÚS DESPLEGABLES (DROPDOWNS) ----- */

/* Contenedor del ítem de navegación que tendrá un menú desplegable. */
.nav-item-dropdown {
    position: relative; /* Permite que el .dropdown-menu se posicione absolutamente con respecto a este elemento. */
}

/* Estilos para el icono indicador de desplegable (flecha hacia abajo) */
.dropdown-indicator {
    font-size: 0.7em; /* Hace el icono un poco más pequeño que el texto del enlace */
    margin-left: 0.3rem;
    transition: transform 0.3s ease-out; /* Para animar la rotación de la flecha */
}

.nav-item-dropdown:hover .dropdown-indicator {
    transform: rotate(180deg); /* Rota la flecha cuando se hace hover sobre el ítem principal */
}

/* Estilos para el menú desplegable */
.dropdown-menu {
    display: none; /* Oculto por defecto */
    position: absolute; /* Posicionamiento absoluto respecto al .nav-item-dropdown */
    top: 100%; /* Se posiciona justo debajo del ítem del menú principal */
    left: 0;
    background-color: var(--surface-color); /* Usa la variable de color de superficie */
    border: 1px solid var(--border-color);
    border-top: none; /* Evita doble borde con la navbar si la sombra no es suficiente */
    border-radius: 0 0 8px 8px; /* Bordes redondeados solo en la parte inferior */
    box-shadow: 0 4px 12px var(--shadow-color-light); /* Sombra sutil para el desplegable */
    padding: 0.5rem 0; /* Padding vertical */
    min-width: 200px; /* Ancho mínimo para el desplegable */
    z-index: 1010; /* Debe estar por encima de la navbar y otros elementos */
    opacity: 0; /* Comienza transparente para la animación */
    visibility: hidden; /* Oculto para accesibilidad y para que no interfiera */
    transform: translateY(10px); /* Comienza ligeramente abajo para la animación */
    transition: opacity 0.3s ease-out, visibility 0.3s ease-out, transform 0.3s ease-out;
}

/* Muestra el menú desplegable cuando se hace hover sobre el .nav-item-dropdown */
.nav-item-dropdown:hover > .dropdown-menu {
    display: block; /* Lo hace visible */
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Estilos para los ítems dentro del menú desplegable */
.dropdown-menu li a {
    display: block; /* Hace que cada enlace ocupe todo el ancho */
    padding: 0.6rem 1.2rem; /* Padding para cada enlace del desplegable */
    color: var(--text-color-secondary); /* Color de texto */
    font-size: 0.85rem; /* Tamaño de fuente */
    text-transform: none; /* Quita el uppercase si estaba en los enlaces principales */
    letter-spacing: normal; /* Restaura el espaciado de letras normal */
    white-space: nowrap; /* Evita que el texto del enlace se parta en múltiples líneas */
    transition: color 0.2s ease-out, background-color 0.2s ease-out; /* Añadida transición para suavidad */
}

.dropdown-menu li a:hover, .dropdown-menu li a:focus {
    background-color: rgba(0, 0, 0, 0.05); /* Fondo de hover muy sutil, se ajustará para modo oscuro */
    color: var(--primary-color); /* El texto cambia al color primario */
}

body.dark-mode .dropdown-menu li a:hover,
body.dark-mode .dropdown-menu li a:focus {
    background-color: rgba(255, 255, 255, 0.08); /* Fondo de hover sutil para modo oscuro */
}


/* Eliminar el pseudo-elemento ::after (subrayado animado) de los enlaces principales que tienen desplegable, si se desea */
.nav-item-dropdown > a::after {
    display: none; /* Opcional: quitar el subrayado animado si interfiere con el look del desplegable */
}

/* ----- FIN DE ESTILOS PARA MENÚS DESPLEGABLES ----- */


.navbar {
    background-color: #ffffff; /* Fondo blanco para la barra de navegación */
    padding: 0.8rem 0; /* Padding vertical reducido para un look más compacto */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08); /* Sombra más sutil y moderna */
    position: sticky; /* Fija la barra de navegación en la parte superior al hacer scroll */
    top: 0; /* Pega la barra en la parte superior */
    z-index: 1000; /* Asegura que la barra de navegación esté por encima de otros contenidos */
    transition: box-shadow 0.3s ease; /* Transición para la sombra si se añade dinámicamente */
}

.navbar .container {
    display: flex; /* Organiza los elementos hijos en una fila */
    justify-content: space-between; /* Distribuye el espacio entre el logo, nav y los iconos */
    align-items: center; /* Centra verticalmente los elementos en la barra */
}

.navbar-brand {
    font-family: 'Poppins', sans-serif; /* Fuente distintiva para la marca */
    font-size: 1.85rem; /* Tamaño de fuente ligeramente aumentado para la marca */
    font-weight: 600; /* Peso de fuente semi-bold para la marca */
    color: #1d1d1f; /* Un negro ligeramente más suave, similar al de Apple/Samsung. */
    letter-spacing: -0.5px; /* Ajuste sutil del espaciado entre letras */
}
.navbar-brand:hover, .navbar-brand:focus {
    color: #0072c6; /* Color de hover para la marca */
}

.navbar-nav {
    display: flex; /* Organiza los ítems del menú en una fila */
    gap: 2rem; /* Espacio entre los ítems del menú, aumentado ligeramente */
}

.navbar-nav a {
    font-family: 'Poppins', sans-serif;
    font-weight: 500; /* Peso medio para los enlaces de navegación */
    color: #4f4f4f; /* Gris oscuro para los enlaces, buena legibilidad */
    font-size: 0.9rem; /* Tamaño de fuente ligeramente reducido para un look más refinado */
    text-transform: uppercase; /* Opcional: para un estilo más formal/de marca */
    letter-spacing: 0.5px; /* Ligero espaciado entre letras */
    position: relative; /* Para el pseudo-elemento del subrayado en hover */
    padding-bottom: 0.3rem; /* Espacio para el subrayado animado */
}

.navbar-nav a::after { /* Pseudo-elemento para el subrayado animado */
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background-color: #0072c6;
    transition: width 0.3s ease-out;
}

.navbar-nav a:hover::after,
.navbar-nav a:focus::after {
    width: 100%; /* Anima el ancho del subrayado al 100% */
}

.navbar-nav a:hover, .navbar-nav a:focus {
    color: var(--primary-color); /* Color del texto al pasar el ratón o enfocar, usando variable */
    text-decoration: none; /* Asegura que no haya otro subrayado */
    background-color: transparent !important; /* Asegura que el fondo del enlace no cambie */
}

.navbar-icons {
    display: flex; /* Organiza los iconos en una fila */
    align-items: center; /* Centra verticalmente los iconos */
    gap: 1.5rem; /* Espacio entre los iconos */
}

.navbar-icons a {
    color: #4f4f4f;
    font-size: 1.25rem; /* Tamaño de los iconos */
    transition: color 0.25s ease-out;
}
.navbar-icons a:hover, .navbar-icons a:focus {
    color: var(--primary-color); /* Actualizado para usar variable */
}


/* ESTILOS PARA EL CAMPO DE BÚSQUEDA EN NAVBAR */
.search-container {
    position: relative;
    display: flex;
    align-items: center;
}

.search-input {
    padding: 0.4rem 0.8rem;
    padding-right: 2.5rem; /* Espacio para el botón de búsqueda */
    border: 1px solid var(--border-color);
    border-radius: 20px; /* Bordes redondeados */
    font-size: 0.85rem;
    background-color: var(--background-color);
    color: var(--text-color-primary);
    transition: width 0.3s ease-in-out, background-color 0.3s ease, border-color 0.3s ease;
    width: 150px; /* Ancho inicial */
}

.search-input::placeholder {
    color: var(--text-color-secondary); /* Color del placeholder */
    opacity: 0.8;
}

.search-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px var(--primary-color-focus-shadow); /* Usando la variable definida para modales */
    width: 200px; /* Ancho al enfocar */
}

.search-button {
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--text-color-secondary);
    padding: 0.4rem 0.8rem;
    cursor: pointer;
    font-size: 1rem; /* Tamaño del icono */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s ease;
}

.search-button:hover,
.search-button:focus {
    color: var(--primary-color);
}

/* Ajustes para modo oscuro */
body.dark-mode .search-input {
    background-color: var(--surface-color); /* Un fondo un poco más claro que el general en modo oscuro */
    border-color: var(--border-color-darker);
    color: var(--text-color-primary);
}

body.dark-mode .search-input::placeholder {
    color: var(--text-color-secondary);
    opacity: 0.7;
}

/* -------------------------------------------------------------------------- */
/*                       ESTILOS PARA PÁGINAS DE CATEGORÍA                    */
/* -------------------------------------------------------------------------- */
.category-products {
    padding-top: 1rem; /* Reducido, ya que main ya tiene padding-top */
    padding-bottom: 4rem; /* Espacio al final de la sección */
}

.category-products h2 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.8rem, 4vw, 2.5rem); /* Tamaño de fuente responsive */
    font-weight: 600;
    text-align: center;
    margin-bottom: 3rem; /* Espacio antes de la cuadrícula de productos */
    color: var(--text-color-primary);
}

/* -------------------------------------------------------------------------- */
/*                             ÁREA DE CONTENIDO PRINCIPAL                    */
/* -------------------------------------------------------------------------- */
main {
    flex-grow: 1; /* Permite que el main ocupe el espacio restante si el footer es pegajoso */
    padding-top: 3rem; /* Espacio para compensar la altura de la barra de navegación fija (ajustar si cambia la altura de la navbar) */
    padding-bottom: 4rem; /* Espacio en la parte inferior del contenido principal */
}

/* -------------------------------------------------------------------------- */
/*                             SECCIÓN HERO (BANNER)                          */
/* -------------------------------------------------------------------------- */
.hero {
    background: linear-gradient(to right, #001f3f, #003366); /* Gradiente azul oscuro sutil */
    color: #ffffff; /* Texto blanco para contraste */
    padding: 5rem 0; /* Padding vertical generoso */
    text-align: center; /* Centra el contenido de la sección hero */
    margin-bottom: 4rem; /* Espacio después de la sección hero */
    border-radius: 0 0 20px 20px; /* Bordes inferiores redondeados para un efecto suave */
    box-shadow: 0 4px 10px rgba(0, 31, 63, 0.3);
}

.hero h1 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(2.5rem, 5vw, 3.5rem); /* Tamaño de fuente responsive */
    font-weight: 700; /* Peso bold para el título principal */
    margin-bottom: 1.5rem;
    text-shadow: 0 2px 4px rgba(0,0,0,0.2); /* Sombra de texto sutil */
}

.hero p {
    font-size: clamp(1rem, 2.5vw, 1.25rem); /* Tamaño de fuente responsive para el párrafo */
    margin-bottom: 2.5rem;
    max-width: 700px; /* Limita el ancho del párrafo para mejor legibilidad */
    margin-left: auto;
    margin-right: auto;
    opacity: 0.9; /* Ligera transparencia para el texto secundario */
}

/* Estilos para botones */
.btn {
    font-family: 'Poppins', sans-serif;
    padding: 0.85rem 2rem; /* Padding ligeramente ajustado */
    border: none;
    border-radius: 25px; /* Bordes más redondeados para un estilo moderno */
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease, box-shadow 0.3s ease;
    display: inline-block;
    text-align: center;
    letter-spacing: 0.5px;
}

.btn:hover, .btn:focus {
    transform: translateY(-2px); /* Ligero efecto de elevación al pasar el ratón */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.btn-primary {
    background-color: #0072c6;
    color: #ffffff;
}

.btn-primary:hover, .btn-primary:focus {
    background-color: #005ba1;
    color: #ffffff;
    text-decoration: none;
}

.btn-secondary {
    background-color: transparent;
    color: #333; /* Color de texto para el botón secundario */
    border: 2px solid #dee2e6; /* Borde sutil para el botón secundario */
}

.btn-secondary:hover, .btn-secondary:focus {
    background-color: #e9ecef; /* Fondo claro al pasar el ratón */
    color: #005ba1;
    border-color: #c1c9d1;
    text-decoration: none;
}

/* -------------------------------------------------------------------------- */
/*                             SECCIÓN DE PRODUCTOS DESTACADOS                */
/* -------------------------------------------------------------------------- */
.featured-products {
    padding-bottom: 4rem;
}

.featured-products h2 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.8rem, 4vw, 2.5rem); /* Tamaño de fuente responsive */
    font-weight: 600;
    text-align: center;
    margin-bottom: 3rem; /* Mayor espacio antes de la cuadrícula de productos */
    color: #1d1d1f;
}

.product-grid {
    display: grid;
    /* Crea columnas responsivas: mínimo 280px de ancho, se ajustan para llenar el espacio */
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2.5rem; /* Espacio entre las tarjetas de producto */
}

.product-card {
    background-color: #ffffff;
    border-radius: 12px; /* Bordes más redondeados para las tarjetas */
    box-shadow: 0 5px 15px rgba(0,0,0,0.07); /* Sombra más pronunciada y suave */
    overflow: hidden; /* Asegura que el contenido no se desborde de los bordes redondeados */
    transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
    display: flex;
    flex-direction: column; /* Organiza el contenido de la tarjeta verticalmente */
}

.product-card:hover {
    transform: translateY(-8px); /* Efecto de elevación más notable */
    box-shadow: 0 10px 25px rgba(0,0,0,0.1); /* Sombra más intensa al pasar el ratón */
}

.product-card img {
    width: 100%;
    height: 220px; /* Altura fija para la imagen, ligeramente aumentada */
    object-fit: contain; /* 'contain' asegura que toda la imagen sea visible, puede dejar espacio si las proporciones no coinciden. Cambiar a 'cover' si se prefiere llenar el espacio. */
    padding: 1rem; /* Añade un poco de espacio alrededor de la imagen dentro de su contenedor */
    background-color: #f8f9fa; /* Fondo sutil para el área de la imagen */
}

.product-card h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.3rem; /* Tamaño de fuente para el nombre del producto */
    font-weight: 600;
    margin: 1.2rem 1.2rem 0.5rem 1.2rem; /* Márgenes ajustados */
    color: #1d1d1f;
    line-height: 1.3;
}

.product-card p {
    font-size: 0.9rem;
    color: #555; /* Color de texto para la descripción */
    margin: 0 1.2rem 1.2rem 1.2rem;
    flex-grow: 1; /* Permite que la descripción ocupe el espacio disponible, útil si las descripciones varían en longitud */
    line-height: 1.5;
}

.product-card .btn {
    margin: 0 auto 1.5rem auto; /* Centra el botón y añade margen inferior */
    display: block; /* Hace que el botón ocupe el ancho disponible si se desea */
    width: calc(100% - 2.4rem); /* Botón ocupa el ancho menos el padding horizontal de la tarjeta */
    padding: 0.7rem 1rem; /* Padding del botón en la tarjeta */
}

/* ESTILOS PARA INDICADOR DE PRODUCTO AÑADIDO */
.product-card {
    position: relative; /* Necesario para posicionar el indicador absolutamente dentro de la tarjeta */
}

.product-added-indicator {
    display: none; /* Oculto por defecto */
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 1.8rem; /* Tamaño del ícono de check */
    color: var(--primary-color); /* Usa el color primario del tema */
    background-color: rgba(255, 255, 255, 0.8); /* Fondo semi-transparente para que destaque un poco sobre la imagen */
    border-radius: 50%;
    padding: 0.2rem;
    line-height: 0; /* Para alinear mejor el icono si tiene espacio extra */
    z-index: 5; /* Para asegurarse que esté sobre la imagen */
}

.product-card.product-selected .product-added-indicator {
    display: block; /* Mostrar el indicador cuando la tarjeta está seleccionada */
}

.product-card.product-selected {
    box-shadow: 0 0 0 2px var(--primary-color), 0 10px 25px var(--shadow-color-medium); /* Borde de color primario y sombra existente */
    /* Opcional: Podríamos quitar el transform: translateY(-8px); de hover si ya está seleccionado */
}

/* Ajuste para modo oscuro si es necesario para el fondo del indicador */
body.dark-mode .product-added-indicator {
    background-color: rgba(40, 40, 40, 0.8);
    color: var(--primary-color); /* El color primario ya se adapta al modo oscuro */
}
/* -------------------------------------------------------------------------- */
/*                                 PIE DE PÁGINA                              */
/* -------------------------------------------------------------------------- */
footer {
    background-color: #1d1d1f; /* Negro suave para el footer, coherente con la marca */
    color: #a8a8b3; /* Gris claro para el texto del footer, buena legibilidad sobre fondo oscuro */
    padding: 4rem 0 2rem 0; /* Padding vertical generoso, menos en la parte inferior */
    font-size: 0.875rem; /* Tamaño de fuente ligeramente más pequeño para el footer */
}

.footer-links {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); /* Columnas responsivas para los enlaces */
    gap: 2.5rem; /* Espacio entre las columnas de enlaces */
    margin-bottom: 3rem;
}

.footer-links h4 {
    font-family: 'Poppins', sans-serif;
    color: #ffffff; /* Texto blanco para los títulos de las secciones del footer */
    font-size: 1.15rem;
    font-weight: 500;
    margin-bottom: 1.2rem;
    letter-spacing: 0.3px;
}

.footer-links ul li {
    margin-bottom: 0.5rem; /* Espacio entre los ítems de la lista */
}

.footer-links ul li a {
    color: #a8a8b3;
    transition: color 0.25s ease-out, padding-left 0.25s ease-out;
}

.footer-links ul li a:hover, .footer-links ul li a:focus {
    color: #ffffff; /* Texto blanco al pasar el ratón sobre los enlaces del footer */
    padding-left: 5px; /* Ligero desplazamiento al pasar el ratón para feedback visual */
    text-decoration: none;
}

.footer-bottom {
    border-top: 1px solid #3a3a3c; /* Línea divisoria sutil y moderna */
    padding-top: 2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap; /* Permite que los elementos se ajusten en pantallas pequeñas */
    gap: 1rem; /* Espacio entre el texto de copyright y los iconos sociales */
}

.footer-bottom p {
    margin: 0;
    font-size: 0.85rem;
}

.social-icons {
    display: flex;
    gap: 1.2rem; /* Espacio entre los iconos sociales */
}

.social-icons a {
    color: #a8a8b3;
    font-size: 1.4rem; /* Tamaño de los iconos sociales */
    transition: color 0.25s ease-out, transform 0.25s ease-out;
}

.social-icons a:hover, .social-icons a:focus {
    color: #ffffff; /* Iconos blancos al pasar el ratón */
    transform: scale(1.15) translateY(-2px); /* Ligero zoom y elevación al pasar el ratón */
}

/* -------------------------------------------------------------------------- */
/*                  ESTILOS PARA EL CONMUTADOR DE TEMA                        */
/* -------------------------------------------------------------------------- */

/* Contenedor que agrupa los iconos de la navbar y el conmutador de tema */
.navbar-controls {
    display: flex;
    align-items: center;
    gap: 1rem; /* Espacio entre el grupo de iconos y el conmutador de tema */
}

.theme-toggle-btn {
    background: none;
    border: 1px solid transparent; /* Borde transparente para mantener el layout */
    color: var(--text-color-secondary); /* Usa variable CSS para color */
    cursor: pointer;
    font-size: 1.25rem; /* Tamaño del icono dentro del botón */
    padding: 0.3rem; /* Padding pequeño para el área de clic */
    border-radius: 50%; /* Hace el botón circular */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s ease, background-color 0.3s ease, transform 0.2s ease;
}

.theme-toggle-btn:hover, .theme-toggle-btn:focus {
    color: var(--primary-color); /* Color primario al hacer hover/focus */
    background-color: rgba(0, 0, 0, 0.05); /* Fondo sutil al hacer hover */
    outline: none; /* Quita el outline por defecto en focus, si se desea un estilo custom */
}
.theme-toggle-btn:active {
    transform: scale(0.9); /* Efecto de "presionado" */
}

/* -------------------------------------------------------------------------- */
/*                             VARIABLES DE COLOR Y MODO OSCURO               */
/* -------------------------------------------------------------------------- */

/* ----- ESTILOS PARA EL ICONO DE CARRITO EN NAVBAR ----- */
.cart-toggle-btn {
    position: relative; /* Para posicionar el contador de ítems */
    color: var(--text-color-secondary);
    font-size: 1.35rem; /* Tamaño similar a otros iconos de navbar-controls */
    padding: 0.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s ease;
}

.cart-toggle-btn:hover, .cart-toggle-btn:focus {
    color: var(--primary-color);
    text-decoration: none;
}

.cart-item-count {
    position: absolute;
    top: -5px; /* Ajustar para posicionar sobre el icono */
    right: -8px; /* Ajustar para posicionar sobre el icono */
    background-color: var(--primary-color);
    color: var(--text-color-on-primary);
    border-radius: 50%;
    padding: 0.1em 0.45em; /* Padding pequeño para el contador */
    font-size: 0.7rem; /* Tamaño de fuente pequeño para el contador */
    font-weight: bold;
    line-height: 1;
    min-width: 18px; /* Ancho mínimo para que se vea bien con 1 dígito */
    text-align: center;
    border: 1px solid var(--surface-color); /* Borde para separarlo del icono */
    display: none; /* Oculto por defecto, se mostrará con JS si hay ítems */
}

body.dark-mode .cart-item-count {
    border-color: var(--background-color); /* Ajustar borde en modo oscuro */
}

.cart-toggle-btn.has-items .cart-item-count {
    display: inline-block; /* Mostrar cuando hay ítems */
}


/* ----- ESTILOS PARA EL MODAL DEL CARRITO ----- */
/* El .modal ya tiene estilos base. Aquí añadimos específicos para el contenido del carrito si es necesario. */
.cart-modal-content {
    max-width: 700px; /* Un poco más ancho que el modal de contacto */
}

#cart-items-container {
    margin-bottom: 1.5rem;
    max-height: 40vh; /* Altura máxima antes de hacer scroll */
    overflow-y: auto; /* Scroll si los ítems exceden la altura */
    padding-right: 10px; /* Espacio para la barra de scroll */
}

.cart-item { /* Estilos para cada fila/item en el carrito */
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.8rem 0;
    border-bottom: 1px solid var(--border-color);
}
.cart-item:last-child {
    border-bottom: none;
}

.cart-item-image {
    width: 60px;
    height: 60px;
    object-fit: contain;
    margin-right: 1rem;
    border-radius: 4px;
}

.cart-item-details {
    flex-grow: 1;
}
.cart-item-details h4 {
    font-size: 1rem;
    margin: 0 0 0.2rem 0;
    font-weight: 500;
    color: var(--text-color-primary);
}
.cart-item-details p {
    font-size: 0.85rem;
    color: var(--text-color-secondary);
    margin: 0;
}

.cart-item-quantity input {
    width: 50px;
    padding: 0.3rem;
    text-align: center;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    margin: 0 0.5rem;
    font-size: 0.9rem;
    background-color: var(--background-color);
    color: var(--text-color-primary);
}
body.dark-mode .cart-item-quantity input {
    background-color: var(--surface-color);
    border-color: var(--border-color-darker);
}


.cart-item-actions button { /* Botón para eliminar ítem */
    background: none;
    border: none;
    color: var(--primary-color);
    font-size: 1.2rem;
    cursor: pointer;
    padding: 0.2rem;
}
.cart-item-actions button:hover {
    color: var(--primary-color-darker);
}

.cart-summary {
    text-align: right;
    font-size: 1.2rem;
    font-weight: bold;
    margin-bottom: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.cart-actions {
    display: flex;
    flex-direction: column; /* Apila los botones de acción */
    gap: 0.8rem;
}

.cart-actions .btn-checkout {
    width: 100%;
    padding: 0.7rem;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.cart-actions .btn-checkout i {
    font-size: 1.1em; /* Icono ligeramente más grande que el texto */
}

.cart-empty-message {
    text-align: center;
    padding: 2rem 0;
    color: var(--text-color-secondary);
    font-style: italic;
}

.order-id-display {
    margin-top: 1rem;
    padding: 0.8rem;
    background-color: var(--background-color); /* Un fondo sutil */
    border: 1px dashed var(--border-color); /* Borde discontinuo para destacar */
    border-radius: 6px;
    text-align: center;
    font-size: 0.9rem;
}
body.dark-mode .order-id-display {
    background-color: var(--surface-color); /* Fondo de superficie en modo oscuro */
    border-color: var(--border-color-darker);
}
.order-id-display p {
    margin: 0;
    line-height: 1.4;
}
.order-id-display strong {
    font-family: 'Courier New', Courier, monospace; /* Fuente monoespaciada para el ID */
    word-break: break-all; /* Para que IDs largos no rompan el layout */
}
.order-id-display small {
    font-size: 0.8em;
    color: var(--text-color-secondary);
}


:root {
    /* Tema Claro (por defecto) */
    --primary-color: #0072c6;
    --primary-color-darker: #005ba1;
    --background-color: #f8f9fa;
    --surface-color: #ffffff; /* Color para superficies como tarjetas, navbar */
    --text-color-primary: #1d1d1f;
    --text-color-secondary: #4f4f4f;
    --text-color-on-primary: #ffffff; /* Texto sobre fondos de color primario */
    --text-color-on-dark: #a8a8b3; /* Texto claro sobre fondos oscuros (ej. footer) */
    --text-color-on-dark-strong: #ffffff; /* Texto más fuerte sobre fondos oscuros */
    --border-color: #dee2e6;
    --border-color-darker: #c1c9d1;
    --shadow-color-light: rgba(0, 0, 0, 0.08);
    --shadow-color-medium: rgba(0, 0, 0, 0.1);
    --hero-gradient-start: #001f3f;
    --hero-gradient-end: #003366;
    --footer-background: #1d1d1f;

    /* Transición suave para todos los cambios de color y fondo */
    --theme-transition: color 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
}

body.dark-mode {
    /* Tema Oscuro */
    --primary-color: #0a84ff; /* Un azul más brillante para modo oscuro, similar a iOS */
    --primary-color-darker: #0060df;
    --background-color: #0d1117; /* Fondo muy oscuro, GitHub style */
    --surface-color: #161b22;   /* Superficies ligeramente más claras que el fondo */
    --text-color-primary: #c9d1d9; /* Texto principal claro */
    --text-color-secondary: #8b949e; /* Texto secundario */
    --text-color-on-primary: #ffffff;
    --text-color-on-dark: #8b949e;
    --text-color-on-dark-strong: #c9d1d9;
    --border-color: #30363d;
    --border-color-darker: #484f58;
    --shadow-color-light: rgba(200, 200, 200, 0.05); /* Sombras muy sutiles en modo oscuro */
    --shadow-color-medium: rgba(200, 200, 200, 0.08);
    --hero-gradient-start: #1a2a3a;
    --hero-gradient-end: #0d1117;
    --footer-background: #0d1117; /* Footer coincide con el fondo general oscuro */
    --image-background-dark: #161b22; /* Un fondo para imágenes ligeramente diferente al fondo principal en modo oscuro */
}

/* Aplicar transiciones a los elementos afectados por el cambio de tema */
body, .navbar, .product-card, footer, .btn-secondary {
    transition: var(--theme-transition);
}

/* Ajustes específicos para elementos en modo claro/oscuro usando variables */
body {
    background-color: var(--background-color);
    color: var(--text-color-primary);
}

.navbar {
    background-color: var(--surface-color);
    box-shadow: 0 1px 3px var(--shadow-color-light);
}
.navbar-brand {
    color: var(--text-color-primary);
}
.navbar-brand:hover, .navbar-brand:focus {
    color: var(--primary-color);
}
.navbar-nav a {
    color: var(--text-color-secondary);
}
.navbar-nav a:hover, .navbar-nav a:focus,
.navbar-nav a:hover::after, .navbar-nav a:focus::after {
    color: var(--primary-color);
    background-color: var(--primary-color); /* Para el ::after */
}
.navbar-icons a {
    color: var(--text-color-secondary);
}
.navbar-icons a:hover, .navbar-icons a:focus {
    color: var(--primary-color);
}

.hero {
    background: linear-gradient(to right, var(--hero-gradient-start), var(--hero-gradient-end));
    color: var(--text-color-on-dark-strong); /* El texto en hero siempre es claro */
    box-shadow: 0 4px 10px var(--shadow-color-medium);
}
.hero p {
    opacity: 0.9;
}

.btn-primary {
    background-color: var(--primary-color);
    color: var(--text-color-on-primary);
}
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--primary-color-darker);
}

.btn-secondary {
    color: var(--text-color-primary);
    border-color: var(--border-color);
}
.btn-secondary:hover, .btn-secondary:focus {
    background-color: var(--surface-color); /* Un color de fondo sutil al hacer hover */
    color: var(--primary-color);
    border-color: var(--border-color-darker);
}
body.dark-mode .btn-secondary:hover, body.dark-mode .btn-secondary:focus {
    background-color: rgba(255, 255, 255, 0.05); /* Fondo más sutil en modo oscuro */
}


.featured-products h2 {
    color: var(--text-color-primary);
}

.product-card {
    background-color: var(--surface-color);
    box-shadow: 0 5px 15px var(--shadow-color-light);
}
.product-card:hover {
    box-shadow: 0 10px 25px var(--shadow-color-medium);
}
.product-card img {
    /* El fondo de la imagen coincide con el fondo general en modo claro,
       y usa --image-background-dark en modo oscuro para un ligero contraste si la imagen tiene transparencias. */
    background-color: var(--background-color);
}
body.dark-mode .product-card img {
    background-color: var(--image-background-dark);
}
.product-card h3 {
    color: var(--text-color-primary);
}
.product-card p {
    color: var(--text-color-secondary);
}

footer {
    background-color: var(--footer-background);
    color: var(--text-color-on-dark);
}
.footer-links h4 {
    color: var(--text-color-on-dark-strong);
}
.footer-links ul li a {
    color: var(--text-color-on-dark);
}
.footer-links ul li a:hover, .footer-links ul li a:focus {
    color: var(--text-color-on-dark-strong);
}
.footer-bottom {
    border-top-color: var(--border-color); /* Borde más oscuro en modo oscuro */
}
.social-icons a {
    color: var(--text-color-on-dark);
}
.social-icons a:hover, .social-icons a:focus {
    color: var(--text-color-on-dark-strong);
}


/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/*                                 ANIMACIONES SUTILES                        */
/* -------------------------------------------------------------------------- */

/* Animación para el icono del carrito cuando se añade un ítem */
@keyframes cartIconPop {
    0% { transform: scale(1); }
    50% { transform: scale(1.3); }
    100% { transform: scale(1); }
}

.cart-toggle-btn.item-added-feedback .bi-cart-fill { /* Aplicar al icono dentro del botón */
    animation: cartIconPop 0.6s ease-in-out;
}


/* Animación de Fade-in para secciones */
.fade-in-section {
    opacity: 0;
    transform: translateY(20px); /* Comienza ligeramente abajo */
    animation: fadeIn 0.7s 0.2s ease-out forwards; /* delay de 0.2s por defecto */
}

@keyframes fadeIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Aplicar delay escalonado a secciones subsiguientes */
/* .hero.fade-in-section tiene el delay por defecto de 0.2s */
.featured-products.fade-in-section {
    animation-delay: 0.4s; /* Un poco más tarde que el hero */
}
footer.fade-in-section { /* Footer también puede tener un fade-in */
    animation-delay: 0.6s;
}

/* Transición mejorada para el botón dentro de la tarjeta de producto */
.product-card .btn {
    /* La transición base ya está en .btn, aquí nos aseguramos que incluya transform */
    transition: background-color 0.3s ease, color 0.3s ease, transform 0.3s ease-out, box-shadow 0.3s ease, border-color 0.3s ease;
}

.product-card:hover .btn { /* Efecto sutil en el botón cuando se hace hover en la tarjeta */
    transform: scale(1.03); /* Ligero escalado del botón */
}


/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/*                       BOTÓN FLOTANTE DE WHATSAPP                           */
/* -------------------------------------------------------------------------- */

/* Estilos para el botón flotante de WhatsApp. */
.whatsapp-float {
    position: fixed; /* Se mantiene fijo en la pantalla incluso al hacer scroll. */
    width: 60px; /* Ancho del botón. */
    height: 60px; /* Alto del botón. */
    bottom: 30px; /* Distancia desde el borde inferior de la ventana. */
    right: 30px; /* Distancia desde el borde derecho de la ventana. */
    background-color: #25D366; /* Color verde oficial de WhatsApp. */
    color: #FFF; /* Color del icono de WhatsApp (blanco). */
    border-radius: 50%; /* Hace que el botón sea perfectamente circular. */
    text-align: center; /* Centra el icono horizontalmente (útil si el icono fuera texto). */
    font-size: 30px; /* Tamaño del icono de WhatsApp. Ajustar según el icono usado. */
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2); /* Sombra sutil para dar profundidad. */
    z-index: 1000; /* Asegura que esté por encima de la mayoría de los otros elementos (igual que la navbar). */
    display: flex; /* Permite centrar el icono fácilmente con align-items y justify-content. */
    align-items: center; /* Centra el icono verticalmente. */
    justify-content: center; /* Centra el icono horizontalmente. */
    transition: transform 0.3s ease-out, background-color 0.3s ease-out; /* Transiciones suaves para efectos hover. */
}

/* Efectos al pasar el cursor o enfocar el botón de WhatsApp. */
.whatsapp-float:hover, .whatsapp-float:focus {
    transform: scale(1.1) translateY(-3px); /* Agranda ligeramente el botón y lo eleva un poco. */
    background-color: #1DAE54; /* Un verde ligeramente más oscuro para el estado hover/focus. */
    color: #FFF; /* Mantiene el color del icono (blanco). */
    text-decoration: none; /* Asegura que no haya subrayado si el icono está dentro de un <a>. */
    outline: none; /* Quita el outline por defecto en focus si se desea un estilo personalizado. */
}


/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/*                             MODAL DE CONTACTO                              */
/* -------------------------------------------------------------------------- */

/* Contenedor principal del modal (fondo oscuro superpuesto) */
.modal {
    display: none; /* Oculto por defecto */
    position: fixed; /* Se mantiene fijo en la pantalla */
    z-index: 2000; /* Por encima de otros contenidos, incluida la navbar */
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto; /* Permite scroll si el contenido del modal es muy largo */
    background-color: rgba(0, 0, 0, 0.6); /* Fondo negro semi-transparente */
    opacity: 0; /* Para animación de fade-in */
    visibility: hidden;
    transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
}

.modal.is-open {
    display: flex; /* Usar flex para centrar el modal-content */
    align-items: center;
    justify-content: center;
    opacity: 1;
    visibility: visible;
}

/* Contenido del modal (la ventana/caja blanca) */
.modal-content {
    background-color: var(--surface-color);
    color: var(--text-color-primary);
    margin: auto; /* Necesario para centrar con display:flex en .modal */
    padding: 25px 30px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    width: 90%;
    max-width: 500px; /* Ancho máximo del modal */
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);
    position: relative; /* Para posicionar el botón de cierre absoluto a este contenedor */
    transform: translateY(-30px) scale(0.95); /* Estado inicial para animación de aparición */
    transition: transform 0.3s ease-out;
}

.modal.is-open .modal-content {
    transform: translateY(0) scale(1); /* Estado final de la animación de aparición */
}

/* Botón de cierre del modal (la 'X') */
.modal-close {
    color: var(--text-color-secondary);
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 28px;
    font-weight: bold;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    line-height: 1; /* Asegura que la 'X' esté bien centrada */
}

.modal-close:hover,
.modal-close:focus {
    color: var(--text-color-primary);
    text-decoration: none;
    outline: none;
}

.modal-content h2 {
    margin-top: 0;
    margin-bottom: 1.5rem;
    font-family: 'Poppins', sans-serif;
    color: var(--text-color-primary);
    text-align: center;
}

/* Estilos para los grupos de formulario (label + input/textarea) */
.form-group {
    margin-bottom: 1.2rem;
}

.form-group label {
    display: block; /* Hace que el label ocupe su propia línea */
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: var(--text-color-secondary);
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group textarea {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-family: 'Roboto', sans-serif;
    font-size: 0.95rem;
    background-color: var(--background-color); /* Fondo sutil para los inputs */
    color: var(--text-color-primary);
    transition: border-color 0.2s ease-out, box-shadow 0.2s ease-out;
}
body.dark-mode .form-group input[type="text"],
body.dark-mode .form-group input[type="email"],
body.dark-mode .form-group textarea {
    background-color: var(--surface-color); /* En modo oscuro, los inputs pueden tener el color de superficie */
    border-color: var(--border-color-darker);
}


.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(var(--primary-color-rgb, 0, 114, 198), 0.25); /* Necesitaríamos --primary-color-rgb para esto */
}

/* Ajuste para el box-shadow en focus, usando un color fijo si no tenemos RGB de la variable */
:root {
    --primary-color-focus-shadow: rgba(0, 114, 198, 0.25);
}
body.dark-mode {
    --primary-color-focus-shadow: rgba(10, 132, 255, 0.25);
}
.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group textarea:focus {
    box-shadow: 0 0 0 3px var(--primary-color-focus-shadow);
}


.modal-content .btn-primary {
    display: block; /* Hace que el botón ocupe todo el ancho */
    width: 100%;
    padding: 0.8rem; /* Un poco más de padding para el botón del modal */
    font-size: 1rem;
}


/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/*                          SECCIÓN DE MUESTRA DE VIDEO                       */
/* -------------------------------------------------------------------------- */

/* Estilos para la sección que contiene el video de muestra. */
.video-showcase {
    padding: 3rem 0; /* Espaciado vertical amplio para destacar la sección. */
    background-color: var(--surface-color); /* Fondo coherente con otras superficies como tarjetas. */
    /* Comentario para el desarrollador: Si se desea un fondo distinto en modo claro, se podría descomentar la siguiente línea: */
    /* background-color: #e9ecef; */
}
/* Comentario para el desarrollador: No se necesita una regla específica para body.dark-mode .video-showcase
   si se desea que --surface-color maneje el color de fondo en ambos modos.
   Si se quisiera un color específico para el fondo de esta sección en modo oscuro, se añadiría aquí. */

/* Estilos para el título de la sección de video. */
.video-showcase h2 {
    font-family: 'Poppins', sans-serif; /* Coherencia con otros títulos de sección. */
    font-size: clamp(1.8rem, 4vw, 2.5rem); /* Tamaño de fuente responsivo. */
    font-weight: 600; /* Peso semi-bold. */
    text-align: center; /* Título centrado. */
    margin-bottom: 2.5rem; /* Espacio debajo del título, antes del video. */
    color: var(--text-color-primary); /* Color de texto primario, adaptable a temas. */
}

/*
 * Contenedor del video (video-wrapper).
 * Esta técnica (padding-bottom hack) se usa para hacer iframes responsivos
 * manteniendo una relación de aspecto fija (comúnmente 16:9 para videos).
 */
.video-wrapper {
    position: relative; /* Necesario para el posicionamiento absoluto del iframe hijo. */
    padding-bottom: 56.25%; /* Para una relación de aspecto 16:9 (calculado como 9 / 16 * 100%). */
    height: 0; /* El alto se controla con el padding-bottom, por lo que height debe ser 0. */
    overflow: hidden; /* Evita que el contenido del iframe (si fuera más grande) se desborde. */
    border-radius: 10px; /* Bordes redondeados para una apariencia más suave y moderna del contenedor del video. */
    box-shadow: 0 8px 20px var(--shadow-color-medium); /* Sombra elegante para destacar el video. */
}

/* Estilos para el iframe del video en sí. */
.video-wrapper iframe {
    position: absolute; /* Se posiciona absolutamente dentro del .video-wrapper. */
    top: 0;
    left: 0;
    width: 100%; /* Ocupa todo el ancho del wrapper. */
    height: 100%; /* Ocupa toda la altura calculada por el padding-bottom del wrapper. */
    border: none; /* Elimina cualquier borde por defecto del iframe. */
}


/* -------------------------------------------------------------------------- */
/*                             ESTILOS RESPONSIVE                             */
/* -------------------------------------------------------------------------- */

/* Para tablets y dispositivos más pequeños */
@media (max-width: 992px) {
    .navbar-nav {
        gap: 1.2rem; /* Reduce el espacio entre ítems del menú en tablets */
    }
    .navbar-nav a {
        font-size: 0.85rem; /* Reduce tamaño de fuente del menú */
    }
    .navbar-controls { /* Ajuste para que el conmutador no cause problemas */
        gap: 0.8rem;
    }
    .product-grid {
        gap: 2rem; /* Un poco más de espacio en tablets */
    }
}

/* Para móviles */
@media (max-width: 768px) {
    .container {
        padding-left: 15px; /* Reduce el padding lateral del contenedor principal en móviles */
        padding-right: 15px;
    }
    .navbar .container {
        flex-direction: column; /* Apila los elementos de la barra de navegación verticalmente */
        align-items: flex-start; /* Alinea los elementos a la izquierda */
    }
    .navbar-controls { /* El grupo de iconos y conmutador se mueve debajo del menú en móviles */
        width: 100%;
        display: flex;
        justify-content: space-between; /* Para espaciar los iconos de la navbar del conmutador */
        margin-top: 0.8rem;
    }
    .navbar-nav {
        flex-direction: column; /* Apila los ítems del menú verticalmente */
        width: 100%; /* Ocupa todo el ancho */
        margin-top: 1rem; /* Espacio después de la marca */
        gap: 0.5rem; /* Espacio reducido entre ítems del menú */
    }
    .navbar-nav li {
        width: 100%; /* Cada ítem del menú ocupa todo el ancho */
    }
    .navbar-nav a {
        display: block; /* Hace que los enlaces ocupen todo el ancho de su contenedor <li> */
        padding: 0.6rem 0; /* Padding vertical para facilitar el toque */
        font-size: 0.9rem; /* Restaura un poco el tamaño para legibilidad en móvil */
    }
    .navbar-nav a::after { /* Deshabilita el efecto de subrayado en móvil si se prefiere */
        display: none;
    }
    .navbar-icons { /* Ya no necesita margen superior porque navbar-controls lo maneja */
        margin-top: 0;
        /* align-self: flex-start;  No es necesario si navbar-controls es flex y space-between */
    }

    .hero {
        padding: 3.5rem 0; /* Reduce el padding vertical en la sección hero */
        border-radius: 0; /* Quita bordes redondeados en móvil si se ve mejor */
    }
    /* .hero h1 se ajusta con clamp() */
    /* .hero p se ajusta con clamp() */

    .featured-products h2 {
        margin-bottom: 2rem; /* Reduce el margen inferior del título de productos */
    }
    .product-grid {
        gap: 1.5rem; /* Reduce el espacio entre tarjetas de producto */
    }

    .footer-links {
        grid-template-columns: 1fr; /* Apila las columnas de enlaces del footer */
        text-align: center; /* Centra el texto de los enlaces del footer */
    }
    .footer-links h4 {
        margin-top: 1rem; /* Espacio antes de cada título en móvil */
    }
    .footer-links ul li a:hover, .footer-links ul li a:focus {
        padding-left: 0; /* Quita el desplazamiento en hover para móvil */
    }

    .footer-bottom {
        flex-direction: column; /* Apila el copyright y los iconos sociales */
        gap: 1.5rem; /* Espacio entre el copyright y los iconos */
        text-align: center; /* Centra el texto del copyright */
    }
}

/*
 * NOTA SOBRE ICONOS:
 * Los estilos .icon-*::before con 'content' y emojis son solo placeholders temporales.
 * Se recomienda encarecidamente usar una librería de iconos SVG (FontAwesome, Bootstrap Icons, Material Icons)
 * o SVGs individuales para una mejor calidad visual, accesibilidad y rendimiento en un sitio en producción.
 * Estos placeholders no tienen buena semántica ni son bien interpretados por lectores de pantalla.
 */
/* Estilos para los iconos de placeholder (ya definidos en el HTML, aquí solo como recordatorio) */
/*
.icon-search::before,
.icon-cart::before,
.icon-user::before,
.icon-facebook::before,
.icon-twitter::before,
.icon-instagram::before,
.icon-youtube::before {
    display: inline-block;
    font-style: normal; // Asegura que no se apliquen estilos de fuente itálica
    font-variant: normal; // Asegura que no se apliquen variantes de fuente como small-caps
    text-rendering: auto; // Permite al navegador optimizar el renderizado de texto
    -webkit-font-smoothing: antialiased; // Mejora el suavizado de fuentes en Webkit
}
*/
