/* 📦 Contenedor relativo general (necesario para elementos posicionados) */
.relative {
    position: relative;
}

/* 🎞️ Contenedor principal del Swiper */
.swiper {
    width: 100%;
    height: 790px;
}

/* 🎞️ Estilos base del carrusel Swiper 3D */
.swiper-3d-7 {
    /* (Opcional) personalizar si se desea */
}

/* 🎞️ Contenedor de slides (hijos directos son .swiper-slide) */
.swiper-wrapper {
    display: flex;
}

/* 🎞️ Cada tarjeta / slide individual */
.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: transparent;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%; /* 💡 Asegura que cada slide se adapte al nuevo alto del swiper */
}

/* 📦 Caja principal de la tarjeta (contenedor completo) */
.tf-card-box {
    width: 100%;                           /* 🔁 Ocupa todo el ancho disponible del slide */
    max-width: 350px;                      /* 🔒 Limita el ancho máximo para mantener proporción */
    min-height: 480px;                     /* ⬆️ Altura mínima para dar espacio al contenido */
    border: 20px solid #000;               /* 🎨 Borde grueso oscuro para efecto de marco */
    border-radius: 32px;                   /* 🔄 Bordes redondeados sutiles en todo el contenedor */
    overflow: hidden;                      /* 🧼 Oculta contenido que se salga (ej: imagen o hover) */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3); /* 🌫️ Sombra suave para efecto de elevación */
    background: #000;                      /* 🎨 Fondo negro/gris oscuro elegante para contraste de las letras debajo de imagen */
    display: flex;                         /* 🔧 Usa flexbox para distribuir contenido verticalmente */
    flex-direction: column;               /* ⬇️ Apila hijos (imagen y texto) verticalmente */
    justify-content: space-between;       /* ↕️ Separa parte superior (imagen) de inferior (texto) */
}

/* 📸 Contenedor de imagen + botón (parte superior de la tarjeta) */
.card-media {
    position: relative;
    overflow: hidden;
    border-radius: 0px; /* 🔁 también aquí por si hay superposición de hover o botón */
    height: 340px;        /* ⬆️ Aumenta altura para evitar espacio negro */
}

/* 🖼️ Imagen del proyecto (con bordes redondeados internos) */
.img-proyecto {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 16px; /*  Redondea todas las esquinas para encajar con .tf-card-box */
}

/* 🏷️ Texto sobre la imagen */
.featured-countdown {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    padding: 5px 12px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: bold;
}

/*  Botón oculto por defecto, aparecerá con animación */
.button-place-bid {
    opacity: 0;
    transform: translateY(20px); /*  Escondido hacia abajo */
    transition: all 0.6s ease;
    pointer-events: none;
    visibility: hidden;
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translate(-50%, 20px);
}

/*  Muestra el botón con animación al hacer hover */
.tf-card-box:hover .button-place-bid,
.card-media.show-button .button-place-bid {
    opacity: 1;
    transform: translate(-50%, 0); /*  animacion hacia arriba */
    pointer-events: auto;
    visibility: visible;
}

.tf-card-box:hover .img-proyecto {
    transform: scale(1.10);
}



/* 🔘 Estilo visual del botón  */
.tf-button {
    display: inline-block;
    padding: 10px 24px;
    background: #e5e5e5;
    color: #111;
    text-decoration: none;
    border-radius: 12px;
    font-weight: 700;
    font-size: 15px;
    transition: all 0.3s ease;
    box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
}

.tf-button:hover {
    background: #fff;
}

/*  Información textual debajo de la imagen */
.meta-info {
    margin-top: 0px;
    padding: 15px;
}

/*  Alineación de texto */
.text-center {
    text-align: center;
}

/* Nombre del proyecto o servicio */
.name {
    font-size: 21px;
    font-weight: bold;
    color: #fff;
}

/*  Precio o especificación secundaria */
.price {
    font-size: 17px;
    color: #ccc;
}

/*  Contenedor de ícono + valor (si se usa) */
.gem {
    display: flex;
    align-items: center;
    gap: 5px;
    justify-content: center;
}

/* Ícono decorativo */
.icon-gem {
    font-size: 16px;
    color: #ffcc00;
}

/*  Navegación del Swiper */
.swiper-pagination {
    bottom: 65px !important;          /* ⬆️ Subido desde 10px */
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

/* ⚪ Puntos de paginación inactivos */
.swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    background: #bbb;                 /* 🎨 Color gris claro */
    opacity: 1;
    transition: all 0.3s ease;
    border-radius: 50%;
    transform: scale(1);
}

/* 🔵 Punto activo */
.swiper-pagination-bullet-active {
    background: #f0eaea;              /* 🎯 Color azul brillante */
    transform: scale(1.5);            /* 🔍 Agrandado para destacar */
    box-shadow: 0 0 8px rgba(175, 173, 173, 0.6); /* 💫 Efecto glow */
}


/*  Posición específica para paginación numerada */
.pagination-number {
    bottom: 10px;
}

/* ⬅️➡️ Flechas de navegación */
.swiper-button-next,
.swiper-button-prev {
    position: absolute;
    top: 50%;
    width: 27px;
    height: 44px;
    margin-top: -22px;
    z-index: 10;
    cursor: pointer;
    background-size: 27px 44px;
    background-position: center;
    background-repeat: no-repeat;
}

.pagination-number .swiper-pagination-bullet::after {
  content: attr(data-index);
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}



.next-3d {
    right: 10px;
}

.prev-3d {
    left: 10px;
}

/* 🗂️ Superposición de elementos sobre swiper */
.over {
    z-index: 11;
}

/* ❤️ Botón tipo favorito */
.wishlist-button {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 20px;
    color: #ff0000;
    cursor: pointer;
}

/* ❤️ Estilo del ícono */
.icon-heart {
    font-size: 20px;
}



/* 🔥 Estilo especial para el slide central activo */
.swiper-slide-active .tf-card-box {
    box-shadow:
        0 0 60px rgba(255, 255, 255, 0.15),   /* 🔆 resplandor blanco alrededor */
        0 20px 30px rgba(0, 0, 0, 0.5),       /* ⬇️ sombra inferior */
        0 -20px 30px rgba(0, 0, 0, 0.25),     /* ⬆️ sombra superior */
        -20px 0 30px rgba(0, 0, 0, 0.25),     /* ⬅️ sombra izquierda */
        20px 0 30px rgba(0, 0, 0, 0.25);      /* ➡️ sombra derecha */
    transition: box-shadow 0.4s ease;
    transform: scale(1.02);
    z-index: 2;
}


/* 🖼️ Efecto de zoom suave al hacer hover en la imagen */
.card-media {
    overflow: hidden; /* 👈 importante para recortar el zoom */
    position: relative;
}

.card-media .img-proyecto {
    transition: transform 0.15s ease; /* ✨ transición suave */
}

.card-media:hover .img-proyecto {
    transform: scale(1.10); /* 🔍 ligero zoom al hacer hover */
}



/* 📱 Responsividad para tabletas y móviles */
@media (max-width: 1024px) {
    .swiper {
        height: 680px; /* ⬇️ Ajusta altura general en pantallas más pequeñas */
    }

    .tf-card-box {
        max-width: 88%;           /* 📏 Que no ocupe el 100%, deja margen a los lados */
        min-height: 440px;        /* ↕️ Altura ajustada para mantener proporción */
        border: 16px solid #000000;  /* 🎨 Borde más delgado para evitar saturación visual */
    }

    .card-media {
        height: 320px;            /* 🖼️ Da más espacio a la imagen en móvil/tablet */
    }

    .img-proyecto {
        height: 100%;             /* ✅ Que ocupe toda la altura del contenedor */
        border-radius: 14px;      /* 🔄 Menos redondeado para pantallas pequeñas */
    }

    .name {
        font-size: 18px;          /* 🔠 Ajuste de texto para que no desborde */
    }

    .price {
        font-size: 16px;          /* 💲 Más pequeño pero legible */
    }

    .button-place-bid {
        bottom: 15px;             /* 🧭 Reposicionado por menor altura */
    }

    .swiper-button-next,
    .swiper-button-prev {
        width: 24px;
        height: 40px;
        margin-top: -20px;
        background-size: 24px 40px;
    }

    .swiper-pagination {
        bottom: 0px;              /* 📍 Subido para que se vea en móviles */
    }
}





/* MODAL *//* Modal Styles */
.mil-modal {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0,0,0,0.85);
  backdrop-filter: blur(5px);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.mil-modal.show {
  opacity: 1;
}

.mil-modal-content {
  position: relative;
  margin: 5% auto;
  max-width: 1200px;
  width: 90%;
  animation: milModalFadeIn 0.4s ease;
}

@keyframes milModalFadeIn {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

.mil-close {
  position: absolute;
  right: 20px;
  top: 20px;
  font-size: 35px;
  font-weight: 300;
  color: #999;
  cursor: pointer;
  transition: all 0.3s;
  z-index: 10;
}

.mil-close:hover {
  color: #fff;
  transform: rotate(90deg);
}

.mil-main-image {
  height: 400px;
  background-color: #0d0d0d;
  border: 1px solid #222;
}

.mil-main-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.mil-thumbnail-container {
  margin-top: 15px;
}

.mil-thumbnail {
  width: 70px;
  height: 70px;
  border-radius: 5px;
  overflow: hidden;
  cursor: pointer;
  opacity: 0.7;
  transition: all 0.3s;
  border: 2px solid transparent;
}

.mil-thumbnail:hover, .mil-thumbnail.active {
  opacity: 1;
  border-color: var(--accent-color);
}

.mil-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mil-secondary-btn {
  background-color: transparent;
  border: 1px solid var(--accent-color);
  color: var(--accent-color);
}

.mil-secondary-btn:hover {
  background-color: rgba(var(--accent-color-rgb), 0.1);
}

/* Responsive */
@media (max-width: 992px) {
  .mil-modal-grid {
    flex-direction: column;
  }
  
  .mil-main-image {
    height: 300px;
  }
  
  .mil-modal-details {
    padding-left: 0 !important;
    margin-top: 30px;
  }
}

@media (max-width: 576px) {
  .mil-modal-content {
    width: 95%;
    padding: 20px;
  }
  
  .mil-main-image {
    height: 200px;
  }
  
  .mil-modal-actions {
    flex-direction: column;
  }
  
  .mil-close {
    right: 10px;
    top: 10px;
    font-size: 28px;
  }
}