

@media only screen and (max-width: 768px) {

    /* TODO el menú principal en negrita */
    .mobile_menu > ul > li,
    .mobile_menu > ul > li * {
        font-weight: 700 !important;
    }

    /* SUBMENÚ normal */
    .mobile_menu ul li ul li,
    .mobile_menu ul li ul li * {
        font-weight: 400 !important;
    }

    /* tamaños */
    .mobile_menu ul li a,
    .mobile_menu ul li span,
    .mobile_menu ul li h4 {
        font-size: 18px !important;
        line-height: 26px !important;
    }

    /* icono hamburguesa */
    .mobile_menu_button span,
    .mobile_menu_button i {
        font-size: 26px !important;
    }
}

.img-centro {
  text-align: center;
}

.img-centro img {
  max-width: 100%;
  height: auto;
}
@media only screen and (max-width: 768px) {

  /* fuerza todas las columnas a ancho completo */
  .vc_row .vc_column_container,
  .qodef-row .qodef-column {
    width: 100% !important;
    float: none !important;
  }

  /* elimina espacios laterales raros */
  .vc_column-inner,
  .qodef-column-inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* separacion entre bloques */
  .vc_column_container {
    margin-bottom: 20px;
  }

}
@media only screen and (max-width: 768px) {

  .img-centro img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }

}
@media only screen and (max-width: 768px) {

  /* elimina offsets raros en columnas */
  .vc_col-sm-offset-1,
  .vc_col-sm-offset-2,
  .vc_col-sm-offset-3,
  .vc_col-sm-offset-4 {
    margin-left: 0 !important;
  }

  /* fuerza TODAS las columnas iguales */
  .vc_row .vc_column_container {
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* asegura que las imágenes ocupen todo */
  .img-centro img {
    width: 100% !important;
    max-width: 100% !important;
  }

}
@media only screen and (max-width: 768px) {

  .servicio-box {
    width: 100% !important;
    margin-bottom: 25px;
  }

  .servicio-box img {
    width: 100% !important;
    height: auto !important;
    display: block;
  }

}
.vc_row {
  margin-bottom: 40px;
}
.hero-overlay {
  background: rgba(0,0,0,0.4);
}
.form-boxed {
  max-width: 600px;
  margin: 0 auto;
}

.form-boxed p {
  margin-bottom: 15px;
  line-height: 1.5;
}

.form-boxed input,
.form-boxed textarea,
.form-boxed select {
  width: 100%;
  padding: 10px;
  margin-top: 5px;
}

.form-boxed .wpcf7-list-item {
  display: block;
  margin-bottom: 5px;
}
.form-boxed {
  max-width: 600px;
  margin: 0 auto;
  font-family: 'Montserrat', sans-serif;
}

.form-boxed p {
  margin-bottom: 10px;
  font-size: 14px;
  color: #444;
}

.form-boxed input,
.form-boxed textarea,
.form-boxed select {
  width: 100%;
  padding: 10px;
  margin-top: 2px;
  border: 1px solid #ddd;
  border-radius: 6px;
}

.form-boxed .wpcf7-list-item {
  display: block;
  margin-bottom: 6px;
  font-size: 14px;
}
.mobile_menu_wrapper .mobile_menu ul li a,
nav.mobile_menu ul li a {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400 !important;
    letter-spacing: 0.3px;
    text-transform: none;
}
.btn-precio-estatico,
.btn-precio-estatico:hover {
    cursor: default !important;
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
}

.btn-precio-estatico a,
.btn-precio-estatico a:hover {
    pointer-events: none !important;
    cursor: default !important;
    color: #FFFFFF !important;
    background-color: #D4AF37 !important;
    border-color: #D4AF37 !important;
    text-decoration: none !important;
}
font-size: clamp(28px, 4.2vw, 70px);
text-shadow: 2px 2px 6px rgba(0,0,0,0.45);
/* =========================
   RESPONSIVE MOBILE FIX
   ========================= */

@media only screen and (max-width: 768px) {

    /* ===== 1. GRID: 2 COLUMNAS ===== */
    .vc_col-sm-4 {
        width: 50% !important;
        float: left;
        padding: 6px !important;
    }

    /* Evita problemas de alineación */
    .vc_row::after {
        content: "";
        display: block;
        clear: both;
    }

    /* ===== 2. ESPACIADO ENTRE BLOQUES ===== */
    .vc_row {
        margin-bottom: 20px !important;
    }

    .wpb_column {
        margin-bottom: 15px !important;
    }

    /* ===== 3. IMÁGENES CONTROLADAS ===== */
    .wpb_single_image img {
        width: 100%;
        height: auto;
        max-height: 180px;
        object-fit: cover;
        border-radius: 6px;
    }

    /* ===== 4. MARCOS MÁS LIVIANOS ===== */
    .wpb_single_image,
    .wpb_wrapper {
        padding: 5px !important;
    }

    /* ===== 5. TEXTOS AJUSTADOS ===== */
    h1 {
        font-size: 22px !important;
        line-height: 1.2 !important;
    }

    h2 {
        font-size: 18px !important;
        line-height: 1.3 !important;
    }

    p {
        font-size: 14px !important;
        line-height: 1.4 !important;
    }

    /* ===== 6. BOTONES MÁS GRANDES ===== */
    .qbutton {
        width: 100%;
        text-align: center;
        padding: 12px !important;
        font-size: 14px !important;
    }

    /* ===== 7. REDUCE ESPACIOS VACÍOS ===== */
    .content .container .container_inner {
        padding-top: 10px !important;
        padding-bottom: 10px !important;
    }

}
body {
    background: red !important;
}
body {
    background: red !important;
}
@media only screen and (max-width: 768px) {

    /* BOTONES COMPLETOS */
    .qbutton {
        width: 100% !important;
        display: block !important;
        padding: 12px 10px !important;
        box-sizing: border-box !important;
    }

    /* CONTENEDOR DEL BOTÓN */
    .wpb_wrapper {
        overflow: visible !important;
    }

}