/* 1. CONFIGURACIÓN GENERAL */
* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

.header-texto h1 {
    display: inline-block;
    animation: derrape 1.2s cubic-bezier(.25,.8,.25,1) forwards;
    }

    @keyframes derrape {
        0% {
            transform: translateX(-600px) skewX(-15deg);
            opacity: 0;
        }

        60% {
            transform: translateX(30px) skewX(10deg);
            opacity: 1;
        }

        80% {
            transform: translateX(-10px) skewX(-5deg);
        }

        100% {
            transform: translateX(0) skewX(0);
        }
    }

.header-texto p {
  position: relative;
  opacity: 0;
  animation: saltar-derecha 2s ease-in-out 1.5s forwards,
             animacion-3d 2s ease-in-out 3.6s forwards; /* empieza después de la primera */
}

@keyframes saltar-derecha {
  0%   { transform: translateX(0) translateY(0) rotateZ(0deg); opacity: 0; }
  20%  { transform: translateX(50px) translateY(-12px) rotateZ(-3deg); opacity: 1; }
  40%  { transform: translateX(70px) translateY(6px) rotateZ(4deg); }
  60%  { transform: translateX(50px) translateY(-8px) rotateZ(-2deg); }
  80%  { transform: translateX(25px) translateY(3px) rotateZ(1deg); }
  100% { transform: translateX(0) translateY(0) rotateZ(0deg); opacity: 1; }
}

@keyframes animacion-3d {
  0%   { transform: translateZ(0) rotateY(0deg) scale(1); }
  25%  { transform: translateZ(20px) rotateY(15deg) scale(1.05); }
  50%  { transform: translateZ(30px) rotateY(20deg) scale(1.1); }
  75%  { transform: translateZ(20px) rotateY(15deg) scale(1.05); }
  100% { transform: translateZ(0) rotateY(0deg) scale(1); }
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    margin: 0;
    padding: 0;
    line-height: 1.6;
    background-color: #f4f4f4;
    color: #333;
}

/* 2. CABECERA Y MENÚ CON IMAGEN */
.header-con-imagen {
    display: flex;
    align-items: center;             /* centra verticalmente el texto respecto a la imagen */
    justify-content: space-between;  /* texto a la izquierda, imagen a la derecha en escritorio */
    padding: 20px;
    background: #072968;             /* fondo azul del header */
    color: #F4F4F4;
    gap: 20px;                       /* espacio entre texto y foto */
    flex-wrap: wrap;                  /* permite que en móviles los elementos bajen */
    border-radius: 12px;
}

.header-con-imagen .header-texto {
    flex: 0 1 auto;                          /* ocupa todo el espacio disponible a la izquierda */
    text-align: center;                /* texto centrado en desktop */
}

.header-con-imagen .header-texto h1,
.header-con-imagen .header-texto p {
    margin: 0 0 10px 0;               /* elimina márgenes extras */
}

/* Imagen del taller */
.header-con-imagen .imagen-header {
    flex-shrink: 0;  /* evita que la imagen se comprima raro */
}

.header-con-imagen .imagen-header img {
    width: 600px;        /* tamaño base real en escritorio */
    max-width: 40%;      /* nunca más del 40% del header */
    height: auto;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

/* MENÚ DE NAVEGACIÓN */
nav ul {
    padding: 0 0 10px 0;
                    /* espacio arriba y abajo del menú */
    list-style: none;                 /* elimina bullets */
    background: #FFB300;                 /* fondo oscuro del menú */
    text-align: center;               /* centra los links */
    margin: 10px auto 0 auto;        /* margen superior e inferior */
    border-radius: 12px;
}

nav li {
    display: inline-block;
    margin: 0 20px;
    padding: 10px 0;
}

nav a {
    color: #fff;                      /* letras blancas */
    text-decoration: none;
    font-weight: bold;                /* negrita */
    position: relative;
    transition: all 0.3s ease;
}

/* Línea animada moderna */
nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 0;
    height: 2px;
    background: #131bac;             /* acento naranja dorado */
    transition: width 0.3s ease;
}

nav a:hover,
nav a:focus {
    color: #131bac;
}

nav a:hover::after,
nav a:focus::after {
    width: 100%;
}

/* AJUSTES MÓVIL */
@media (max-width: 600px) {
    .header-con-imagen {
        flex-direction: column;       /* apila texto e imagen verticalmente */
        align-items: center;           /* centra todo en móvil */
        text-align: center;
    }

    .header-con-imagen .imagen-header img {
        width: 60%;                    /* reduce tamaño en móvil */
        max-width: 250px;
        margin-top: 15px;              /* separación del texto */
    }
}

/* 3. CONTENEDOR PRINCIPAL */
main {
    padding: 30px;
    max-width: 1000px;
    margin: 40px auto;
    background: #F8F9FA;
    color: #333;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    border-radius: 12px;
}

/* 4. TÍTULOS Y SECCIONES */
h2 {
    color: #333;
    border-left: 5px solid #ff9900;
    padding-left: 15px;
    margin-top: 40px;
}

/* 5. BARRA DE CONFIANZA / POR QUÉ ELEGIRNOS */
#confianza .contenedor-servicios {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 20px;
    list-style: none; /* evita bullets por herencia */
}

#confianza .servicio-card {
    flex: 1 1 300px;   /* ancho mínimo 300px */
    padding: 20px;
    background: #f9f9f9;  /* opcional: gris suave */
    border: 1px solid #ddd;
    border-radius: 10px;
    line-height: 1.5;
    transition: all 0.3s ease;
}

/* Hover para confianza */
#confianza .servicio-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}

/* 6. TARJETAS DE SERVICIOS */
.contenedor-servicios {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 20px;
}

.servicio-card {
    flex: 1 1 300px;
    padding: 20px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    transition: all 0.3s ease;
    line-height: 1.5;
}

.servicio-card:hover {
    border-color: #ff9900;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    transform: translateY(-5px);
}

/* 7. SECCIÓN CONTACTO */
.info-taller {
    margin-top: 20px;
}

.mapa-pequeno {
    width: 320px;
    max-width: 100%;
    margin: 15px 0;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 5px 15px rgba(0,0,0,0.08);
}

.mapa-pequeno iframe {
    display: block;
}

/* Horario separado */
.horario-seccion {
    margin-top: 30px;
}

/* 7.5 BOTONES DE CONTACTO RÁPIDO */
.contenedor-contacto {
    display: flex;
    gap: 30px;
    margin-top: 30px;
    align-items: stretch; 
}


.tarjeta-contacto,
.info-extra {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 15px;
}


.mapa-wrapper {
    flex: 1;                 /* ocupa la otra mitad */
}

@media (max-width: 768px) {

    .contenedor-contacto {
        flex-direction: column;   /* se ponen uno debajo del otro */
    }

    .tarjeta-contacto,
    .info-extra {
        width: 100%;              /* ocupan todo el ancho */
    }

}



/* Estilo de los botones */
.btn-contacto {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: bold;
    color: white;
    transition: all 0.3s ease;
    font-size: 1.1rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.btn-contacto span {
    margin-right: 12px;
    font-size: 1.4rem;
}

.btn-contacto:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.15);
    filter: brightness(1.1); /* Brillo al pasar el ratón */
}

/* Colores personalizados para el taller */
.btn-llamada { background-color: #1B263B; } /* El azul oscuro de tu header */
.btn-whatsapp { background-color: #25d366; } /* Verde WhatsApp */
.btn-email { background-color: #FFB300; color: #1B263B; } /* El naranja de tu menú */
.btn-google {background-color: #4285F4;   /* azul Google */}
.btn-mapa { background-color: #ff4e4e; }     /* Azul Google */

/* Contenedor del mapa para que crezca */
.info-extra {
    flex: 1 1 300px;
}

.mapa-wrapper {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    border: 1px solid #ddd;
}

/* 8. FOOTER */
footer {
    text-align: center;
    padding: 25px;
    font-size: 0.9rem;
    color: #666;
}

/* 9. AJUSTES PARA MÓVIL */
@media (max-width: 600px) {

    /* MENÚ */
    nav li {
        display: block;
        margin: 10px 0;
        border-bottom: 2px solid #fff;
    }

    nav ul {
        text-align: left;   /* alinea los links a la izquierda */
        padding-left: 15px; /* un poco de espacio desde el borde */
    }

    /* BARRA DE CONFIANZA */
    .confianza {
        flex-direction: column;
        align-items: center;
    }

    /* TARJETAS DE SERVICIOS */
    .servicio-card {
        flex: 1 1 100%;
    }

    /* INFO TALLER */
    /* .info-taller ya no necesita flex-direction, pero si quisieras mantener la consistencia: */
    /* .info-taller { flex-direction: column; } */

    /* CABECERA */
    header h1 {
        font-size: 1.5rem;
    }

    /* CONTENEDOR PRINCIPAL */
    main {
        margin: 15px;
        padding: 20px;
    }
}
