/* --- Fuentes y Estilos Base --- */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700;900&display=swap');

body {
    background-color: #101010;
    color: #FFFFFF;
    font-family: 'Montserrat', sans-serif;
    margin: 0;
    padding: 0;
    position: relative;
}

body::before { /* Patrón de fondo */
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('assets/isotipo-blanco.png');
    background-repeat: repeat;
    background-size: 40px;
    opacity: 0.07;
    z-index: -1;
}

/* --- Layout General --- */
header, main.hero, main, footer {
    position: relative;
    width: 100%;
    padding: 20px 0;
}

.container { /* Contenedor centrado con fondo sólido */
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 50px;
    background-color: #101010;
}

/* --- Header y Footer --- */
header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 20px;
    padding-bottom: 20px;
}

footer {
    border-top: 1px solid #222;
}

footer .container {
    text-align: center;
    padding-top: 20px;
    padding-bottom: 20px;
}

.logo img {
    height: 40px;
}

nav a {
    color: #FFFFFF;
    text-decoration: none;
    margin-left: 25px;
    font-weight: 700;
}

/* --- Página de Inicio (Hero) --- */
main.hero {
    padding-top: 60px;
    padding-bottom: 80px;
}

main.hero .container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 50px;
    padding-top: 40px;
    padding-bottom: 40px;
}

.hero-texto h1 {
    font-size: 72px;
    font-weight: 900;
    margin: 0;
    line-height: 1.1;
    text-transform: uppercase;
}
.hero-texto h1 span { color: #E60023; }
.hero-texto p {
    font-size: 18px;
    margin-top: 20px;
    max-width: 500px;
}
.hero-imagen img {
    max-width: 400px;
    height: auto;
    border-radius: 10px;
}

/* Botones Hero */
.hero-botones {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-top: 40px;
}
.hero-botones .boton-principal,
.hero-botones .boton-secundario {
    margin: 0;
    text-decoration: none;
}
.hero-botones span {
    font-weight: 700;
    color: #FFFFFF;
    font-size: 18px;
    padding: 0 5px;
}
.boton-principal {
    display: inline-block;
    background-color: #E60023;
    color: #FFFFFF;
    padding: 15px 35px;
    text-decoration: none;
    font-weight: 700;
    border-radius: 5px;
    text-transform: uppercase;
    border: 2px solid #E60023; /* Borde añadido para consistencia */
    transition: background-color 0.3s ease, color 0.3s ease;
}
.boton-principal:hover {
    background-color: transparent;
    color: #E60023;
}
.boton-secundario {
    background-color: transparent;
    border: 2px solid #E60023;
    color: #E60023;
}
.boton-secundario:hover {
    background-color: #E60023;
    color: #FFFFFF;
}

/* --- Página de Contacto --- */
.container-contacto {
    max-width: 1100px;
    margin: 0 auto;
    padding: 40px 20px;
    text-align: center;
    background-color: #101010;
}
.container-contacto > p { /* Selector > p para el subtítulo */
    margin-bottom: 50px;
}
.contacto-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    text-align: left;
}
.info-contacto { /* Columna info */
    flex: 1;
    min-width: 300px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    background-color: #1a1a1a;
    padding: 30px;
    border-radius: 10px;
}
.info-item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}
.info-icono {
    font-size: 24px;
    color: #E60023;
    margin-top: 5px;
}
.info-texto strong {
    display: block;
    font-size: 18px;
    color: #FFFFFF;
    margin-bottom: 5px;
}
.info-texto a, .info-texto p {
    font-size: 16px;
    color: #ccc;
    text-decoration: none;
    margin: 0;
}
.info-texto a:hover { color: #E60023; }

.formulario-contacto { /* Columna formulario */
    flex: 2;
    min-width: 300px;
    margin-top: 0;
}
.campo-form { margin-bottom: 20px; }
.campo-form label { display: block; margin-bottom: 5px; font-weight: 700; }
.campo-form input, .campo-form textarea {
    width: 100%;
    padding: 15px;
    background-color: #222;
    border: 1px solid #444;
    border-radius: 5px;
    color: white;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    box-sizing: border-box;
}
.formulario-contacto .boton-principal { width: 100%; border: none; cursor: pointer; }

/* --- Página de Catálogo --- */
.container-catalogo {
    max-width: 1600px;
    margin: 0 auto;
    padding: 40px 20px;
    text-align: center;
    min-height: calc(100vh - 200px);
    display: flex;
    flex-direction: column;
    align-items: center;
}
.container-catalogo h1 {
    font-size: 48px;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 10px;
}
.container-catalogo > p { /* Selector > p para el subtítulo */
    margin-bottom: 40px;
    font-size: 18px;
    color: rgba(255, 255, 255, 0.8);
}
.galeria-productos {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 25px;
    width: 100%;
    max-width: 1600px;
}
.producto-card {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    aspect-ratio: 1 / 1.25;
    background-color: #101010;
}
.producto-card:hover {
    transform: scale(1.08) translateY(-10px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.5);
    z-index: 10;
}
.producto-imagenes-wrapper {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    display: flex; justify-content: center; align-items: center;
}
.producto-imagen { /* Carrusel */
    width: 100%; height: 100%; object-fit: cover;
    opacity: 0; transition: opacity 0.6s ease-in-out; position: absolute;
}
.producto-card .producto-imagen:first-child { opacity: 1; }
.producto-imagen.active { opacity: 1; }
.producto-card:hover .producto-imagen:first-child:not(.active) { opacity: 0; }
.producto-card:not(:hover) .producto-imagen:not(:first-child) { opacity: 0; }

.producto-hover { /* Overlay */
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to top, rgba(0,0,0,0.95), rgba(0,0,0,0.1));
    color: white; display: flex; flex-direction: column; justify-content: flex-end;
    padding: 20px; box-sizing: border-box; opacity: 0; transition: opacity 0.4s ease;
}
.producto-card:hover .producto-hover { opacity: 1; }
.producto-hover h3, .producto-hover p, .producto-hover .boton-catalogo {
    transform: translateY(15px); transition: transform 0.4s ease, opacity 0.4s ease; opacity: 0;
}
.producto-card:hover .producto-hover h3,
.producto-card:hover .producto-hover p,
.producto-card:hover .producto-hover .boton-catalogo {
    transform: translateY(0); opacity: 1;
}
.producto-card:hover h3 { transition-delay: 0.1s; }
.producto-card:hover p { transition-delay: 0.2s; }
.producto-card:hover .boton-catalogo { transition-delay: 0.3s; }
.boton-catalogo { /* Botón 'Me Interesa' */
    display: inline-block; background-color: #E60023; color: #FFFFFF;
    padding: 10px 20px; text-decoration: none; font-weight: 700;
    border-radius: 5px; text-align: center; align-self: flex-start;
    border: 2px solid #E60023;
    transition: background-color 0.3s ease, color 0.3s ease;
}
.boton-catalogo:hover {
    background-color: transparent;
    color: #E60023;
}

/* Acordeón de Categorías */
.acordeon-wrapper { width: 100%; max-width: 1600px; margin-top: 40px; }
.categoria-acordeon { border-bottom: 1px solid #333; }
.categoria-trigger {
    width: 100%; background: none; border: none; color: white;
    font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: 700;
    text-transform: uppercase; padding: 25px 10px; display: flex;
    justify-content: space-between; align-items: center; cursor: pointer; text-align: left;
}
.categoria-trigger:hover { color: #E60023; }
.categoria-icono { display: inline-block; width: 20px; height: 20px; position: relative; transition: transform 0.3s ease; }
.categoria-icono::before, .categoria-icono::after {
    content: ''; position: absolute; top: 50%; left: 50%; width: 100%; height: 3px;
    background-color: white; transform: translate(-50%, -50%);
}
.categoria-icono::after { transform: translate(-50%, -50%) rotate(90deg); }
.categoria-trigger:hover .categoria-icono::before, .categoria-trigger:hover .categoria-icono::after { background-color: #E60023; }
.categoria-trigger.active .categoria-icono { transform: rotate(135deg); }
.categoria-contenido { max-height: 0; overflow: hidden; transition: max-height 0.5s ease-out; }
.categoria-contenido.show { max-height: 5000px; transition: max-height 1s ease-in; }
.categoria-contenido .galeria-productos { padding: 30px 0; }

/* --- Página de Personalización --- */
.container-personaliza {
    max-width: 900px; margin: 0 auto; padding: 40px 20px;
    background-color: #101010; text-align: center;
}
.hero-personaliza h1 {
    font-size: 48px; text-transform: uppercase; color: #E60023; margin-bottom: 15px;
}
.hero-personaliza p {
    font-size: 18px; color: #ccc; max-width: 600px; margin: 0 auto 50px auto;
}
.como-funciona {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px;
    margin-bottom: 60px; text-align: left;
}
.paso-guia { background-color: #1a1a1a; padding: 25px; border-radius: 10px; }
.paso-guia span { font-size: 24px; font-weight: 900; color: #E60023; }
.paso-guia h3 { margin: 10px 0; font-size: 20px; }
.paso-guia p { font-size: 15px; color: #aaa; line-height: 1.6; }

.configurador-form {
    background-color: #1a1a1a; padding: 40px; border-radius: 10px;
    text-align: left; overflow: hidden;
}
.step-title { text-align: center; font-size: 24px; font-weight: 700; margin-bottom: 30px; }
.step-subtitle { text-align: center; font-size: 16px; color: #aaa; margin-top: -20px; margin-bottom: 30px; }
.progress-bar { display: flex; justify-content: space-between; margin-bottom: 40px; position: relative; }
.progress-bar::before {
    content: ''; position: absolute; top: 50%; left: 0; transform: translateY(-50%);
    height: 4px; width: 100%; background-color: #333; z-index: 1;
}
.progress-step { font-weight: 700; color: #888; background-color: #1a1a1a; z-index: 2; padding: 0 10px; }
.progress-step.active { color: #E60023; }

.form-step { display: none; animation: fadeIn 0.5s ease; }
.form-step.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

.btn-group { display: flex; justify-content: space-between; margin-top: 30px; }
.btn-group .boton-secundario { background-color: #333; border-color: #333; color: white; }
.btn-group .boton-secundario:hover { background-color: #444; }
.input-file {
    font-family: 'Montserrat', sans-serif; background-color: #333; border: none;
    border-radius: 5px; padding: 10px; color: white; width: 100%; box-sizing: border-box;
}
.nota-importante {
    background-color: #222; border-left: 5px solid #E60023; padding: 15px 20px;
    margin-bottom: 30px; border-radius: 5px; font-size: 15px; line-height: 1.6; color: #ccc;
}
.prenda-selector {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 15px;
}
.prenda-card {
    display: block; background-color: #222; padding: 20px; border-radius: 8px;
    border: 2px solid #333; cursor: pointer; transition: all 0.3s ease; position: relative;
}
.prenda-card input[type="checkbox"] { display: none; }
.prenda-info { display: flex; align-items: center; gap: 15px; }
.prenda-icono { font-size: 28px; }
.prenda-card:hover { border-color: #555; transform: translateY(-3px); }
.prenda-card input[type="checkbox"]:checked + .prenda-info { color: #E60023; }
/* .prenda-card.selected { border-color: #E60023; box-shadow: 0 0 10px rgba(230, 0, 35, 0.5); } */

.nota-tallas { font-size: 15px; color: #aaa; margin-bottom: 30px; text-align: center; line-height: 1.6; }
.tablas-tallas-wrapper {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px; margin-bottom: 30px;
}
.tabla-tallas { background-color: #222; border-radius: 8px; overflow: hidden; border: 1px solid #333; }
.tabla-titulo {
    font-size: 18px; font-weight: 700; text-align: center; padding: 12px;
    background-color: #333; margin: 0; color: #E60023;
}
.talla-fila { display: grid; grid-template-columns: 1fr 100px; align-items: center; padding: 10px 15px; border-bottom: 1px solid #333; }
.talla-fila.header { background-color: #2a2a2a; font-weight: 700; padding: 8px 15px; }
.talla-fila:last-child { border-bottom: none; }
.talla-fila label, .talla-fila span { font-size: 15px; }
.talla-fila label { font-weight: 700; }
.input-talla {
    width: 70px; padding: 8px; font-size: 15px; background-color: #333;
    border: 1px solid #444; color: white; border-radius: 5px; justify-self: end; text-align: center;
}
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; appearance: none; }
.total-general {
    text-align: right; font-size: 20px; font-weight: 700; margin-top: 20px;
    padding: 15px; background-color: #333; border-radius: 8px;
}

/* --- Responsive General --- */
@media (max-width: 1700px) { .galeria-productos { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1300px) { .galeria-productos { grid-template-columns: repeat(3, 1fr); } .container { padding-left: 20px; padding-right: 20px; } }
@media (max-width: 992px) {
    .galeria-productos { grid-template-columns: repeat(2, 1fr); }
    main.hero .container { flex-direction: column; text-align: center; }
    .hero-imagen { margin-top: 40px; }
    .contacto-wrapper { flex-direction: column; }
    .container-contacto { max-width: 700px; }
    .hero-botones { justify-content: center; }
}
@media (max-width: 768px) {
    header .container { flex-direction: column; gap: 20px; }
    nav { display: flex; flex-wrap: nowrap; justify-content: center; width: 100%; overflow-x: auto; }
    nav a { margin: 0 8px; font-size: 14px; white-space: nowrap; }
    .hero-texto h1 { font-size: 48px; }
    .hero-imagen img { max-width: 80%; }
    .hero-botones { flex-direction: column; gap: 15px; width: 100%; align-items: stretch; }
    .hero-botones .boton-principal, .hero-botones .boton-secundario { width: 90%; margin: 0 auto; box-sizing: border-box; }
    .como-funciona { grid-template-columns: 1fr; }
    .configurador-form { padding: 20px; }
    .progress-bar { font-size: 12px; }
    .prenda-selector { grid-template-columns: 1fr; }
    .tablas-tallas-wrapper { grid-template-columns: 1fr; }
    .btn-group { flex-direction: column-reverse; gap: 15px; align-items: stretch; }
    .btn-group .boton-principal { width: 100%; box-sizing: border-box; }
}
@media (max-width: 600px) {
    .galeria-productos { grid-template-columns: repeat(1, 1fr); }
    .container-catalogo h1 { font-size: 38px; }
    .container-catalogo p { font-size: 16px; }
    .categoria-trigger { font-size: 18px; }
}
/* --- ESTILOS PARA INPUT DE CANTIDAD +/- --- */
.quantity-input {
    display: flex;
    align-items: center;
    justify-content: flex-end; /* Alinea a la derecha */
}

.quantity-btn {
    background-color: #444;
    border: none;
    color: white;
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
    width: 30px;
    height: 30px;
    line-height: 30px; /* Centra el +/- verticalmente */
    text-align: center;
    border-radius: 5px;
    transition: background-color 0.2s ease;
}

.quantity-btn:hover {
    background-color: #555;
}
.quantity-btn.minus {
    margin-right: 5px;
}
.quantity-btn.plus {
    margin-left: 5px;
}

.input-talla[readonly] { /* Estilo del input cuando es readonly */
    width: 45px; /* Más angosto que antes */
    padding: 8px 5px; /* Ajustamos padding */
    font-size: 16px;
    background-color: #333;
    border: 1px solid #444;
    color: white;
    border-radius: 5px;
    text-align: center;
    /* Quitamos las flechas por si acaso */
    -moz-appearance: textfield;
     appearance: none;
}
.input-talla[readonly]::-webkit-inner-spin-button, 
.input-talla[readonly]::-webkit-outer-spin-button { 
  -webkit-appearance: none; 
  margin: 0; 
}

/* Ajustamos la fila de talla para el nuevo input */
.talla-fila {
    display: grid;
    /* Ajustamos las columnas para dar espacio a los botones */
    grid-template-columns: 1fr auto; 
    align-items: center;
    padding: 10px 15px;
    border-bottom: 1px solid #333;
}
.talla-fila.header {
    grid-template-columns: 1fr 1fr; /* Mantenemos el header con 2 columnas */
}
/* --- ESTILOS ADICIONALES PARA TABLAS DINÁMICAS (Paso 3 Personaliza) --- */

#dynamic-talla-tables {
    /* Mantenemos el grid principal para las PRENDAS */
    display: grid;
    grid-template-columns: 1fr; /* Cada prenda ocupa una fila */
    gap: 40px; /* Espacio entre bloques de prenda */
    margin-bottom: 30px;
}

.prenda-tallas-container {
    background-color: #2a2a2a; /* Fondo un poco más claro para agrupar tablas de una prenda */
    padding: 20px;
    border-radius: 8px;
    border: 1px solid #444;
}

.prenda-titulo {
    font-size: 20px;
    text-align: center;
    color: #FFFFFF;
    margin: 0 0 20px 0;
    text-transform: capitalize; /* Pone mayúscula inicial */
    border-bottom: 1px solid #444;
    padding-bottom: 10px;
}

/* El wrapper interno ahora usa grid para Hombre/Mujer/Niño */
.tablas-tallas-wrapper.interno {
    display: grid;
     /* Ajusta las columnas según el espacio, mínimo 200px */
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 0; /* Quitamos margen inferior aquí */
}

/* Quitamos el borde de la tabla individual, ya lo tiene el contenedor */
.tabla-tallas {
   border: none;
}

/* Ajustamos el responsive si es necesario */
@media (max-width: 768px) {
    .tablas-tallas-wrapper.interno {
        grid-template-columns: 1fr; /* Una columna en móvil */
    }
     .prenda-tallas-container {
        padding: 15px;
    }
}