    :root{
    --bg-page:#fff;
    --text:#2d2d2d;
    --muted:#555;
    --white:#fff;
    --card:#F4F4F4;
    --primary:#09a2c8;
    --primary-dark:#008FB1;
    --blue-left:#005998;
    --blue-right:#008FB1;
    --shadow:0 6px 16px rgba(0,0,0,.12);
    --radius:10px;
    --radius-lg:14px;
    --max:1209px;
    }

    *{ box-sizing:border-box; }

    html,body{
    margin:0;
    padding:0;
    }

    body{
    font-family:'Montserrat', Arial, sans-serif;
    background:var(--bg-page);
    color:var(--text);
    line-height:1.25;
    }

    img{
    max-width:100%;
    display:block;
    }

    button,input{
    font:inherit;
    }

    .container{
    width:min(calc(100% - 32px), var(--max));
    margin-inline:auto;
    }

    .section-gap{
    margin-top:28px;
    }

    /* =========================
    LOGO
    ========================= */
    .top-logo{
    display:flex;
    justify-content:center;
    align-items:center;
    padding:28px 0 40px;
    }

    .logo-box{
    text-align:center;
    line-height:1;
    }

    .logo-main{
    font-family:'Roboto', sans-serif;
    font-weight:900;
    font-size:clamp(34px, 5vw, 62px);
    color:#131820;
    letter-spacing:.4px;
    display:inline-flex;
    align-items:center;
    gap:8px;
    }

    .logo-plus{
    display:grid;
    grid-template-columns:repeat(3, 10px);
    grid-template-rows:repeat(3, 10px);
    gap:3px;
    transform:translateY(2px);
    }

    .logo-plus span{
    width:10px;
    height:10px;
    border-radius:2px;
    background:#17a8d1;
    opacity:.18;
    }

    .logo-plus span.on{
    opacity:1;
    }

    .logo-sub{
    margin-top:4px;
    font-family:'Roboto', sans-serif;
    font-weight:700;
    font-size:clamp(11px,1.3vw,22px);
    letter-spacing:.8px;
    color:#222;
    }

    .logo-img{
    max-width:250px;
    width:100%;
    height:auto;
    }

    /* =========================
    HERO SLIDER
    Tamaño base aprox: 1209x457
    ========================= */
    .hero-slider{
    position:relative;
    border-radius:12px;
    overflow:hidden;
    background:#ddd;
    aspect-ratio:1209 / 457;
    }

    .slider-track{
    position:relative;
    width:100%;
    height:100%;
    }

    .slide{
    position:absolute;
    inset:0;
    opacity:0;
    visibility:hidden;
    transition:opacity .45s ease, visibility .45s ease;
    }

    .slide.is-active{
    opacity:1;
    visibility:visible;
    z-index:2;
    }

    .slide > img{
    width:100%;
    height:100%;
    object-fit:cover;
    }

    .slide-overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(90deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.36) 28%, rgba(0,0,0,.08) 55%, rgba(0,0,0,.03) 100%);
    }

    .slide-content{
    position:absolute;
    left:70px;
    top:50%;
    transform:translateY(-50%);
    z-index:3;
    max-width:min(55%, 600px);
    color:#fff;
    }

    .slide-icon-box{
    display:block;
    margin-bottom:14px;
    line-height:0;
    background:transparent;
    box-shadow:none;
    width:auto;
    height:auto;
    }

    .slide-icon-box img {
        display: block;
        width: 60px;
        height: 60px;
        object-fit: contain;
        filter: none;
        margin-left: -6px;
    }

    .slide-content h1,
    .slide-content h2{
    margin:0;
    font-family:'Roboto', sans-serif;
    font-weight:700;
    font-size:clamp(24px, 2.7vw, 54px);
    line-height:1.05;
    text-shadow:0 2px 8px rgba(0,0,0,.28);

    /* 👇 reserva espacio para 2 líneas */
    min-height: calc(1.05em * 2);
    display:flex;
    align-items:flex-start;
    }

    /* Controles slider */
    .slider-btn{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:5;
    width:42px;
    height:42px;
    border:none;
    border-radius:50%;
    background:rgba(0,0,0,.35);
    color:#fff;
    font-size:28px;
    line-height:1;
    cursor:pointer;
    display:grid;
    place-items:center;
    transition:background .2s ease, transform .2s ease;
    }

    .slider-btn:hover{
    background:rgba(0,0,0,.5);
    }

    .slider-btn:active{
    transform:translateY(-50%) scale(.96);
    }

    .slider-btn.prev{ left:14px; }
    .slider-btn.next{ right:14px; }

    .slider-dots{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    bottom:14px;
    z-index:5;
    display:flex;
    gap:8px;
    background:rgba(0,0,0,.18);
    padding:6px 10px;
    border-radius:999px;
    backdrop-filter: blur(4px);
    }

    .dot{
    width:9px;
    height:9px;
    border-radius:50%;
    border:none;
    padding:0;
    cursor:pointer;
    background:rgba(255,255,255,.55);
    }

    .dot.is-active{
    background:#fff;
    }

    /* =========================
    INTRO
    ========================= */
    .intro{
    text-align:center;
    padding: 40px 60px 40px;
    }

    .intro h3{
    margin:0 auto 10px;
    max-width:960px;
    font-family:'Roboto', sans-serif;
    font-weight:700;
    font-size:clamp(23px, 1.55vw, 31px);
    line-height:1.15;
    color:#1f1f1f;
    }

    .intro p{
    margin:0 auto;
    max-width:960px;
    font-weight:400;
    font-size: clamp(20px, 1.3vw, 31px);
    line-height:1.22;
    color:#444;
    }

    /* =========================
    SERVICIOS
    ========================= */
    .services{
        max-width: 1040px;
    padding-top:6px;
    padding-bottom:8px;
    }

    .services h2{
    text-align:center;
    margin:0 0 40px;
    font-family:'Roboto', sans-serif;
    font-size:clamp(24px, 2vw, 34px);
    font-weight:700;
    color:var(--primary);
    line-height:1.1;
    }

    .services-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0,1fr));
    gap:10px; /* un poco más de aire como en el boceto */
    }

    .services-grid + .services-grid{
    margin-top:8px;
    }

    .service-card{
    background:var(--card);
    border-radius:6px;
    min-height:165px;           /* más alto como el diseño */
    padding:16px 14px 14px;     /* más aire interno */
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    }

    .service-icon{
    margin-bottom:2px;
    flex-shrink:0;
    background:transparent;
    box-shadow:none;
    width:auto;
    height:auto;
    border-radius:0;
    display:block;
    line-height:0;
    }

    .service-icon img{
        display: block;
        width: 60px;
        height: 60px;
        object-fit: contain;
        filter: none;
        margin-left: -5px;
    }

    .service-card p{
    margin:0;
    font-size:18px;       /* 👈 en tu versión estaba muy chico */
    line-height:1.18;
    color:#2f2f2f;
    word-break:break-word;
    max-width:95%;
    }

    .services-action{
    display:flex;
    justify-content:center;
    margin-top:40px;
    }

    .toggle-services-btn{
    border:1px solid #35afd0;
    color:#2f9ec3;
    background:transparent;
    border-radius:999px;
    min-width:172px;
    height:36px;             /* 👈 más alto */
    padding:0 18px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    cursor:pointer;
    font-size:14px;          /* 👈 más legible */
    font-weight:500;
    transition:all .2s ease;
    }

    .toggle-services-btn:hover{
    background:rgba(9,162,200,.06);
    }

    .toggle-services-btn:active{
    transform:translateY(1px);
    }

    .toggle-arrow{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    line-height:0;
    transition:transform .2s ease;
    }

    .toggle-arrow img{
    display:block;
    width:12px;   /* ajusta según el SVG */
    height:auto;
    }

    .toggle-services-btn[aria-expanded="true"] .toggle-arrow{
    transform: rotate(180deg);
    }

    /* animación desplegable simple */
    .services-grid-extra[hidden]{
    display:none !important;
    }

    /* =========================
    CONTACTO
    ========================= */
    .contact-section{
    background: linear-gradient(90deg, #005998 0%, #008FB1 100%);
    margin-top:26px;
    }

.contact-wrap{
  min-height:228px;
  display:grid;
  grid-template-columns: minmax(240px, 320px) minmax(320px, 420px);
  align-items:center;
  justify-content:center;
  column-gap:34px;
  padding:26px 24px;
  max-width:980px;       /* 👈 clave: centra el conjunto como en el boceto */
  margin-inline:auto;    /* 👈 clave */
}
.contact-title{
  display:flex;
  justify-content:center;
  align-items:center;
  padding-right:0;
}

.contact-title h2{
  margin:0;
  color:#fff;
  font-family:'Roboto', sans-serif;
  font-weight:700;
  font-size:clamp(24px, 2vw, 38px);
  line-height:0.98; /* más compacto como la referencia */
  text-align:left;
  max-width:260px;
}

.contact-form-box{
  background:#fff;
  border-radius:2px;
padding: 50px 30px;
  width:100%;
  max-width:420px;
  justify-self:center;  /* 👈 importante */
  position:relative;
  box-shadow:none;
}

    /* Fallback visual (si no carga datacrush) */
    .fake-form{
    display:grid;
    gap:12px;
    }
    
.fake-form input{
  height:40px;
  border:0px solid #d9d9d9;
  background:#F4F4F4;   /* 👈 menos blanco */
  padding:0 10px;
  outline:none;
  font-size:13px;
  color:#444;
  border-radius:0;
}

    .fake-form button{
    margin-top:2px;
    height:30px;
    border:none;
    border-radius:999px;
    background:#0095B1;
    color:#fff;
    cursor:pointer;
    font-weight:600;
    width:65%;
    justify-self:center;
    }

    /* Cuando DataCrush inyecte el form, ocultamos fallback visual con JS si hace falta */
    body.datacrush-loaded .fake-form{
    display:none;
    }
    

    #datacrush-form-wrapper{
    width:100%;
    min-height:0;
    }

    body.datacrush-loaded #datacrush-form-wrapper{
    min-height:120px;
    }

    #datacrush-form-wrapper iframe,
    #datacrush-form-wrapper form{
    width:100% !important;
    max-width:100% !important;
    }

    /* =========================
    RESPONSIVE
    ========================= */
    @media (max-width: 1024px){
    .slide-content{
        left:40px;
        bottom:30px;
        max-width:62%;
    }

    .slide-icon-box{
        width:38px;
        height:38px;
        margin-bottom:10px;
    }

    .slide-icon-box img{
        width:20px;
        height:20px;
    }

    .services-grid{
        grid-template-columns:repeat(4, minmax(0,1fr));
        gap:8px;
    }

    .service-card{
        min-height:118px;
    }
    }

    @media (max-width: 768px){
    .container{
        width:min(calc(100% - 20px), var(--max));
    }

    .top-logo{
        padding:18px 0 40px;
    }

    .logo-img {
        max-width: 200px;
        }

    .hero-slider{
        aspect-ratio:16 / 9;
        border-radius:10px;
    }

    .slide-overlay{
        background:
        linear-gradient(90deg, rgba(0,0,0,.64) 0%, rgba(0,0,0,.38) 42%, rgba(0,0,0,.12) 70%, rgba(0,0,0,.03) 100%);
    }

    .slide-content{
        left:40px;
        right:18px;
        bottom:18px;
        max-width:82%;
    }

    .slide-icon-box{
        width:40px;
        height:40px;
        border-radius:7px;
        margin-bottom:8px;
    }

    .slide-icon-box img{
        width:40px;
        height:40px;
    }

    .slider-btn{
        width:36px;
        height:36px;
        font-size:22px;
    }

    .slider-btn.prev{ left:8px; }
    .slider-btn.next{ right:8px; }

    .slider-dots{
        bottom:10px;
        padding:5px 8px;
        gap:6px;
    }

    .dot{
        width:8px;
        height:8px;
    }

    .intro{
        padding-inline:4px;
    }

    .services h2{
        margin-bottom:12px;
    }

        .services-grid{
        grid-template-columns:repeat(2, minmax(0,1fr));
        gap:8px;
        }

        .service-card{
        min-height:140px;
        padding:12px 10px;
        }


    .service-card p{
        font-size:12px;
    }

.contact-wrap{
  grid-template-columns: 1fr 280px;
  gap:18px;
  padding:20px 14px 26px;
  align-items:center;
}

.contact-title{
  justify-content:center;
  padding-right:0;
}

.contact-title h2{
  text-align:left;
  line-height:0.98;
  max-width:180px;
  font-size:clamp(18px, 2.4vw, 28px);
}

.contact-form-box{
  max-width:280px;
  padding:14px 12px;
  justify-self:start;
}

/* Footer / contacto mobile */
.contact-wrap{
  grid-template-columns:1fr !important;
  gap:14px;
  padding:18px 12px 22px;
  max-width:100%;
  margin-inline:auto;
  justify-content:stretch;
}

.contact-title{
  justify-content:flex-start;   /* o center si lo prefieres centrado */
  align-items:flex-start;
  width:100%;
  padding-right:0;
}

.contact-title h2{
  max-width:220px;
  font-size:24px;
  line-height:0.98;
  text-align:left;
  margin:0;
}

.contact-form-box{
  width:100%;
  max-width:100%;
  justify-self:stretch;
  padding:14px 12px;
}

.fake-form{
  gap:8px;
}

.fake-form input{
  height:30px;
  font-size:13px;
}

.fake-form button{
  width:78%;
  height:28px;
  font-size:12px;
}
    }

    @media (max-width: 480px){
    .logo-main{
        font-size:32px;
    }

    .logo-plus{
        grid-template-columns:repeat(3, 8px);
        grid-template-rows:repeat(3, 8px);
        gap:2px;
    }

    .logo-plus span{
        width:8px;
        height:8px;
    }

    .logo-sub{
        font-size:11px;
        letter-spacing:.7px;
    }

    .hero-slider{
        aspect-ratio: 4 / 3;
    }

    .slide-content{
        left:40px;
        right:14px;
        bottom:14px;
        max-width:88%;
    }

    .slide-content h1,
    .slide-content h2{
        font-size:clamp(18px, 5.8vw, 28px);
        line-height:1.08;
    }

    .slide-icon-box{
        width:40px;
        height:4;
        margin-bottom:7px;
    }

    .slide-icon-box img{
        width:40px;
        height:40px;
    }

    .slider-btn{
        width:32px;
        height:32px;
        font-size:20px;
        opacity:.95;
    }

    /* Servicios mobile en 2 columnas */
    .services-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:8px;
    }


    .service-card{
    min-height:120px !important;   /* evita cajas gigantes pero mantiene uniformidad */
    padding:10px 8px 10px;
    display:flex;                  /* vuelve al layout vertical */
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    }

    .service-icon{
  margin-bottom:6px;
  width:auto;
  height:auto;
  display:block;
}

.service-icon img{
  width:36px;
  height:36px;
  object-fit:contain;
  margin-left:0;
}

.service-card p{
  font-size:12px;
  line-height:1.15;
  margin:0;
  max-width:100%;
}

    .toggle-services-btn{
        min-width:145px;
        height:30px;
    }

    .contact-title h2{
        font-size:26px;
    }

    .fake-form button{
        width:80%;
    }

    /* Footer / contacto mobile */
.contact-wrap{
  grid-template-columns:1fr !important;
  gap:14px;
  padding:18px 12px 22px;
  max-width:100%;
  margin-inline:auto;
  justify-content:stretch;
}

.contact-title{
  justify-content:flex-start;   /* o center si lo prefieres centrado */
  align-items:flex-start;
  width:100%;
  padding-right:0;
}

.contact-title h2{
  max-width:220px;
  font-size:24px;
  line-height:0.98;
  text-align:left;
  margin:0;
}

.contact-form-box{
  width:100%;
  max-width:100%;
  justify-self:stretch;
  padding:14px 12px;
}

.fake-form{
  gap:8px;
}

.fake-form input{
  height:30px;
  font-size:13px;
}

.fake-form button{
  width:78%;
  height:28px;
  font-size:12px;
}

.contact-title h2 br {
    display: none;
}
    }

    /* Reduce motion */
    @media (prefers-reduced-motion: reduce){
    .slide{
        transition:none;
    }
    .slider-btn,
    .toggle-services-btn{
        transition:none;
    }
    }

    /* ==========================================
   DataCrush FORZADO (2 columnas desktop/tablet)
   Pegar al FINAL del CSS
========================================== */

/* Contenedor */
.contact-form-box #datacrush-form-wrapper,
.contact-form-box #z-form-container{
  width:100% !important;
  min-height:0 !important;
}

/* FORM GRID */
.contact-form-box #z-form-container form.z-form-horizontal{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  column-gap:14px !important;
  row-gap:10px !important;
  align-items:start !important;
  width:100% !important;
  margin:0 !important;
}

/* Reset fieldsets */
.contact-form-box #z-form-container form.z-form-horizontal > fieldset.z-fieldset{
  display:block !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  min-width:0 !important;
  width:auto !important;
}

/* Wrappers internos */
.contact-form-box #z-form-container .z-control-group,
.contact-form-box #z-form-container .z-controls{
  margin:0 !important;
  padding:0 !important;
  width:100% !important;
}

/* Labels */
.contact-form-box #z-form-container .z-label{
  display:block !important;
  margin:0 0 4px !important;
  font-family:'Roboto', sans-serif !important;
  font-weight:700 !important;
  font-size:12px !important;
  line-height:1.2 !important;
  color:#1f1f1f !important;
}

/* Inputs */
.contact-form-box #z-form-container .z-form-control{
  display:block !important;
  width:100% !important;
  height:30px !important;
  padding:0 10px !important;
  border:1px solid #d5d5d5 !important;
  border-radius:0 !important;
  background:#f6f6f6 !important;
  color:#444 !important;
  font-family:'Montserrat', Arial, sans-serif !important;
  font-size:13px !important;
  outline:none !important;
  box-shadow:none !important;
  float:none !important;
}

/* Bloques de ayuda */
.contact-form-box #z-form-container .z-help-block{
  margin:0 !important;
  min-height:0 !important;
  line-height:1 !important;
  display:block !important;
}

/* Campo 5 (¿Cómo podemos ayudarte?) full width */
.contact-form-box #z-form-container #fieldset_street_number{
  grid-column:1 / -1 !important;
}

/* Botón full width row */
.contact-form-box #z-form-container .z-control-button{
  grid-column:1 / -1 !important;
  margin:4px 0 0 !important;
  padding:0 !important;
  width:100% !important;
}

/* Botón estilo */
.contact-form-box #z-form-container .z-control-button .z-btn,
.contact-form-box #z-form-container .z-control-button .z-btn-primary,
.contact-form-box #z-form-container .z-control-button #btnFormSend{
  display:inline-block !important;
  height:28px !important;
  min-width:140px !important;
  padding:0 18px !important;
  border:none !important;
  border-radius:999px !important;
  background:#0f9dbc !important;
  color:#fff !important;
  font-family:'Montserrat', Arial, sans-serif !important;
  font-size:12px !important;
  font-weight:500 !important;
  cursor:pointer !important;
  box-shadow:none !important;
  line-height:28px !important;
}

/* Mobile: volver a 1 columna */
@media (max-width: 480px){
  .contact-form-box #z-form-container form.z-form-horizontal{
    grid-template-columns:1fr !important;
    row-gap:8px !important;
  }

  .contact-form-box #z-form-container #fieldset_street_number,
  .contact-form-box #z-form-container .z-control-button{
    grid-column:auto !important;
  }

  .contact-form-box #z-form-container .z-label{
    font-size:12px !important;
    margin-bottom:3px !important;
  }

  .contact-form-box #z-form-container .z-form-control{
    height:30px !important;
    font-size:13px !important;
  }

  .contact-form-box #z-form-container #btnFormSend{
    width:78% !important;
    min-width:0 !important;
  }
}

/* =========================
   Footer legal (barra final)
========================= */
.legal-footer{
  background:#3f3f3f;                 /* gris oscuro como referencia */
}

.legal-footer__inner{
  min-height:54px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  padding:8px 12px;
  text-align:center;
}

.legal-footer__inner p{
  margin:0;
  color:#fff;
  font-family:'Montserrat', Arial, sans-serif;
  font-size:12px;
  line-height:1.05;
  font-weight:500;
  opacity:.95;
}

@media (max-width: 480px){
  .legal-footer__inner{
    min-height:auto;
    padding:8px 10px 10px;
    gap:4px;
  }

  .legal-footer__inner p{
    font-size:10px;
    line-height:1.15;
  }
}