
@font-face {
 font-family: 'generis';
  src:  url("../fonts/generis.woff2") format('woff2');
}

@font-face {
 font-family: 'sequel';
  src:  url("../fonts/sequel.woff2") format('woff2');
}


:root {
	   --color-yellow: #FFDE00; /* Tono de amarillo principal */
	--color-black: #2a2a2f;
    --color-dark-gray: #1a1a1a;
    --color-light-gray: #f4f4f4;
    --color-white: #FFFFFF;
    --font-main: 'Poppins', sans-serif;
		--col-data:  ;
		--col-light:;
		--col-dark: ;
		--font-family: 'sequel', sans-serif;
		--font-family2: 'generis', sans-serif;
		--font-xsss: clamp(0.08rem, calc(0.5rem + 0.1vw), 0.8rem);
		--font-xssb: clamp(0.1rem, calc(0.8rem + 0.1vw), 1.4rem);
		--font-xssa: clamp(0.1rem, calc(0.9rem + 0.1vw), 1.4rem);
		--font-xss: clamp(0.1rem, calc(1rem + 0.1vw), 1.4rem);
		--font-xs: clamp(0.2rem, calc(1.1rem + 0.2vw), 1.7rem);
		--font-sm: clamp(1.42rem, calc(1.24rem + 0.9vw), 1.88rem);
		--font-md: clamp(1.89rem, calc(1.53rem + 1.8vw), 2.81rem);
		--font-lg: clamp(2.52rem, calc(1.85rem + 3.32vw), 4.22rem);
  		--font-xl: clamp(3.35rem, calc(2.19rem + 2.8vw), 6.33rem);  
  		--font-xxl: clamp(5.15rem, calc(4.19rem + 4.8vw), 10.33rem);  
		--padding-xl: clamp(3.35rem, calc(2.19rem + 111.8vw), 6.33rem); 
		--padding-xll: clamp(4.35rem, calc(2.99rem + 141.8vw), 8.33rem); 
		
}
.carousel-control-prev, .carousel-control-next {    display: none !important}


.footerhr {  padding: 10px; display: inline-grid;  vertical-align: middle;  border-top: 6px solid;  color: var(--color-yellow); opacity: .6;}
.selected { color: var(--color-yellow) !important }
.cel {display: none}

#video-compce {box-sizing: border-box; height: 56.25vw; left: 50%; min-height: 100%; min-width: 104%; transform: translate(-50%, -50%);
	position: absolute;  top: 50%;  width: 177.77777778vh; z-index: 1;}

.sequel{font-family: var(--font-family) !important}
.generis{font-family: var(--font-family2) !important}

.font-xsss{font-size: var(--font-xsss)}
.font-xss{font-size: var(--font-xss)}
.font-xs{font-size: var(--font-xs)}
.font-sm{font-size: var(--font-sm)}
.font-md{font-size: var(--font-md)}
.font-lg{font-size: var(--font-lg)}
.font-xl{font-size: var(--font-xl)}
.font-xxl{font-size: var(--font-xxl)}


.motores {    position: absolute;    top: 25%;    left: 5%; z-index: 1}
.w-300 { width: 300px}
.text-black { color: var(--color-black) !important}
.blackbg { background-color: var(--color-black)}
.yellowbg { background-color: var(--color-yellow) !important}

.blackbgafter::after { content: ''; background-color: var(--color-black)}
.yellowbgafter::after { content: ''; background-color: var(--color-yellow)}

.mision-vision * .active { color: var(--color-yellow) !important }


body {
    margin: 0;
    font-family: var(--font-main);
    background-color: var(--color-black);
    color: var(--color-white);
    overflow-x: hidden; /* Evita scroll horizontal */
}

#datos * a { text-decoration: none !important; color: inherit !important;}

.mg0{
	margin: 0
}

.w-70{
	width: 70%;
}
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ======== HEADER ======== */
.main-header {
    background-color: var(--color-black);
    padding: 15px 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
}

.main-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo img {
    height: 60px;     z-index: 99999;    position: relative;
}

.main-nav a {
   color: var(--color-white);
    text-decoration: none;
    margin-left: 90px;
    font-weight: bold;
    transition: color 0.3s ease;
    font-family: var(--font-family2);
    font-size: var(--font-xsss);
    text-transform: uppercase;
	letter-spacing: 2px;
}

.main-nav a:hover {
    color: var(--color-yellow);
}

/* ======== HERO SECTION ======== */
.hero-section {
    height: 100vh;
    background-image: url('https://via.placeholder.com/1920x1080/000000/333333?text=IMAGEN+DE+FONDO+MOTOR');
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    position: relative;
}

.hero-content {
    position: relative;
}

.hero-content .vertical-lines {
    position: absolute;
    left: -20px;
    top: 10px;
    bottom: 10px;
    width: 5px;
    background-color: var(--color-yellow);
}
.hero-content .vertical-lines::after {
    content: '';
    position: absolute;
    left: -15px;
    top: 0;
    bottom: 0;
    width: 5px;
    background-color: var(--color-yellow);
}

.hero-content h1 {
    margin: 0 0 25px 0;
    line-height: 0.5;
}

.hero-content h1 span {
    color: var(--color-yellow);
}

.whatsapp-float {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 999;
    border-radius: 50%;
    overflow: hidden;
}

/* CONTACTO */


  .contact-card {
    border-radius: 1rem;
    transition: transform .25s ease, box-shadow .25s ease;
    background: #fff; transition: all 0.3s ease !important;
    transform: translateY(0px) ;
  }
  .contact-card:hover { transform: translateY(-4px);  }

  .icon-wrap{
    width: 96px;
    height: 96px;
    margin: 0 auto;
    display: grid;
    place-items: center;
    border-radius: 50%;
    /* background: #fff; */
    border: 2px solid #ffc30f8f;
    /* box-shadow: 0 8px 20px rgba(0, 0, 0, .06);*/
  }

  .icon{
    font-size:44px;
    color:var(--color-yellow); /* icono amarillo */
    line-height:1;
  }

  /* Animaciones */
  @keyframes ring { /* teléfono: pequeña vibración */
    0%,100%{ transform:rotate(0deg); }
    10%{ transform:rotate(12deg); }
    20%{ transform:rotate(-10deg); }
    30%{ transform:rotate(8deg); }
    40%{ transform:rotate(-6deg); }
    50%{ transform:rotate(4deg); }
  }
  @keyframes float { /* email: flotando suave */
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(-6px); }
  }
  @keyframes bob { /* pin: rebote leve */
    0%,100%{ transform:translateY(0) scale(1); }
    50%{ transform:translateY(-4px) scale(1.02); }
  }

  .icon-phone{ animation: ring 1.4s ease-in-out infinite; transform-origin: 60% 10%; }
  .icon-mail{ animation: float 2.2s ease-in-out infinite; }
  .icon-pin { animation: bob 1.8s ease-in-out infinite; }

  /* Respeto a usuarios con reducción de movimiento */
  @media (prefers-reduced-motion: reduce){
    .icon-phone,.icon-mail,.icon-pin{ animation: none; }
    .contact-card{ transition: none; }
  }

/* ======== BOTONES ======== */
.btn {
    display: inline-block;
    padding: 12px 30px;
    text-decoration: none;
    font-weight: bold;
    border-radius: 5px;
    transition: transform 0.3s ease, background-color 0.3s ease;
}

.btn-primary {
    background-color: var(--color-yellow);
    color: var(--color-black);
}

.btn-dark {
    background-color: var(--color-black);
    color: var(--color-yellow);
    border: 2px solid var(--color-yellow);
}

.btn:hover {
    transform: translateY(-3px);
}


/* MARQUESINA */

.marquee-container {
  background-color: #1d1d1d;
  border-top: 8px solid var(--color-yellow);
  border-bottom: 8px solid var(--color-yellow);
  overflow: hidden;
  width: 100%;
}

.marquee-content {
  display: flex;
  width: max-content;
  animation: scrollLoop 20s linear infinite;
}

.marquee-content span {
  white-space: nowrap;
  font-size: 2rem;
  font-weight: 900;
  font-family: 'Arial Black', sans-serif;
  color: transparent;
  -webkit-text-stroke: 1px yellow;
  padding-right: 4rem;
}

/* Animación que se repite infinitamente */
@keyframes scrollLoop {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-10%);
  }
}
.marquee-container:hover .marquee {
  animation-play-state: paused;
}

/* ======== FIN MARQUESINA ======== */

/* ======== CIRCLE TEXT ======== */
 .container-svg {
           width: 250px; height: auto;  margin-top: 50px;
        }

        /* 2. Estilos que movimos desde tu SVG original */
        .st0 {
            stroke: #fff;
            stroke-width: 2.2px;
        }

        .st0, .st1, .st2 {
            fill: none;
            stroke-miterlimit: 10;
        }

        .st1 {
            stroke-width: .74px;
        }

        .st1, .st2 {
            stroke: #fe0; /* Amarillo */
        }

        .st2 {
            stroke-width: .62px;
        }

        /* 3. La animación de rotación */
        @keyframes rotar-texto {
            from {
                transform: rotate(0deg);
            }
            to {
                transform: rotate(360deg);
            }
        }

        /* 4. Aplicar la animación SOLO al grupo de texto */
        #texto {
            /* El secreto para que gire desde el centro del SVG (149px 151px) */
            transform-origin: center; 
            
            /* Aplicamos la animación infinita y suave */
            animation: rotar-texto 30s linear infinite;
        }
/* ======== FIN CIRCLE TEXT ======== */


/* --- ESTILOS PARA ESCRITORIO (> 768px) --- */
.imgformulario {position: absolute;    width: 300px;    z-index: 0;    bottom: 0px;    right: 0px;}
.textoformulario { width: 85%; text-align: left;}

input, textarea { border: none !important}


.flipper-scene {
    width: 100%;
    height: 600px;
    perspective: 1500px;
}

.card-flipper {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.8s;
    transform-style: preserve-3d;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.card-flipper.is-flipped {
    transform: rotateY(180deg);
}

.card-face {
    position: absolute;
    width: 100%;
    height: 100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    display: flex;
}

.card-face--back {
    transform: rotateY(180deg);
}

.flipper-columna {
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    overflow-y: auto;
}

.card-face--front .col-md-6.col-left { background-color: #ffffff; color: #333; }
.card-face--front .col-md-6.col-right { background-color: var(--color-black); color: #ffffff; }

.card-face--back .col-md-6.col-left { background-color: var(--color-black); color: #ffffff; position: relative}
.card-face--back .col-md-6.col-right { background-color: #ffffff; color: #333; position: relative }

/* Estilos de elementos */
.card-flipper h2 {  margin-bottom: 20px; z-index: 1; font-family: var(--font-family); text-align: left; font-size: var(--font-md); letter-spacing: 1px}
.card-flipper p { font-size: var(--font-xss);    line-height: 1.6;    z-index: 2;    font-family: var(--font-family2);    width: 300px;    text-align: left; position: relative}
.card-flipper img { max-width: 100%; height: auto; margin-bottom: 20px; }
.card-flipper .form-group { width: 100%; margin-bottom: 15px; text-align: left; }
.card-flipper .form-group input, .card-flipper .form-group textarea { width: 100%; padding: 12px;  background-color: #f0f0f0; border-radius: 5px; font-family: 'Montserrat', sans-serif; }
.card-flipper .btn { display: inline-block; padding: 12px 24px;  background-color: #ffeb3b; color: #333; font-weight: 700; text-transform: uppercase; cursor: pointer; border-radius: 5px; text-decoration: none; margin-top: 10px; }
.card-flipper .btn-secundario { background-color: transparent; border: 2px solid #ffeb3b; color: #ffeb3b; }

.btn-group {
    display: flex;
    gap: 10px;
}

/* --- LÓGICA RESPONSIVE PARA MÓVILES (<= 768px) --- */
@media (min-width: 768px)  {
	.responsiveoff { display: none !important}
}
	
	
@media (max-width: 768px) {
    /* 1. Aplanamos el efecto 3D */
	.responsiveoff {display: block}
    .flipper-scene {
        height: auto;
        perspective: none;
    }
    .card-flipper {
        transform-style: flat;
        transform: none !important;
        position: static;
        height: auto;
        box-shadow: 0 5px 15px rgba(0,0,0,0.2);
    }
    .card-face {
        position: static;
        backface-visibility: visible;
        display: block;
    }

    /* ===== LA LÍNEA CLAVE DE LA CORRECCIÓN ===== */
    /* Reseteamos la rotación de la cara trasera en móvil, 
       porque ya no hay un giro 3D que la compense. */
    .card-face--back {
        transform: none;
    }
    
    /* 2. Mostramos SOLO la cara que corresponde según la clase */
    .card-flipper.is-flipped .card-face--front { display: none; }
    .card-flipper.is-flipped .card-face--back { display: block; }
    
    .card-flipper:not(.is-flipped) .card-face--front { display: block; }
    .card-flipper:not(.is-flipped) .card-face--back { display: none; }
    
    /* 3. Ocultamos las columnas que no queremos ver en móvil */
    .card-face--front .col-md-6.col-right,
    .card-face--back .col-md-6.col-left {
        display: none;
    }

    /* 4. La columna visible ocupa todo el ancho */
    .flipper-columna {
        width: 100%;
        padding: 30px 20px;
    }
}

/* ======== TÍTULOS DE SECCIÓN ======== */
.section-title {
    font-family: var(--font-family);
    font-size: var(--font-md);
    color: var(--color-black);
    line-height: 1.1;
    margin-top: 0;
    margin-bottom: 20px;
    position: relative;
    padding-bottom: 10px;
}

.section-title::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -15px;
    width: 80px;
    height: 20px;
    
}

.section-p {    font-family: var(--font-family2);    font-size: var(--font-xss);    color: var(--color-black);}


/* ======== ABOUT SECTION ======== */
.about-section {
    background-color: var(--color-yellow);
    color: var(--color-black);
    padding: 100px 0;
}

.about-container {
    display: flex;
    align-items: center;
    gap: 50px;
}

.about-image {
    flex: 1;
    position: relative;
}

.about-image img {
    width: 100%;
    max-width: 400px;
    /*border-radius: 50%;*/
	place-content: center;
    display: block;
    justify-self: center;
}

.check-icon {
       position: absolute;
    bottom: -6%;
    left: 21%;
    transform: translateY(-50%);
    background-color: var(--color-black);
    color: var(--color-yellow);
    width: 70px;
    height: 70px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: bold;
}

.about-text {    flex: 1}




/* ======== ABOUT página ======== */

.about-pagina { background-color: var(--color-yellow); color: var(--color-white); padding: 120px 0;}

.about-paginacontainer { display: flex; align-items: center; gap: 50px;}

.about-paginaimage { flex: 1; position: relative;}

.about-paginaimage img { width: 100%; max-width: 400px; place-content: center; display: block; justify-self: center;}

.check-icon { position: absolute; bottom: -6%; left: 21%; transform: translateY(-50%);
    background-color: var(--color-black); color: var(--color-yellow); width: 70px;
    height: 70px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2rem;
    font-weight: bold;}

.about-paginatext { flex: 1;}

label {    display: inline-block;    font-family: var(--font-family2); font-size: 14px }





/* ======== PRODUCTS SECTION ======== */
.products-section {
    /* Usamos tu imagen como fondo de toda la sección */
    background-image: url('../imagenes/fondo-productos.jpg');
    background-size: cover; /* Hacemos que la imagen cubra todo el espacio */
    background-position: center; /* Centramos la imagen */
    padding: 100px 0;
    position: relative;
    overflow: hidden;
}

.products-container {
    display: flex; /* Usamos flexbox para crear las dos columnas */
    align-items: center;
    min-height: 400px;
	justify-content: center;/* Le damos una altura mínima */
}

.products-text {
    flex-basis: 50%; /* La columna de texto ocupará el 50% del espacio */
    padding-right: 40px; /* Un poco de espacio para que no se pegue al centro */
    position: relative; /* Necesario para posicionar el círculo de garantía */
    z-index: 2; /* Nos aseguramos que el texto esté por encima del círculo */
}

/* Creamos el círculo de "Garantía Confiable" con un pseudo-elemento */
.products-text::before {
    content: ''; /* Es necesario para que el pseudo-elemento se muestre */
    position: absolute;
    width: 250px;
    height: 250px;
    background-image: url('URL_A_TU_IMAGEN_DEL_SELLO_CIRCULAR.svg'); /* RECOMENDADO: Usa un SVG o PNG del sello */
    background-size: contain;
    background-repeat: no-repeat;
    left: -30px;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.15; /* Lo hacemos semitransparente como en el diseño */
    z-index: -1; /* Lo ponemos detrás del texto */
}

/* El título ya debería tener estilos, pero nos aseguramos que tenga el color correcto */
.products-text .section-title {
    color: var(--color-yellow);
}

/*.products-text p {
    font-size: 1.1rem;
    max-width: 450px; /* Limitamos el ancho del párrafo 
}*/

.products-image-spacer {
    flex-basis: 50%; /* La columna de la derecha ocupa el otro 50% */
    /* Esta columna se queda vacía para que se vea la imagen del repuesto en el fondo */
}

/* ======== CONTACT SECTION ======== */
.contact-section {
    background-color: var(--color-dark-gray);
    /* Podrías agregar una textura con background-image si tienes una */
    padding: 80px 0;
}

.contact-container {
    display: flex;
    align-items: center;
    gap: 50px;
}

.contact-form-wrapper {
    flex: 1;
    background-color: var(--color-white);
    color: var(--color-black);
    padding: 40px;
    border-radius: 10px;
}

.contact-form-wrapper h3 {
    margin-top: 0;
    font-size: 1.8rem;
}

.contact-form-wrapper input,
.contact-form-wrapper textarea {
    width: 100%;
    padding: 12px;
    margin-bottom: 15px;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-sizing: border-box; /* Importante para el padding */
}

.contact-form-wrapper textarea {
    height: 120px;
    resize: vertical;
}

.contact-form-wrapper .btn {
    width: 100%;
    text-align: center;
}

.guarantee-wrapper {
    flex: 1;
    text-align: center;
}

.guarantee-wrapper img {
    max-width: 250px;
}

/* ======== BRANDS & FOOTER ======== */
.brands-section {
    background-color: var(--color-white);
    padding: 40px 0;
}

.brands-container {
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
}

.main-footer {
    background-color: var(--color-black);
    color: #888;
    padding: 20px 0;
    font-size: 0.9rem;
}

.footer-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}


.espaciomediano{
	padding: 50px
}

.relative{position: relative}

/* ======== AJUSTES Y NUEVOS ESTILOS PARA EL HERO SLIDER ======== */

/* La sección principal del slider ahora ocupa toda la altura de la pantalla */
.hero-section.carousel {
    height: 100vh;
    width: 100%;
    overflow: hidden; background-color: var(--color-black);
}

/* Cada slide individual también ocupará toda la altura */
.carousel-item {
    height: 100vh;
    width: 100%;
    position: relative;
}

/* Estilo para el video de fondo de cada slide */
.video-background {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: 0; /* Lo pone detrás del contenido */
    background-color: var(--color-black); /* Color de fondo mientras carga el video */
}

/* Aseguramos que el contenido del slide se mantenga centrado y visible */
.hero-content {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    height: 100%;
    padding-top: 80px;
    flex-direction: column; margin-top: 150px;
}

/* Estilos personalizados para las flechas de control */
.carousel-control-prev,
.carousel-control-next {
    width: 10%; /* Aumenta el área de click */
    opacity: 1; /* Hacemos que siempre sean visibles */
}

.carousel-control-icon {
    background-image: none !important; /* Eliminamos el ícono por defecto de Bootstrap */
    width: 48px;
    height: 48px;
    color: white;
    transition: transform 0.3s ease;
}

/* Efecto hover para las flechas */
.carousel-control-prev:hover .carousel-control-icon,
.carousel-control-next:hover .carousel-control-icon {
    transform: scale(1.2);
}

.textohome { font-family: var(--font-family2); font-size: var(--font-xs); color: var(--color-white)   }
.textohomeh1 { font-family: var(--font-family); font-size: var(--font-xxl); color: var(--color-yellow)   }

.textohomeboton { font-family: var(--font-family2) !important; font-size: var(--font-xssb) !important; color: var(--color-black) !important;
  background-color: var(--color-yellow) !important; margin-top: 25px; position: relative; letter-spacing: 1px; padding: 10px 20px !important;
  transition: all 0.3s ease !important; transform: translateY(0px) !important; font-weight: 900;} 

.textohomeboton:hover {  font-weight: 900; transform: translateY(-3px) !important}

.botones { font-family: var(--font-family2) !important; font-size: var(--font-xssb) !important;  margin-top: 25px; position: relative; letter-spacing: 1px; padding: 10px 20px !important;  transition: all 0.3s ease !important; transform: translateY(0px) !important; font-weight: 900;} 

.botones:hover {  font-weight: 900; transform: translateY(-3px) !important}


.botones1:hover { background-color: transparent !important; font-weight: 900; transform: translateY(-3px) !important; border-color: var(--color-yellow) !important;}


.seccion-garantia{height: 100%; display: flex; justify-content: center; flex-direction: column;     align-items: center;}

.seccion-formulario-index{
	background-image: url("../imagenes/fondo1.jpg");
	background-repeat: no-repeat;
    background-size: cover; position: relative;
}

.franja-amarilla{width: 100%; height: 30px; background-color: #FFEE00;}

.fondo-productos{  position: absolute; z-index: -1; top: -330px; width: 100%; }


.producto1{
	width: 500px;
    position: absolute;
    top: 0;
    right: -2px;
}
.producto2{
    position: absolute;
    top: -380px !important;
    z-index: 1;
    width: 280px !important;
    left: 60px !important;
}
.producto3{
    position: absolute;
    width: 250px !important;
    right: 0px !important;
    top: -127px !important;
}
.producto4{
    width: 200px !important;
    position: absolute;
    top: 650px !important;
}


.productosparallax {    background-color: var(--color-black);    padding: 200px 0;}
.productosparallax { background-image:url("../imagenes/fondo-productos.jpg");  height: 100vh;
    background-size: cover;  background-attachment: scroll;  background-repeat: no-repeat;  background-position: center 80%}
.parallax-section {  position: relative;  height: 100vh;  overflow: hidden;}
.parallax {  position: absolute;  width: 100%;  height: auto;  object-fit: cover;  top: 0;  left: 0;}

.fixmotor {padding: 0px;  position: relative;     padding-left: 0 !important;     padding-right: 0 !important;}


	 /* Hamburguesa */
.hamburger {
  display: flex;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
  z-index: 10000;
}
.hamburger span {
  width: 25px;
  height: 3px;
  background: white;
  border-radius: 2px;
  transition: 0.3s;
}
.hamburger:hover span:nth-child(2) {
  transform: translateX(5px);
}

/* Estado activo: se transforma en una X */
.hamburger.active span:nth-child(1) {  transform: rotate(42deg) translate(5px, 5px);}
.hamburger.active span:nth-child(2) {  opacity: 0;}
.hamburger.active span:nth-child(3) {      transform: rotate(318deg) translate(6px, -5px);}

/* Overlay móvil */
.mobile-overlay {
  position: fixed;
  top: 0;
  left: 0;
  background-color: var(--color-black);
  width: 100%;
  height: 100%;
  z-index: 9998;
  padding-top: 80px;
  display: none;
  flex-direction: column;
  align-items: center;
  animation: fadeIn 0.4s ease forwards;
}
@keyframes fadeIn {
  from {opacity: 0; transform: translateY(-20px);}
  to {opacity: 1; transform: translateY(0);}
}

.mobile-overlay.show {
  display: flex;
}

.mobile-menu {list-style: none; padding: 0;  color: white; font-size: 1.5rem; text-align: center; display: flex; flex-direction: column;
    justify-content: center;  align-items: center;  height: 100%; font-family: 'generis';}

	  .mobile-menu li {
  margin-bottom: 15px;
}
.mobile-menu a, .mobile-menu span {
  color: white;
  text-decoration: none;
}
.mobile-menu a:hover, .mobile-menu span:hover {
  color: var(--color-yellow);
  text-decoration: none;
}
.submenu {
  font-size: 1rem;
  margin-top: 10px;
}
.submenu li {
  margin-bottom: 5px;
}

/* Ocultar hamburguesa en escritorio */
@media(min-width: 992px) {
  .hamburger {
    display: none;
  }
}


/* ======== RESPONSIVE DESIGN (Básico) ======== */
@media (max-width: 768px) {
	
	.fixmotor {  top: 150px; }   
    .main-header .container, .footer-container {
        flex-direction: column;
        gap: 15px;
    }

    .about-container, .products-container, .contact-container {
        flex-direction: column;
    }

    .hero-content {
        padding-left: 20px; /* Para compensar las líneas */
    }

    .products-container {
        flex-direction: column-reverse; /* Cambia el orden en móvil */
    }
	
	}


.brands-section img {width: 120px}
footer * i { font-size: 18px}


/* footer */
.activewhatsapp { bottom: 70px !important}

#back-top.active {
    opacity: 1;
    transition: all 0.6s ease;
    -webkit-transition: all 0.6s ease;
    -ms-transform: translateY(-20px);
    -webkit-transform: translateY(-20px);
    transform: translateY(-20px);
}
.fa-angle-up:before {    content: "\f106";}

#back-top { bottom: 0; opacity: 0; z-index: 9; right: 20px; width: 50px; height: 50px; padding: 9px 0 0; cursor: pointer; font-size: 25px; position: fixed;	line-height: 27px;   text-align: center;  border-radius: 50%;  background: #a0d8ff;  -webkit-transition: all 0.6s ease;  transition: all 0.6s ease; -webkit-transform: translateY(40px);    transform: translateY(40px);  -ms-transform: translateY(40px);  -webkit-transition: all 0.6s ease;
-webkit-transform: translateY(40px);}	
	
#back-top{    color: #002b51}	

/* --- Contenedor Principal del Footer --- */
        .site-footer {
            color: #ffffff; font-family: var(--font-family2)
        }

        /* --- Sección Superior (Oscura) --- */
        .footer-top {
            background-color: #2a2a2a;
    		padding-bottom: 50px;
    		padding-top: 70px;
        }

        .footer-container {
            max-width: 1200px;
    		margin: 0 auto;
    		display: flex;
    		justify-content: space-between;
    		flex-wrap: wrap;
    		gap: 30px;
    		flex-direction: row;
    		align-items: flex-start;
        }

        /* --- Columnas del Footer --- */
        .footer-column {
            flex: 1; /* Permite que las columnas crezcan y ocupen el espacio */
            min-width: 220px; /* Ancho mínimo antes de que se apilen */
        }

        .footer-column.logo-col {
            /*flex-basis: 250px; *//* Un poco más de espacio para el logo */
            flex-grow: 0;
        }

        .footer-column img {
            max-width: 200px; /* Ajusta el tamaño de tu logo */
        }

        /* --- Estilos de Texto y Enlaces --- */
        .footer-column h4 {
            font-size: 1rem;
            font-weight: 700;
            margin-top: 0;
            margin-bottom: 20px;
            color: var(--color-yellow);
        }

        .footer-column p, .footer-column a {
            font-size: 0.9rem;
            color: #c7c7c7; /* Un gris claro para el texto */
            text-decoration: none;
            line-height: 1.8;
            margin: 0;
        }

        .footer-column a:hover {
            color: #ffeb3b; /* Efecto hover amarillo */
        }
        
        .footer-column .contact-item {
            display: flex;
            align-items: center;
            gap: 10px; /* Espacio entre ícono y texto */
            margin-bottom: 10px;
        }

        /* --- Íconos Sociales --- */
        .social-icons a {
            font-size: 1.5rem; /* Tamaño de los íconos */
            margin-right: 15px;
            color: #ffffff;
            transition: color 0.3s ease;
        }
        
        .social-icons a:hover {
            color: #ffeb3b;
        }
        
        .footer-column .contact-title {
            margin-top: 30px;
        }

        /* --- Sección Inferior (Amarilla) --- */
        .footer-bottom {
            background-color: #ffeb3b;
            padding: 20px;
            text-align: center;
        }

        .footer-bottom p {
            margin: 0;
            color: #333;
            font-size: 0.9rem;
        }


@media (max-width: 1200px) {
	
	.main-nav a {    margin-left: 74px;}
   
	.textoformulario h2 {    font-size: var(--font-md) !important;    line-height: var(--font-md) !important}
	.textoformulario h2.responsivesm {    font-size: var(--font-sm) !important;    line-height: var(--font-md) !important}
	
}

        /* --- Estilos Responsivos para Móviles --- */
        @media (max-width: 992px) {
		
			hr {width: 90%; text-align: center;  justify-self: center}
			
			
            .footer-container {
                flex-direction: column; /* Apila las columnas */
                align-items: center; /* Centra las columnas apiladas */
                text-align: center;
            }

            .footer-column {
                min-width: 100%; /* Cada columna ocupa todo el ancho */
            }
            
            .footer-column .contact-item {
                justify-content: center; /* Centra los items de contacto */
            }
        }

 @media (max-width: 768px) {
	 .celpadding { padding: 20px }
            }
 @media (max-width: 600px) {
.main-header {    padding: 3px 0;}
.logo img {  height: 50px}
.hamburger span {width: 24px;height: 2px; background: white; border-radius: 2px; transition: 0.3s;}	 
	}

 @media (max-width: 550px) {
.textohomeh1 {  font-size: var(--font-xl)}
.textohomeboton {margin-top: 0px}
.cel {display: block}
}
          



