/* =========================================
   SERVICIOS.CSS 
   eta pagina se encarga de los diseños de la pagina servicios_view.php
   aqui puedes modificar el color, estilos, forma y acomodo de los elementos de esa pagina
   ========================================= */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: 'Lato', sans-serif;
}
html{
    scroll-behavior: smooth;
}

:root {
    --naranja-principal: #e17203;
    --purpura-oscuro: #52073a;
    --blanco: #FFFFFF;
    --negro-texto: #000000;
}

/* =========================================
   CSS BLINDADO PARA LA PANTALLA DE CARGA 
   ========================================= */
/* Reemplaza .loader-container con la clase real que tengas en tu loader_view.php */
.loader-container {
    position: fixed !important; 
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important; 
    height: 100vh !important; 
    background-color: #ffffff; 
    z-index: 99999 !important; 
    
    display: flex !important;
    flex-direction: column !important; 
    justify-content: center !important; 
    align-items: center !important; 
    text-align: center !important; 
}

.imagen-principal {
    position: relative; /* clave */
    width: 100%;
    height: 80vh;
   
    margin-bottom: -20px;
}

.img-p {
    width: 100%;
    height: 97%;
    object-fit: cover; /* evita que se deforme */
}

.contenido-imagen {
    position: absolute; /* lo saca del flujo */
    top: 50%;
    left: 63%;
    transform: translate(-50%, -50%); /* lo centra */
    color: white;
    text-align: center;
}
h1{
    margin-top:15%;
    font-size: 2.8rem;
    margin-bottom: 10px;
    font-weight: 900;
}
h2{
       font-size: 2.3rem;
    font-weight: 400;
 
}
p{
    margin-top:20px;
    color:#fffcd4;
      font-size: 1.3rem;
      margin-right:40%;
      font-weight: 700;
      margin-bottom: 10px;
}
.boton-servicio{
display: inline-block;
width:150px;
height:35px;
border-radius: 15px;
border:none;
transition: transform 0.3s ease;
background-color: rgba(255, 255, 255, 0.864);
color: #202020;
 padding:4px 14px;
 text-align:center;
 margin-top: 5px;
 transition: transform 0.3s ease, color 0.3s ease;
}


    
.boton-servicio:hover{
    transform: scale(1.1);
    background-color:rgba(219, 218, 218, 0.864);
    
}
.link-info{
    display: inline-block;
margin-left:20px;
transition: transform 0.3s ease, color 0.3s ease;
}

.link-info:hover{
    transform: scale(1.1);
    color: #383838;
    cursor: pointer;
}
a{
    text-decoration: none;
    color:#FFFFFF;
}

    .contenedor-servicios {
       top:0;
        display: flex;
        flex-wrap: wrap;
        gap: 40px;
        justify-content: center;
        padding: 0px 40px 40px 40px;
        background-color: #f7f7f7;
        
    }

.card-servicio {
    position: relative;
    width: 300px;
    max-height: 480px;
    border-radius: 12px;
    overflow: hidden;
    background-color: #fff;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.397);
    display: flex;
    flex-direction: column;
    transition: 
        max-height 0.7s cubic-bezier(0.25, 0.8, 0.25, 1),
        transform 0.4s ease,
        box-shadow 0.4s ease;
}

.card-servicio:hover {
    max-height: 680px;
    transform: translateY(-3px); /* menos movimiento = más elegante */
    box-shadow: 0 18px 35px rgba(0, 0, 0, 0.35);
}

    .imagen-url {
      width: 300px;
        height: 300px; 
        display: block;
    }

    /* Contenedor de Título y Precio (Siempre visible abajo) */
    .info-basica {
         position: relative; /* 👈 esto es lo que te falta */
        padding: 14px 16px 6px;
    background: #fff;
    z-index: 2;
      
        
    }
    

    .info-basica h3 { 
        margin: 0; 
        font-size: 1.2rem; 
        color: #383838; 
      
    }

    .info-basica .precio { 
        display: block;
        font-size: 1.1rem;
        font-weight: bold; 
        color: #f78605; /* Color distintivo para el precio */
        margin-top: 5px;
    }
.badge-nuevo {
    position: absolute;
    top: 10px;
    left: 10px;
    background-color:#8cee04;
    color: white;
    padding: 7px 27px;
    font-size: 0.9rem;
    font-weight: bold;
    text-transform: uppercase;
    border-radius: 4px;
    z-index: 10; /* Para que esté por encima de la imagen */

    animation: pulse-nuevo 2s infinite;
    border: 4px solid white;
}

/* Un pequeño efecto de pulso para llamar la atención */
@keyframes pulse-nuevo {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

.overlay-descripcion {
    padding: 0 16px 16px;
    background: #fff;
    color: #555;
    opacity: 0;
    transform: translateY(10px);
    transition: 
        opacity 0.5s ease 0.2s,
        transform 0.5s ease 0.2s,
        padding 0.4s ease;

}
/* DESKTOP */
.card-servicio:hover .overlay-descripcion {
    opacity: 1;
    transform: translateY(0);
    max-height: 400px;
    padding: 10px 16px 16px;
    border-top: 2px solid #66666686;
}

.overlay-descripcion h3 {
    /* puedes quitarlo si prefieres no repetir el título */
    display: none;
}

.overlay-descripcion p {
    font-size: 0.85rem;
    line-height: 1.6;
    margin: 0;
    color: #555;
    text-align: left;
}

    .overlay-descripcion h4 {
        color: #ffc18f;
        margin-bottom: 15px;
        border-bottom: 1px solid #334155;
        padding-bottom: 5px;
        font-size: 1rem;
    }

/* 1. Ajuste del contenedor padre */
.buscador-oculto {
  
    display: flex; 
    flex-direction: column;
    align-items: center;
    background: rgb(236, 235, 235);
    width: 100%;
    height: auto; /* Cambiado a auto para que crezca con el contenido */
    min-height: 200px; /* Altura mínima suficiente */
    padding: 60px 20px 20px 20px; /* Padding arriba para dejar espacio a la X */
    /* Muy importante: FIXED para que flote sobre todo */
    position: fixed; 

    left: 0;
    z-index: 999; /* Un número muy alto */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    /* Estado inicial */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-100%); 
    transition: all 0.4s ease-in-out; 
}

.buscador-oculto.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0); 
}

/* 2. Ajuste del botón de cerrar */
.btn-cerrar-buscador {
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 2rem; /* Aumentado para que se vea bien */
    color: #cc0808;
    cursor: pointer;
    z-index: 1000 !important;
    padding: 10px;
    background: rgba(255,255,255,0.8); /* Fondo blanco semi-transparente */
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.btn-cerrar-buscador:hover {
    color: #ff6811;
    transform: scale(1.1);
}

/* 3. Ajuste del input para que no tape nada */
#inputBuscador {
    width: 90%;
    max-width: 800px;
    padding: 15px 20px;
    border-radius: 30px;
    border: 1px solid #ccc;
    margin-top: 10px; /* Espacio extra */
}
#inputBuscador:focus{
     outline: 3px solid #ff6811;
}
.resultado-item {
    padding: 10px;
    margin-bottom: 15px;
     color:#616161;
     font-size: 1.2rem;;
    border-bottom: 2px solid #7574747a;
    cursor: pointer;
    width: 900px;
}
.resultado-item:hover {
    background: #acacac49;
    transform: scale(1.1);
    transition: all 0.3 ease-out;
     border-radius: 5px;
      color:#202020;
     font-size: 1.3rem;;
    border-bottom: 2px solid #242424f1;
}
.resultado-item:active {
    background: #ff4107ad;
    transform: scale(1.0);
    transition: all 0.3 ease-out;
     border-radius: 5px;
      color:#ffffff;
     font-size: 1.3rem;;
    border-bottom: 2px solid #fffffff1;
}
/*Modal*/
.modal {
    display: none;
    position: fixed;
    z-index: 2000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0,0,0,0.5);
}

.modal-contenido {
    background: white;
    margin: 10% auto;
    padding: 20px;
    width: 60%;
    border-radius: 10px;
}

.cerrar {
    float: right;
    font-size: 25px;
    cursor: pointer;
}
/*carousel*/
.carousel-container {
    position: relative;
    width: 100%;
    height: 60vh; /* 60% de la altura de la pantalla actual */
    min-height: 100px; /* Evita que se haga diminuto en pantallas muy pequeñas */
    overflow: hidden;

   
}

.carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: ease-in-out, transform 1.2s ease-in-out;
    transform: scale(1.05);
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-slide.active {
    opacity: 1;
    transform: scale(1);
    z-index: 1;
}

.carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    .carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: ease-in-out, transform 1.2s ease-in-out;
    transform: scale(1.05);
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-slide.active {
    opacity: 1;
    transform: scale(1);
    z-index: 1;
}

.carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
   object-position:right;
}
   
}
.codigo-tag {
    display: inline-block;
    background-color: #f0f0f0;
    color: #666;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: bold;
    margin-bottom: 5px;
    text-transform: uppercase;
    border: 1px solid #ddd;
}

.info-basica h3 {
    margin-top: 2px; /* Ajusta el espacio entre el código y el título */
}



.card-servicio:hover {
    transform: translateY(-5px);
}

.btn-ver-mas {
  
    align-items: right;
    gap: 6px;

    padding: 6px 12px;
    font-size: 13px;
    font-weight: 500;

    color: #555;
    background: transparent;
    border: 1px solid rgba(0,0,0,0.1);


    cursor: pointer;
    transition: all 0.25s ease;
}

/* Ícono */
.btn-ver-mas i {
    font-size: 12px;
    transition: transform 0.25s ease;
}

/* Hover */
.btn-ver-mas:hover {
    color:#ff6811;; /* puedes cambiar a tu paleta */
    border-color: #ff6811;

}

/* Movimiento del ícono */
.btn-ver-mas:hover i {
    transform: translateX(4px);
}


.seccion-header {
    width: 100%;
    margin-top: 40px;
    margin-bottom: 5px;
    padding: 0 5%;
}

.titulo-categoria {
    font-size: 1.8rem;
    color: var(--purpura-oscuro);
    text-transform: uppercase;
    margin-bottom: 10px;
    font-weight: 700;
}

.linea-separadora {
    border: none;
    height: 3px;
    background: linear-gradient(to right, var(--naranja-principal), transparent);
    margin-bottom: 0px;
}
.servicios-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: center;
}


/* Ajuste para el hover del enlace que pediste antes */
.link-info {
    display: inline-block;
    transition: transform 0.3s ease, color 0.3s ease;
}

.link-info:hover {
    transform: scale(1.1);
    color: #383838;
}
/* =========================================
   RESPONSIVE DESIGN - AS TECH COMPUTER
   ========================================= */
/* Para Tablets: 2 columnas */
@media (max-width: 992px) {
    .servicios-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
/* Ajuste dentro de tu Media Query de móviles (max-width: 768px o 600px) */
/* =========================================
   RESPONSIVE TARJETAS SERVICIOS
   ========================================= */

@media (max-width: 768px) {
    .carousel-container {
        height: 500px; /* Un poco más alto para que quepa el texto */
        width:100%;
     

    }
    .contenido-imagen {
        top: 45%;
    }
    .boton-servicio{
        margin-left:40%;
    }

    h1 { font-size: 1.8rem; margin-top: 10%;   text-align: right;}
    h2 { font-size: 1.4rem;   text-align: right;}
    p { 
        margin-right: 0; /* Centramos el texto del precio */
        text-align: right;
        font-size: 1.1rem;
    }
    .seccion-header {
        text-align: center;
    }

    .linea-separadora {
        background: linear-gradient(to right, transparent, var(--naranja-principal), transparent);
    }

    .servicios-grid {
        gap: 20px; /* Reducimos espacio entre tarjetas */
    }

    .imagen-url {
        width: 100%; /* La imagen se ajusta a la tarjeta */
        height: auto;
        aspect-ratio: 1 / 1;
    }

    /* En móviles, el efecto hover es difícil, 
       hacemos que la descripción sea un poco más visible */
    .card-servicio:active {
        transform: scale(0.98);
    }
    .servicios-grid{
        display:grid;
        grid-template-columns: repeat(2, 1fr);
        gap:12px;
        padding:10px;
    }

    .card-servicio{
        width:100%;
        max-width:none;
        height:auto;
        min-height:auto;
        max-height:600px;
        overflow:hidden;

        transition: all 0.4s ease;
    }

    .imagen-url{
        width:100%;
        height:250px;
        object-fit:cover;
    }

    .info-basica{
        padding:10px;
    }

    .info-basica h3{
        font-size:0.9rem;
        line-height:1.2;
        margin-bottom:4px;
    }

    .info-basica .precio{
        font-size:0.85rem;
    }

    .codigo-tag{
        font-size:0.65rem;
    }

    /* =========================================
       OVERLAY RESPONSIVO
       ========================================= */

    .overlay-descripcion{

        opacity:0;

        max-height:0;

        overflow:hidden;

        padding:0 10px;

        transform:translateY(-10px);

        transition:
            opacity 0.4s ease,
            max-height 0.5s ease,
            transform 0.4s ease,
            padding 0.4s ease;

        background:#fff;

    }

    /* AL TOCAR O HOVER */
    .card-servicio:hover .overlay-descripcion,
    .card-servicio:active .overlay-descripcion,
    .card-servicio:focus-within .overlay-descripcion{

        opacity:1;

        max-height:300px;

        padding:10px;

        transform:translateY(0);

        border-top:1px solid #ddd;
    }

    .overlay-descripcion h3{
        display:block;
        font-size:0.8rem;
        margin-bottom:5px;
        color:var(--purpura-oscuro);
    }

    .overlay-descripcion p{
        font-size:0.72rem;
        line-height:1.4;
        color:#555;
        margin:0;
    }

    .btn-ver-mas{
        width:100%;
        padding:8px;
        font-size:0.75rem;
    }
}


/* =========================================
   MOVILES MUY PEQUEÑOS
   ========================================= */

@media (max-width: 480px){

    .servicios-grid{
        grid-template-columns:1fr;
    }

    .imagen-url{
        height:180px;
    }

    .overlay-descripcion p{
        font-size:0.75rem;
    }
}
@media (max-width: 654px) {
      .carousel-container{
        width:100%;
        height:100px;
    }
    .carousel-container img{
        width:100%;
        heigh:100%;
    }
 .servicios-grid {
        display: grid;
        /* Esto fuerza exactamente 2 columnas de igual tamaño */
        grid-template-columns: repeat(2, 1fr); 
        gap: 10px; /* Espacio reducido entre tarjetas */
        padding: 10px;
    }

    .card-servicio {
        width: 100%; /* Que ocupe el ancho de su columna */
        max-width: none;
        min-height: auto;
        /* Reducimos la altura máxima para que no se vea infinita */
        max-height: 350px; 
    }
}

/* --- AJUSTE PARA DISPOSITIVOS MÓVILES (2 por fila) --- */
@media (max-width: 600px) {
    .carousel-container{
        width:100%;
        height:80px;
    }
    .servicios-grid {
        display: grid;
        /* Esto fuerza exactamente 2 columnas de igual tamaño */
        grid-template-columns: repeat(2, 1fr); 
        gap: 10px; /* Espacio reducido entre tarjetas */
        padding: 10px;
    }

    .card-servicio {
        width: 100%; /* Que ocupe el ancho de su columna */
        max-width: none;
 
     
    }
    .imagen-url {
        height: 130px; /* Imagen más pequeña para dejar espacio al texto */
        width: 100%;
        object-fit: cover;
    }
.contenido-imagen h1, 
.contenido-imagen h2, 
.contenido-imagen p, 
.contenido-imagen a, 
.contenido-imagen button {
    pointer-events: auto; /* ...pero reactiva los clics en los elementos internos */
}
    /* Ajuste de textos para que no se encimen */
    .info-basica {
        padding: 8px;
    }

    .info-basica h3 {
        font-size: 0.85rem; /* Título más pequeño */
        margin-bottom: 4px;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .info-basica .precio {
        font-size: 0.9rem;
        font-weight: 700;
    }

    .codigo-tag {
        font-size: 0.6rem;
        padding: 2px 4px;
    }

    /* Ocultamos o reducimos elementos que estorban en móvil */
    .btn-ver-mas {
        display: none; /* En móvil el usuario ya sabe que debe tocar la card */
    }

    .badge-nuevo {
        font-size: 0.6rem;
        padding: 3px 6px;
        top: 5px;
        left: 5px;
        border: 2px solid white;
    }

    /* Ajuste del Overlay para que sea legible al tocar */
    .overlay-descripcion {
        padding: 10px;
    }
    
    .overlay-descripcion p {
        font-size: 0.7rem;
        line-height: 1.2;
    }
}
/* Tablets y Laptops pequeñas (Menos de 1024px) */
@media (max-width: 1024px) {
    .contenido-imagen {
        left: 50%; /* Centramos el contenido del carrusel */
        width: 90%;
    }

    h1 { font-size: 2.2rem; }
    h2 { font-size: 1.8rem; }
    
    .resultado-item {
        width: 90%; /* El buscador se adapta */
    }
     .servicios-grid {
        display: grid;
        /* Esto fuerza exactamente 2 columnas de igual tamaño */
        grid-template-columns: repeat(2, 1fr); 
        gap: 10px; /* Espacio reducido entre tarjetas */
        padding: 10px;
    }

    .card-servicio {
        width: 100%; /* Que ocupe el ancho de su columna */
        max-width: none;
        min-height: 100px;
        /* Reducimos la altura máxima para que no se vea infinita */
        max-height: 350px; 
    }
}

/* Móviles Pequeños (Menos de 480px) */
@media (max-width: 480px) {
    .carousel-container {
        height: 400px;
    }

    h1 { font-size: 1.5rem; }
    h2 { font-size: 1.1rem; }

    .boton-servicio {
        width: 130px;
        font-size: 0.9rem;
    }

    .link-info {
        display: block;
        margin-left: 0;
        margin-top: 15px;
    }

    .contenedor-servicios {
        padding: 20px 10px;
    }

    #inputBuscador {
        width: 90%;
    }
}

