html {
    scroll-behavior: smooth; /* Hace que el movimiento sea suave y no un salto brusco */
    scroll-padding-top: 100px; /* Ajusta este valor según la altura de tu menú */
}

/* --- VARIABLES Y RESET --- */
:root {
    --color-fondo-oscuro: #1b2e21; 
    --color-verde-claro: #9bb07f;  
    --color-blanco: #ffffff;
    --fuente-principal: 'Montserrat', sans-serif;
}

* {
    max-width: 100%;
    box-sizing: border-box;
}

img {
    max-width: 100%;
    height: auto;
    display: inline-block;
}

body {
    font-family: var(--fuente-principal);
    background-color: var(--color-fondo-oscuro);
    color: var(--color-blanco);
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

/* --- SISTEMA DE COLUMNAS M (Ajustado) --- */
.row { 
    display: flex; 
    flex-wrap: wrap; 
}

[class*="col-m-"] {
    width: 100%;
    padding: 20px;
}

@media (min-width: 992px) {
    .col-m-3 { width: 25%; }
    .col-m-6 { width: 50%; }
    .col-m-9 { width: 75%; }
}

/* --- ENCABEZADO --- */
.encabezado-principal {
    background-color: var(--color-blanco);
    padding: 15px 0;
}

.logo-marca {
    max-height: 80px;
    width: auto;
}

.menu-lista li {
    display: inline-block;
    margin: 0 15px;
}

.menu-lista li a {
    text-decoration: none;
    color: #333;
    font-weight: 500;
    font-size: 1.2rem;
}

.icono-rrss {
    width: 30px;
    margin-left: 15px;
    filter: brightness(0.2);
}

.encabezado-principal {
    background-color: var(--color-blanco);
    border-bottom: 1px solid #eee;
}

.logo-marca {
    max-height: 60px; /* Un poco más pequeño para móviles */
    width: auto;
}

/* Ajustes para los enlaces en desktop y móvil */
.menu-lista .nav-link {
    color: #333 !important;
    font-weight: 500;
    font-size: 1.1rem;
    padding: 10px 15px !important;
}

.icono-rrss {
    width: 25px;
    margin: 0 8px;
    filter: brightness(0.2);
    transition: 0.3s;
}
.navbar-toggler {
    border: 2px solid var(--color-verde-claro) !important;
    padding: 4px 8px;
}

/* Forzar que aparezcan las 3 líneas en color verde oscuro */
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='%23253528' stroke-width='3' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E") !important;
    width: 1.5em;
    height: 1.5em;
}


/* --- ESTILOS RESPONSIVE PARA EL MENÚ --- */
@media (max-width: 991px) {
    .navbar-collapse {
        background: white;
        padding: 20px;
        border-radius: 15px;
        margin-top: 15px;
        box-shadow: 0 10px 20px rgba(0,0,0,0.1);
        text-align: center;
    }
    
    .menu-lista li {
        margin: 10px 0;
        display: block; /* Apilar en móvil */
    }

    .iconos-sociales {
        margin-top: 20px;
        padding-top: 15px;
        border-top: 1px solid #eee;
    }
    .navbar-collapse.show {
        border-top: 3px solid var(--color-verde-claro);
    }
}



/* --- SECCIÓN HERO (REFINADA) --- */
.seccion-hero {
    min-height: 80vh;
    display: flex;
    align-items: center;
    padding: 60px 0;
}

.contenedor-reducido {
    max-width: 1500px; /* Evita que el contenido se expanda al infinito */
    margin: 0 auto;
    width: 100%;
}

.titulo-principal {
    font-size: 4.5em; /* Tamaño más controlado y elegante */
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1.5rem;
}

.subtitulo {
    font-size: 2em;
    color: var(--color-verde-claro);
    font-weight: 400;
    margin-bottom: 0.5rem;
}

.lema {
    font-size: 1.9em;
    font-weight: 700;
    margin-bottom: 2.5rem;
}

.boton-accion {
    display: inline-block;
    background-color: var(--color-verde-claro);
    color: var(--color-blanco);
    padding: 14px 30px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.1em;
    transition: transform 0.3s ease;
}

.boton-accion:hover {
    transform: scale(1.05);
    color: #253528;
}

/* --- IMAGEN Y ETIQUETAS --- */
.contenedor-imagen-destacada {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
}

.imagen-principal {
    border-radius: 20px;
    width: 100%;
    box-shadow: 0px 15px 35px rgba(0,0,0,0.4);
    border: #9bb07f 1px solid;
}

.etiqueta {
    position: absolute;
    background-color: var(--color-verde-claro);
    color: var(--color-blanco);
    padding: 10px 20px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1.2em;
    z-index: 10;
}

.etiqueta-superior {
    top: 20px;
    right: -45px;
}

.etiqueta-inferior {
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    text-align: center;
}

.seccion-hero {
    scroll-margin-top: 400px; 
}

/* --- AJUSTE MÓVIL --- */
@media (max-width: 991px) {
    .titulo-principal { font-size: 2.2rem; line-height: 1.1; }
    .seccion-hero { text-align: center; padding: 40px 15px; }
    .etiqueta { 
        position: relative !important; 
        width: fit-content; 
        margin: 10px auto; 
        left: 0 !important; 
        right: 0 !important; 
        top: 0 !important; 
        transform: none !important; 
    }
    .contenedor-imagen-destacada { padding: 0 15px; }
}



/* --- SECCIÓN SERVICIOS --- */
.seccion-servicios {
    background-color: var(--color-blanco);
    color: #333;
    padding-top: 120px;
    padding-bottom:120px;
}

/* EDITAR LÍNEAS DEL TÍTULO */
.linea {
    height: 4px;             /* Grosor de la línea */
    width: 150px;             /* Largo de la línea */
    background-color: #253528; /* Color de la línea */
    display: inline-block;
}

.titulo-seccion {
    font-weight: 700;
    text-transform: none;
    font-size: 4em;         /* Tu tamaño original */
    color: #253528;
}

.subtitulo-verde {
    color: var(--color-verde-claro);
    font-weight: 700;
    font-size: 2.5em;    
    letter-spacing: 1px;
}

.texto-descripcion {
    font-size: 2em;      
    color: #000000;
}

.cuadro-cubrimos {
    border: 2px solid var(--color-verde-claro);
    border-radius: 40px;
    background-color: #fff;
}

.titulo-cubrimos {
    font-weight: 700;
    font-size: 4em; 
    color: #253528;
}

.imagen-banner-servicio {
    border-radius: 15px;
    width: 100%;
}

/* TARJETAS CON EFECTO ZOOM */
.tarjeta-servicio {
    border: 2px solid #9bb07f;
    border-radius: 15px;
    padding: 25px 15px;
    height: 100%;
    transition: transform 0.3s ease, border-color 0.3s ease; /* Transición suave */
}

.tarjeta-servicio:hover {
    border-color: var(--color-verde-claro);
    transform: scale(1.08); /* EFECTO ZOOM AL PASAR EL MOUSE */
    cursor: pointer;
}

.icono-servicio {
    height: 100px;
    width: auto;
}

.nombre-servicio {
    font-weight: 700;
    font-size: 2em;      
    margin-bottom: 0;
    color: #253528;
}

/* EDITAR CUADRO AMARILLO (IMPORTANTE) */
.alerta-importante {
    background-color: #fff9c4; /* COLOR DE FONDO */
    border: 2px solid #fbc02d; 
    border-radius: 10px;
}

.icono-alerta {
    width: 47px;
    height: auto;
}

.texto-alerta {
    /* EDITAR TEXTO AQUÍ */
    font-size: 1.8em;      
    color: #253528;         
    line-height: 1.4;
    text-align: center;
}
.seccion-servicios {
    scroll-margin-top: 350px; 
}

/* Ajuste para dispositivos móviles */
@media (max-width: 991px) {
    .linea { width: 50px; }
    .titulo-seccion, .titulo-cubrimos, .titulo-principal-claro, .titulo-ayuda { 
        font-size: 2rem !important; 
    }
    .subtitulo-verde, .subtitulo-contactanos { font-size: 1.5rem !important; }
    .texto-descripcion, .texto-paso, .texto-defensa-secundario { font-size: 1.2rem !important; }
    
    /* Forzar que las columnas de servicios ocupen el 100% en móvil */
    [class*="col-m-"] {
        width: 100% !important;
        padding: 10px;
    }
}



/* --- SECCIÓN DEFENSA (CIERRE) --- */
.seccion-defensa {
    background-color: #9faf8a; 
    color: #253528;       
}

.contenido-defensa {
    /* Espaciado interno para dar aire al mensaje */
    padding: 2em 0;
}

.titulo-defensa {
    font-weight: 800;
    font-size: 3.5em; 
    line-height: 1.2;
    margin: 0 auto;
    max-width: 1000px;
}

.texto-defensa-secundario {
    font-weight: 400;
    font-size: 2em;   /* Tamaño acorde a tus p anteriores */
    color: #253528;
    opacity: 0.9;
    margin-top: 1.5rem;
}

/* Ajustes para que en pantallas pequeñas el texto no sea excesivo */
@media (max-width: 991px) {
    .titulo-defensa {
        font-size: 2.2em;
    }
    .texto-defensa-secundario {
        font-size: 1.5em;
    }
}

@media (max-width: 768px) {
    .titulo-defensa {
        font-size: 1.8em;
    }
    .texto-defensa-secundario {
        font-size: 1.2em;
    }
}




/* --- SECCIÓN NUESTRO PROCESO --- */
.seccion-proceso {
    background-color: var(--color-blanco);
    padding-top: 80px;
    padding-bottom: 180px;
    padding-top: 120px;
}

/* Reutilizamos el estilo de las líneas que ya definimos */
.linea {
    height: 4px;
    width: 100px;
    background-color: #253528;
    display: inline-block;
}

.titulo-seccion {
    font-weight: 700;
    font-size: 4em; /* Tu tamaño original */
    color: #253528;
}

/* Tarjetas de Proceso */
.tarjeta-proceso {
    background-color: #fff;
    border: 2px solid var(--color-verde-claro); /* Borde verde claro */
    border-radius: 25px;
    position: relative;
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.tarjeta-proceso:hover {
    transform: scale(1.03); /* Efecto zoom suave */
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

/* Números de los pasos (esquina superior izquierda) */
.numero-paso {
    position: absolute;
    top: 20px;
    left: 25px;
    font-weight: 700;
    font-size: 2em; /* Tamaño grande para el número */
    color: #253528;
}

/* Contenedor del icono (fondo verde suave) */
.contenedor-icono-proceso {
    background-color: var(--color-verde-claro);
    width: 90px;
    height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    margin-top: 10px;
}

.icono-proceso {
    max-height: 60px;
    width: auto;
}

/* Texto del paso */
.texto-paso {
    font-weight: 700;
    font-size: 2.2em; /* Tamaño prominente en em */
    color: #253528;
    margin-top: 15px;
    line-height: 1.2;
}
.seccion-proceso {
    scroll-margin-top: 350px; 
}

/* Ajustes Responsivos */
@media (max-width: 991px) {
    .titulo-seccion { font-size: 2.5em; }
    .texto-paso { font-size: 1.8em; }
    .numero-paso { font-size: 1.5em; }
}

@media (max-width: 576px) {
    .col-m-6 { width: 100%; } /* En móviles muy pequeños, 1 por fila */
}





/* --- SECCIÓN TAMBIÉN REPRESENTAMOS --- */
.seccion-representamos {
    background-color: var(--color-fondo-oscuro);
    padding: 100px 0;
    padding-bottom: 180px;
    padding-top: 120px;
}

.titulo-principal-claro {
    color: var(--color-blanco);
    font-size: 4em;
    font-weight: 700;
}

/* Tarjetas Blancas (1 fila de 4) */
.tarjeta-blanca-vertical {
    background-color: #ffffff;
    border-radius: 30px;
    padding: 35px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    height: 100%;
    min-height: 320px;
    border: 5px solid var(--color-verde-claro);
    transition: transform 0.3s ease;
}

.tarjeta-blanca-vertical:hover {
    transform: translateY(-10px);
}

.contenedor-icono-verde {
    background-color: #fff;
    border: #8aa16d 3px solid;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.icono-representamos {
    width: 50px;
    height: auto;
}

.titulo-tarjeta-representamos {
    color: #253528;
    font-weight: 700;
    font-size: 1.8em; /* Ajustado para que quepa bien en los 4 bloques */
    margin-bottom: 10px;
}

.texto-tarjeta-representamos {
    color: #666;
    font-size: 1.3em;
    margin-bottom: 0;
    line-height: 1.2;
}

/* Cuadro CTA Final */
.cuadro-indemnizacion-final {
    border: 3px solid var(--color-verde-claro);
    border-radius: 40px;
    background-image: linear-gradient(to right, transparent, #5f6743, transparent);
     max-width: 1200px;
    margin: 0 auto; 
}


.texto-cta-indemnizacion {
    color: var(--color-blanco);
    font-size: 2em; 
    font-weight: 400;
}

.boton-accion-representamos {
    display: inline-flex;
    align-items: center;
    background-color: #fff;
    color: #253528;
    border: #8aa16d 3px solid;
    padding: 10px 35px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.4em;
    margin-top: 25px;
    transition: 0.3s ease;
}

.boton-accion-representamos:hover {
    background-color: #8aa16d;
    transform: scale(1.05);
}

/* Ajustes Responsivos para móvil */
@media (max-width: 991px) {
    .seccion-representamos .col-m-3 { 
        width: 100% !important; 
        margin-bottom: 20px;
    }
    .tarjeta-blanca-vertical {
        min-height: auto;
    }
}






/* --- SECCIÓN CONTACTO --- */
.seccion-contacto {
    background-color: #ffffff;
    padding: 100px 0;
    padding-bottom: 180px;
    padding-top: 120px;
}

/* Tarjeta del Formulario */
.tarjeta-formulario {
    background-color: #f1f3ef; /* Gris verdoso muy claro */
    border-radius: 40px;
    box-shadow: 15px 15px 0px #1b2e21; /* Sombra sólida estilo diseño */
}

.contenedor-icono-formulario {
    background-color: var(--color-verde-claro);
    width: 70px;
    height: 70px;
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15px;
}

.titulo-formulario {
    font-size: 2.5em;
    font-weight: 700;
    color: #253528;
    margin-bottom: 5px;
}

.texto-formulario-guia {
    font-size: 1.1em;
    color: #253528;
    line-height: 1.3;
}

/* Inputs personalizados */
.form-control-custom {
    width: 100%;
    padding: 12px 20px;
    border-radius: 15px;
    border: 1px solid #0c301785;
    background-color: #fff;
    font-size: 1em;
    color: #333;
    outline: none;
    transition: border-color 0.3s;
}

.form-control-custom:focus {
    border-color: var(--color-verde-claro);
}

.boton-enviar-formulario {
    background-color: var(--color-verde-claro);
    color: #fff;
    border: none;
    padding: 12px 40px;
    border-radius: 15px;
    font-weight: 700;
    font-size: 1.3em;
    transition: background 0.3s;
    cursor: pointer;
}

.boton-enviar-formulario:hover {
    background-color: #9faf8a;
}

.texto-seguridad {
    font-size: 0.9em;
    color: #253528;
}

.punto-divisor {
    width: 5px;
    height: 5px;
    background-color: #ccc;
    border-radius: 50%;
}

/* Información de Contacto (Derecha) */
.titulo-ayuda {
    font-size: 4em; /* Tu escala de texto */
    font-weight: 700;
    color: #1b2e21;
    line-height: 1.1;
}

.subtitulo-contactanos {
    font-size: 2.5em;
    font-weight: 700;
    color: #253528;
}

.icono-contacto-circulo {
    background-color: var(--color-verde-claro);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.icono-contacto-circulo img {
    width: 30px;
    height: auto;
}

.etiqueta-medio {
    font-size: 1.8em;
    font-weight: 700;
    color: #253528;
    margin-bottom: 0;
}

.dato-medio {
    font-size: 1.2em;
    color: #333;
    margin-bottom: 0;
    font-weight: 500;
}

.detalle-medio {
    font-size: 1em;
    color: #666;
    margin-bottom: 0;
}
.seccion-contacto {
    scroll-margin-top: 350px; 
}

/* Responsivo */
@media (max-width: 991px) {
    .titulo-ayuda { font-size: 2.5em; }
    .subtitulo-contactanos { font-size: 1.8em; }
    .etiqueta-medio { font-size: 1.4em; }
    .tarjeta-formulario { margin-bottom: 50px; }
}



/* ===============================
   FOOTER FARIA BUSINESS
================================ */

.faria-footer{
  background:#1F2F27;
  color:#ffffff;
  padding:35px 0 18px;
  font-size: 1.5em;
  padding-top: 80px;
}

.faria-footer__wrap{
  max-width:1200px;
  margin:0 auto;
  padding:0 25px;
  display:flex;
  gap:30px;
  align-items:center;
}

/* Columnas */
.faria-footer__col{ flex:1; }
.faria-footer__center{ text-align:center; }

/* Logo */
.faria-footer__logo{
  width:160px;
  display:block;
}

/* Redes */
.faria-footer__social{
  display:flex;
  gap:14px;
  margin-top:15px;
}
.faria-footer__social img{
  width:22px;
  height:auto;
  filter:none;
}

.faria-footer__social a:hover img{
  opacity:.7;
  transform:scale(1.05);
  transition:.25s ease;
}

/* Texto central */
.faria-footer__center p{
  font-size:14px;
  line-height:1.6;
  margin:0 0 10px;
}

/* Info */
.faria-footer__infoGrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); /* Se ajusta solo según el espacio */
    gap: 20px;
    width: 100%;
    margin-left: 200px;
}

.faria-infoItem{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.faria-infoItem img{
  width:45px;
  height:45px;
  border-radius:50%;
}

.faria-infoItem strong{
  display:block;
  font-size:13px;
  color:#FFFFFF;
}

.faria-infoItem span{
  font-size:13px;
  display:block;
}

.faria-infoItem small{
  font-size:11px;
  color:#AFC2B2;
}

/* Bottom */
.faria-footer__bottom{
  margin-top:22px;
}

.faria-footer__line{
  height:1px;
  background:#6F806F;
  margin-bottom:12px;
}

.faria-footer__bottomRow{
  max-width:1200px;
  margin:0 auto;
  padding:0 25px;
  display:flex;
  justify-content:space-between;
  font-size:12px;
  color:#C5CEC7;
}

/* Responsive */
@media(max-width:900px){
  .faria-footer__wrap{
    flex-direction:column;
    text-align:center;
  }
  .faria-footer__infoGrid{
    grid-template-columns:1fr;
  }
  .faria-footer__bottomRow{
    flex-direction:column;
    gap:6px;
    text-align:center;
  }
}