/* Fuentes elegantes tipo joyería */
@import url('https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400&family=Playfair+Display:wght@400;500;600;700&display=swap');

:root {
    --color-oro: #D4AF37;
    --color-oro-claro: #F4E4A6;
    --color-plata: #C0C0C0;
    --color-bronce: #CD7F32;
    --color-negro-elegante: #1a1a1a;
    --color-blanco-puro: #ffffff;
    --color-gris-claro: #f8f9fa;
    --color-gris-medio: #e9ecef;
    --color-gris-oscuro: #495057;
    --sombra-suave: 0 4px 20px rgba(0,0,0,0.08);
    --sombra-intensa: 0 8px 40px rgba(0,0,0,0.12);

    /* Tamaños de imagen en las cards y mínimo/máximo para modal */
    --card-image-height: 180px; /* alto fijo del área de imagen en cada card */
    --modal-image-min: 300px;
    --modal-image-max: 700px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Crimson Text', 'Bookman Old Style', serif;
    background-color: var(--color-gris-claro);
    color: #333;
    line-height: 1.6;
}

/* HEADER ELEGANTE */
.header-elegante {
    background: linear-gradient(135deg, var(--color-negro-elegante) 0%, #2d2d2d 100%);
    border-bottom: 3px solid var(--color-oro);
    box-shadow: var(--sombra-suave);
}

/* Logo principal (cuando se usa imagen) */
.logo-img {
    max-height: 110px; /* ajustar según necesites */
    width: auto;
    display: inline-block;
}

/* Si se usa texto como logo */
.logo-joyeria {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    font-size: 2.2rem;
    color: var(--color-blanco-puro) !important;
    text-decoration: none;
    letter-spacing: 1.5px;
}

.logo-joyeria:hover {
    color: var(--color-oro-claro) !important;
}

.subtitulo-joyeria {
    font-family: 'Crimson Text', serif;
    font-size: 0.9rem;
    color: var(--color-plata);
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-top: -5px;
}

/* Nav links centrados debajo del logo */
.nav-links {
    gap: 0.5rem;
    margin-top: 6px;
    flex-wrap: wrap;
    justify-content: center;
}

/* NAVEGACIÓN */
.nav-link-joyeria {
    color: var(--color-blanco-puro) !important;
    font-weight: 500;
    padding: 0.5rem 1rem !important;
    margin: 0 0.2rem;
    border-radius: 4px;
    transition: all 0.3s ease;
}

.nav-link-joyeria:hover {
    background-color: rgba(212, 175, 55, 0.1);
    color: var(--color-oro) !important;
    transform: translateY(-1px);
}

.btn-joyeria {
    background: linear-gradient(135deg, var(--color-oro) 0%, #B8860B 100%);
    border: none;
    color: var(--color-negro-elegante);
    font-weight: 600;
    padding: 0.5rem 1.5rem;
    border-radius: 25px;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
    font-family: 'Playfair Display', serif;
}

.btn-joyeria:hover {
    transform: translateY(-2px);
    box-shadow: var(--sombra-intensa);
    color: var(--color-negro-elegante);
}

/* BOTÓN CONTACTAR (estilo principal para modal) */
.btn-contact {
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%); /* WhatsApp green */
    color: #fff;
    border: none;
    padding: 0.75rem 1.25rem;
    font-size: 1.05rem;
    font-weight: 700;
    border-radius: 8px;
    box-shadow: 0 6px 18px rgba(0,0,0,0.15);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
}
.btn-contact:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 24px rgba(0,0,0,0.2);
    text-decoration: none;
    color: #fff;
}

/* HERO SECTION */
.hero-section {
    background: linear-gradient(135deg, var(--color-gris-medio) 0%, var(--color-gris-claro) 100%);
    padding: 80px 0;
    text-align: center;
}

.titulo-principal {
    font-family: 'Playfair Display', serif;
    font-size: 3.5rem;
    font-weight: 700;
    color: var(--color-negro-elegante);
    margin-bottom: 1rem;
    letter-spacing: 1px;
}

.subtitulo-principal {
    font-size: 1.3rem;
    color: var(--color-gris-oscuro);
    margin-bottom: 2rem;
    font-style: italic;
}

/* PRODUCT CARDS
   - Cada card tendrá la misma altura.
   - El área de imagen (.producto-imagen-wrapper) tendrá altura fija (var(--card-image-height)).
*/
.producto-card {
    background: var(--color-blanco-puro);
    border: 1px solid var(--color-gris-medio);
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.4s ease;
    box-shadow: var(--sombra-suave);
    margin-bottom: 2rem;

    display: flex;
    flex-direction: column;
    height: 360px; /* misma altura para todas las cards */
}

.producto-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--sombra-intensa);
    border-color: var(--color-oro-claro);
}

/* Area fija para la imagen dentro de la card: todas iguales */
.producto-imagen-wrapper {
    width: 100%;
    height: var(--card-image-height);
    overflow: hidden;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* En la grid queremos que la imagen llene el área y se recorte proporcionalmente */
.producto-imagen {
    width: 100%;
    height: 100%;
    object-fit: cover; /* recorta para rellenar el área sin deformar */
    display: block;
    transition: transform 0.4s ease;
}

.producto-card:hover .producto-imagen {
    transform: scale(1.05);
}

.producto-cuerpo {
    padding: 12px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1 1 auto;
}

/* Texto y metadatos */
.producto-titulo {
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--color-negro-elegante);
    margin-bottom: 0.5rem;
}

.producto-descripcion {
    color: var(--color-gris-oscuro);
    font-size: 0.95rem;
    margin-bottom: 1rem;
    line-height: 1.4;
    overflow: hidden;
    max-height: 3.2rem; /* limitar para mantener altura de card */
}

.producto-precio {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-oro);
    margin-bottom: 1rem;
}

.producto-codigo {
    font-size: 0.85rem;
    color: var(--color-gris-oscuro);
    font-style: italic;
}

/* MODAL ELEGANTE */
.modal-joyeria .modal-content {
    border-radius: 15px;
    border: none;
    box-shadow: var(--sombra-intensa);
}

.modal-joyeria .modal-header {
    background: linear-gradient(135deg, var(--color-negro-elegante) 0%, #2d2d2d 100%);
    color: var(--color-blanco-puro);
    border-bottom: 3px solid var(--color-oro);
    border-radius: 15px 15px 0 0;
}

.modal-joyeria .modal-title {
    font-family: 'Playfair Display', serif;
    font-weight: 600;
    font-size: 1.5rem;
}

.modal-joyeria .modal-body {
    padding: 1.25rem 1.5rem;
    background: var(--color-blanco-puro);
}

.modal-joyeria .modal-footer {
    background: var(--color-gris-claro);
    border-top: 1px solid var(--color-gris-medio);
    border-radius: 0 0 15px 15px;
}

/*
 Modal: queremos que las imágenes se vean COMPLETAS dentro del contenedor del modal.
 Usamos object-fit: contain en .modal-img y centramos con background.
 Además permitimos que el JS ajuste dinámicamente la altura del contenedor (.modal-img-wrapper)
 según el tamaño del card o la ventana, manteniendo límites mínimos/máximos.
*/
.modal-img-wrapper {
    width: 100%;
    /* altura por defecto; JS puede sobrescribir inline para ajustarla dinámicamente */
    height: 420px;
    overflow: hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    background: #000; /* relleno visible para letterbox cuando se use contain */
    position: relative;
}

.modal-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* muestra la imagen completa sin recorte */
    display: block;
}

/* Carousel controls visibles en modal */
.carousel-control-prev,
.carousel-control-next {
    width: 50px;
    height: 50px;
    background: var(--color-oro);
    border-radius: 50%;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.9;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1;
}

/* RESPONSIVE adjustments */
@media (max-width: 992px) {
    :root {
        --card-image-height: 160px;
    }
    .producto-card { height: 340px; }
}

@media (max-width: 768px) {
    :root {
        --card-image-height: 140px;
    }
    .producto-card { height: 340px; }
}

@media (max-width: 576px) {
    :root {
        --card-image-height: 120px;
    }
    .producto-card { height: auto; } /* móvil: altura flexible */
    .producto-cuerpo { padding: 10px; }
    .modal-img-wrapper { height: auto; } /* JS manejará altura; para móvil permitimos auto */
    .btn-contact { width: 100%; justify-content: center; }
}

/* Animaciones */
.fade-in {
    animation: fadeIn 0.8s ease-in;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Badges */
.badge-joyeria {
    background: linear-gradient(135deg, var(--color-oro) 0%, #B8860B 100%);
    color: var(--color-negro-elegante);
    font-weight: 600;
    padding: 0.3rem 0.8rem;
    border-radius: 15px;
    font-size: 0.8rem;
}


/* ----- Ajustes para footer: fondo negro y texto blanco ----- */
/* Añade estas reglas al final de tu styles.css o reemplázalas por este bloque si prefieres */
.footer-joyeria {
    background: #000 !important;
    color: #fff !important;
    padding: 3rem 0 2rem;
}

.footer-joyeria h5 {
    color: #fff !important;
    font-family: 'Playfair Display', serif;
    color: var(--color-oro);
    margin-bottom: 1rem;
    font-size: 1.2rem;
}

.footer-joyeria p,
.footer-joyeria .producto-precio,
.footer-joyeria .producto-codigo,
.footer-joyeria a,
.footer-joyeria li {
    color: #fff !important;
}

.footer-joyeria a {
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-joyeria a:hover {
    color: var(--color-oro) !important;
}

.footer-divider {
    border-top: 1px solid rgba(212, 175, 55, 0.15);
    opacity: 0.4;
    margin: 2rem 0 1rem;
}

/* Asegurar contraste en íconos si son font-awesome */
.footer-joyeria .fa,
.footer-joyeria .fas {
    color: #fff !important;
}