:root{
  --bg:#070b0f;
  --bg2:#0a1016;
  --fg:#eaf2f7;
  --muted:rgba(234,242,247,.72);

  --green:#10A060;
  --orange:#E09030;

  --card:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.12);
  --shadow: 0 20px 60px rgba(0,0,0,.55);

  --max:1200px;
  --radius:26px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--fg);
}
a{text-decoration:none;color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ================= NAV ================= */

.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  background:linear-gradient(to bottom, rgba(7,11,15,.92), rgba(7,11,15,.35));
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.nav__inner{
  height:78px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

.brand{
  position:absolute;
  left:24px;
}

.brand__logo{
  height:70px;
  width:auto;
  display:block;
}

.menu{
  display:flex;
  gap:32px;
  font-size:14px;
  opacity:.9;
}

.menu a{
  padding:8px 6px;
  border-radius:10px;
  transition:.2s ease;
}

.menu a:hover{
  color:var(--green);
  background:rgba(16,160,96,.08);
}

/* ================= HERO ================= */

.hero{
  height:100vh;
  display:flex;
  align-items:flex-end;
  padding-top:100px;
  position:relative;
  overflow:hidden;
}

.hero__bg{
  position:absolute;
  inset:0;
  background-image:url("img/hero.jpg");
  background-size:cover;
  background-position:center;
  filter: brightness(1.05) contrast(1.05) saturate(1.15);
  transform:scale(1.03);
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.65), rgba(0,0,0,.25));
}

.hero__inner{
  position:relative;
  z-index:2;
  padding:60px 0 140px;
  margin-left:50px;
}

.hero h1{
  font-size:clamp(42px, 4.5vw, 70px);
  line-height:1.02;
  letter-spacing:-1px;
  text-transform:uppercase;
  max-width:900px;
}

.lead{
  margin-top:20px;
  font-size:17px;
  max-width:700px;
  color:var(--muted);
}

/* ================= SECTIONS ================= */

.section{
  padding:100px 0;
}

.section--soft{
  background:var(--bg2);
}

h2{
  font-size:clamp(32px, 3.2vw, 46px);
  margin-bottom:16px;
  line-height:1.10; 
}

.muted{color:var(--muted)}

.grid-2{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:40px;
}

/* ================= METRICS ================= */

.card{
  background:var(--card);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:22px;
}

.metrics{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.metric{
  padding:18px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}

.metric__value{
  font-size:34px;
  font-weight:900;
  color:var(--green);
}

.metric__label{
  font-size:13px;
  margin-top:6px;
  color:var(--muted);
}

/* ================= SECTORES NUEVO ESTILO ================= */

.sector-grid{
  margin-top:40px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

/* Card base */
.sector-tile{
  position:relative;
  min-height:440px;
  border-radius:32px;
  overflow:hidden;

  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);

  transition:.3s ease;
  will-change:transform;

  /* FLIP (sin tocar HTML) */
  perspective:1000px;
  transform-style:preserve-3d;

  /* la imagen ahora va en ::before */
  background:none;
}

/* Cara frontal = imagen */
.sector-tile::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;

  background:var(--bg) center/cover no-repeat;

  backface-visibility:hidden;
  transform:rotateY(0deg);
  z-index:0;

  pointer-events:none;
}

/* Cara trasera = negro */
.sector-tile::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;

  background:#000;

  backface-visibility:hidden;
  transform:rotateY(180deg);
  z-index:1;

  pointer-events:none;
}

/* Contenido (aparece al hover, y se oculta cuando está flip) */
.sector-tile__content{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;

  opacity:0;
  transform:translateY(14px);
  transition:opacity .35s ease, transform .35s ease;

  backface-visibility:hidden;
}

/* Hover: mostrar texto */
.sector-tile:hover .sector-tile__content{
  opacity:1;
  transform:translateY(0);
}

/* Si está girada, no mostramos el texto (evita “cosas raras” visuales) */
.sector-tile.is-flipped .sector-tile__content{
  opacity:0 !important;
  transform:translateY(14px) !important;
}

/* ===== SOMBREADO INFERIOR SOLO EN HOVER ===== */
/* Aparece junto con el texto para mejorar lectura */

.sector-tile__content{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;

  opacity:0;
  transform:translateY(14px);
  transition:opacity .35s ease, transform .35s ease;

  backface-visibility:hidden;

  /* 👇 agregado: para que el pseudo-elemento se posicione bien */
  position:absolute;
}

/* Capa de sombreado (solo abajo) */
.sector-tile__content::before{
  content:"";
  position:absolute;
  left:-24px;
  right:-24px;
  bottom:-24px;
  height:170px;

  background:linear-gradient(
    to top,
    rgba(0,0,0,.75) 0%,
    rgba(0,0,0,.45) 45%,
    rgba(0,0,0,0) 100%
  );

  opacity:0;
  transition:opacity .35s ease;
  z-index:-1;
  pointer-events:none;

  border-bottom-left-radius:32px;
  border-bottom-right-radius:32px;
}

/* Mostrar texto */
.sector-tile:hover .sector-tile__content{
  opacity:1;
  transform:translateY(0);
}

/* Mostrar sombreado SOLO cuando aparece el texto */
.sector-tile:hover .sector-tile__content::before{
  opacity:1;
}

.sector-tile:hover .sector-tile__content::before{
  opacity:1;
}

/* 🚫 Cuando está flip, nunca mostrar sombreado */
.sector-tile.is-flipped .sector-tile__content::before{
  opacity:0 !important;
  display:none !important;
}

/* Tipografía + legibilidad */
.sector-tile h3{
  position:relative;
  font-size:20px;
  margin-bottom:6px;
  padding-left:14px;
  color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,.65);
}

.sector-tile h3::before{
  content:"";
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  width:4px;
  height:1.2em;
  background:var(--green);
  border-radius:999px;
}

/* ===== FLIP SIN ESPEJO (solo giran las caras) ===== */

.sector-tile{
  position:relative;
  min-height:440px;
  border-radius:32px;
  overflow:hidden;

  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);

  perspective:1000px;
  background:none;

  /* hover suave */
  transition:transform .3s ease, filter .3s ease;
  will-change:transform;
}

/* CARAS */
.sector-tile::before,
.sector-tile::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  backface-visibility:hidden;
  transform-style:preserve-3d;
  transition:transform .7s cubic-bezier(.4,.2,.2,1);
  pointer-events:none;
}

/* Frente = imagen */
.sector-tile::before{
  background:var(--bg) center/cover no-repeat;
  transform:rotateY(0deg) translateZ(1px);
}

/* Dorso = negro */
.sector-tile::after{
  background:#000;
  transform:rotateY(180deg) translateZ(1px);
}

/* Cuando está flip: intercambiamos las caras */
.sector-tile.is-flipped::before{
  transform:rotateY(180deg) translateZ(1px);
}
.sector-tile.is-flipped::after{
  transform:rotateY(0deg) translateZ(1px);
}
  transition:opacity .35s ease, transform .35s ease;
}

/* Texto solo en hover cuando NO está flip */
.sector-tile:hover .sector-tile__content{
  opacity:1;
  transform:translateY(0);
}
.sector-tile.is-flipped .sector-tile__content{
  opacity:0 !important;
  transform:translateY(14px) !important;
}

/* Hover */
.sector-tile:hover{
  transform:translateY(-6px);
  filter:brightness(1.05);
}

/* ================= TEXTO CARA TRASERA ================= */

/* Estilo base del texto atrás */
.sector-tile::after{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:40px;
  color:#fff;
  font-size:16px;
  line-height:1.6;
  font-weight:500;
}

/* 1 */
.sector-grid .sector-tile:nth-child(1)::after{
  content:"Distribución: cámaras de Media Tensión, subestaciones MT/BT, tendidos de líneas aéreas y cables subterráneos, subestaciones de alta tensión hasta 220 kV. Generación: montaje de generadores hasta 35 MW.";
}

/* 2 */
.sector-grid .sector-tile:nth-child(2)::after{
  content:"Plantas de Tratamiento y Estaciones de bombeo agua potable, agua cruda, cloacal. Soluciones contra golpe de ariete. Sistemas de transmisión de datos y control a distancia. Sistemas de velocidad variable.";
}

/* 3 */
.sector-grid .sector-tile:nth-child(3)::after{
  content:"Ingeniería de montaje, rediseño de puntos específicos e instalación de catenarias. Tendidos de alimentación MT.";
}

/* 4 */
.sector-grid .sector-tile:nth-child(4)::after{
  content:"Obras multidisciplinarias: montajes eléctricos (alta media y baja), obras mecánicas (cañerías, montajes de equipos, estructuras, piping, sistemas hidráulicos, izajes importantes – 200tn , 60 mts de altura-etc..) y electromecánicos (montaje de motores, comandos, alineación) construcciones civiles (estructuras, cámaras, cámaras enterradas, cisternas, caminos, excavaciones, movimiento de tierra.)";
}

/* 5 */
.sector-grid .sector-tile:nth-child(5)::after{
  content:"Automatismos industriales a base de PLC, sistemas de transmisión de datos y de monitoreo de instalaciones industriales y/o repartidas.\00000a\00000aEn particular, mantenimiento eléctrico en media y alta tensión, pero también mantenimiento integral especialmente en sectores conocidos como el agua y la energía.";
  display:block;
  white-space:pre-line !important;
  text-align:center;
  max-width:78%;
  margin:0 auto;
  padding-top:80px;
}

/* 6 */
.sector-grid .sector-tile:nth-child(6)::after{
  content:"Contamos con el deseo y el conocimiento para hacer de su problema nuestra mejor solución.";
}

/* ===== BOTÓN + (solo en flip, clickeable) ===== */

/* En flip, convertimos .sector-tile__content en botón circular */
.sector-tile.is-flipped .sector-tile__content{
  /* visible aunque no haya hover */
  opacity:1 !important;
  visibility:visible !important;

  /* posición abajo centrado */
  left:50% !important;
  right:auto !important;
  bottom:18px !important;
  top:auto !important;

  width:40px !important;
  height:40px !important;

  background:var(--green) !important;
  border-radius:50% !important;
  box-shadow:0 8px 22px rgba(0,0,0,.45) !important;

  display:flex !important;
  align-items:center !important;
  justify-content:center !important;

  padding:0 !important;
  text-shadow:none !important;

  z-index:5 !important;
  cursor:pointer !important;

  transform:translateX(-50%) !important;
}

/* Ocultamos el contenido normal del frente dentro del botón */
.sector-tile.is-flipped .sector-tile__content h3,
.sector-tile.is-flipped .sector-tile__content p,
.sector-tile.is-flipped .sector-tile__content .sector-tile__bar{
  display:none !important;
}

/* Dibujamos el + */
.sector-tile.is-flipped .sector-tile__content::after{
  content:"+";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -60%);
  font-size:22px;
  font-weight:800;
  line-height:1;
  color:#000;
}

/* Hover */
.sector-tile.is-flipped .sector-tile__content:hover{
  transform:translateX(-50%) scale(1.08) !important;
}

/* ================= STEPS ================= */

.steps{ 
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:22px; 
  margin-top:30px;
}

.step{ 
  border-radius:var(--radius); 
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04); 
  padding:20px;
}

.step span{ 
  display:inline-flex;
  width:38px; height:38px;
  border-radius:14px; align-items:center; 
  justify-content:center; 
  background:rgba(16,160,96,.15); 
  border:1px solid rgba(16,160,96,.35); 
  font-weight:900; 
  margin-bottom:10px; 
  margin-right:6px;
}

/* ================= FORM ================= */

.form label{
  display:block;
  font-size:13px;
  color:var(--muted);
  margin-bottom:14px;
}

input,textarea{
  width:100%;
  margin-top:6px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.14);
  color:var(--fg);
  padding:14px;
  border-radius:16px;
  outline:none;
}

input:focus,textarea:focus{
  border-color:rgba(16,160,96,.55);
}

.form button{
  margin-top:10px;
  width:100%;
}

/* ================= FOOTER ================= */

.footer{
  padding:40px 0;
  border-top:1px solid rgba(255,255,255,.08);
}

.footer__inner{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:20px;
}

/* ================= RESPONSIVE ================= */

@media (max-width:1100px){
  .sector-grid{
    grid-template-columns:1fr;
  }
  .grid-2{
    grid-template-columns:1fr;
  }
  .steps{
    grid-template-columns:1fr;
  }
  .menu{
    display:none;
  }
}

/* ================= FILOSOFÍA (solo esta sección) ================= */

/* corte visual para que no sea todo “de corrido” */
#filosofia.section{
  background: linear-gradient(180deg,
    rgba(255,255,255,.035) 0%,
    rgba(255,255,255,.015) 55%,
    rgba(0,0,0,0) 100%);
  position: relative;
  overflow: hidden;
}

/* líneas suaves arriba/abajo para marcar el cambio de sección */
#filosofia.section::before,
#filosofia.section::after{
  content:"";
  position:absolute;
  left:0; right:0;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  pointer-events:none;
}
#filosofia.section::before{ top:0; }
#filosofia.section::after{ bottom:0; }

/* card de introducción (la que ya tenés) */
#filosofia .card.philosophy{
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 26px 28px;
  box-shadow: 0 16px 55px rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
}

/* Si no existe .cards-3 global, lo definimos SOLO acá para no romper */
#filosofia .cards-3{
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

/* Tiles SOLO dentro de filosofía */
#filosofia .tile{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px;
  padding: 26px;
  box-shadow: 0 14px 45px rgba(0,0,0,.32);
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
  position: relative;
  overflow: hidden;
}

/* marca verde sutil, estilo GTMH */
#filosofia .tile::before{
  content:"";
  position:absolute;
  left:18px;
  top:26px;
  width:6px;
  height:22px;
  border-radius: 999px;
  background: var(--green);
  opacity: .95;
}

#filosofia .tile h3{
  font-size: 20px;
  margin: 0 0 12px 14px; /* deja lugar a la barrita */
}

#filosofia .tile p{
  line-height: 1.65;
}

/* hover premium */
#filosofia .tile:hover{
  transform: translateY(-6px);
  border-color: rgba(16,160,96,.45);
  background: rgba(255,255,255,.06);
}

/* Responsive: 1 columna */
@media (max-width:1100px){
  #filosofia .cards-3{
    grid-template-columns: 1fr;
  }
}


/* ================= CERTIFICACION ISO ================= */

.certificacion{
  padding:70px 0;
  background:#05090d;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}

.certificacion-header{
  text-align:center;
  margin-bottom:40px;
}

.certificacion-header h2{
  font-size:42px;
  position:relative;
  display:inline-block;
}

.certificacion-header h2::after{
  content:"";
  display:block;
  width:60px;
  height:3px;
  background:var(--green);
  margin:18px auto 0;
}

.certificacion-box{
  display:flex;
  align-items:center;
  gap:80px;
  background:rgba(255,255,255,.03);
  padding:40px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.06);
}

.certificacion-content p{
  color:rgba(234,242,247,.75);
  line-height:1.8;
  margin-bottom:18px;
}

.certificacion-beneficio{
  margin-top:25px;
  padding-left:20px;
  border-left:3px solid var(--green);
  color:var(--fg);
}

.certificacion-sello img{
  max-width:340px;
}
.form button{
  margin-top:20px;
  width:100%;
  padding:6px;
  border-radius:18px;
  border:1px solid rgba(16,160,96,.35);
  background:linear-gradient(135deg, rgba(16,160,96,.9), rgba(16,160,96,.6));
  color:#000;
  font-weight:700;
  letter-spacing:.5px;
  cursor:pointer;
  transition:.25s ease;
}

.form button:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 25px rgba(16,160,96,.35);
}

.form button:active{
  transform:translateY(0);
  box-shadow:none;
}

.whatsapp-float{
  position:fixed;
  bottom:25px;
  right:25px;
  width:60px;
  height:45px;
  z-index:1000;
}

.whatsapp-float img{
  width:100%;
  height:100%;
}

/* ================= CLIENTES ================= */

.clients{
  padding:30px 0;
  background:var(#000);
  border-top:1px solid var(--stroke);
  border-bottom:1px solid var(--stroke);
}

.clients-title{
  text-align:center;
  font-size:26px;
  margin-bottom:-30px;
  color:var(--fg);
  position:relative;
  display:inline-block;
  left:50%;
  transform:translateX(-50%);
}

.clients-title::after{
  content:"";
  display:block;
  width:60px;
  height:3px;
  background:var(--green);
  margin:12px auto 0;
  border-radius:2px;
}

.clients-logos{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:80px;
  flex-wrap:nowrap;
  margin-top:40px;
}

.clients-logos img{
  height:100px;
  width:auto;
  opacity:1;
  filter:none;
}

/* =========================
   ESPECIALISTAS EN AGUA
========================= */

.agua-carousel{
  padding: 90px 0;
  background:
    radial-gradient(circle at top, rgba(16,160,96,.08), transparent 35%),
    linear-gradient(180deg, #081019 0%, #070b0f 100%);
  overflow: hidden;
}

.agua-carousel .section-kicker{
  text-align: center;
  color: var(--muted);
  font-size: .95rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.agua-carousel .section-title{
  text-align: center;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1.1;
  margin-bottom: 20px;
}

.agua-carousel .section-title span{
  color: var(--green);
  position: relative;
}

.agua-carousel .section-title span{
  color: var(--green);
  position: relative;
  display: inline-block;
}

.agua-carousel .section-title span{
  color: var(--green);
  position: relative;
  display: inline-block;
  z-index: 1;
}

.agua-carousel .section-title .agua-word{
  color: var(--green);
}

.agua-carousel .section-title .agua-u{
  text-decoration: underline;
  text-decoration-color: var(--green);
  text-decoration-thickness: 4px;
  text-underline-offset: 6px;
}

.agua-carousel .section-title .agua-g{
  text-decoration: none;
}

.agua-carousel__intro{
  max-width: 900px;
  margin: 0 auto 42px;
  text-align: center;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.75;
}

.agua-slider{
  position: relative;
  width: 100%;
  padding: 0 72px;
}

.agua-slider__viewport{
  overflow: hidden;
  width: 100%;
}

.agua-slider__track{
  display: flex;
  gap: 18px;
  transition: transform .45s ease;
  will-change: transform;
}

.agua-slide{
  flex: 0 0 calc((100% - 36px) / 3);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(0,0,0,.32);
}

.agua-slide img{
  display: block;
  width: 100%;
  height: 320px;
  object-fit: cover;
}

.agua-slider__btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;

  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .25s ease;
  backdrop-filter: blur(6px);
}

.agua-slider__btn--prev{
  left: 0;
}

.agua-slider__btn--next{
  right: 0;
}

.agua-slider__btn:hover{
  background: var(--green);
  border-color: var(--green);
  transform: translateY(-50%) scale(1.06);
}

.agua-slider__dots{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 26px;
}

.agua-dot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,.28);
  cursor: pointer;
  transition: .25s ease;
}

.agua-dot.is-active{
  width: 28px;
  border-radius: 999px;
  background: var(--green);
}

@media (max-width: 1100px){
  .agua-slide{
    flex: 0 0 calc((100% - 18px) / 2);
  }

  .agua-slide img{
    height: 300px;
  }
}

@media (max-width: 768px){
  .agua-carousel{
    padding: 72px 0;
  }

  .agua-carousel__intro{
    font-size: 1rem;
    margin-bottom: 28px;
  }

  .agua-slider{
    padding: 0 56px;
  }

  .agua-slider__btn{
    width: 44px;
    height: 44px;
    font-size: 22px;
  }

  .agua-slide{
    flex: 0 0 100%;
  }

  .agua-slide img{
    height: 240px;
  }
}

@media (max-width: 560px){
  .agua-slider{
    padding: 0 44px;
  }

  .agua-slider__track{
    gap: 12px;
  }

  .agua-slide img{
    height: 220px;
  }
}

.agua-slide{
  position:relative;
  overflow:hidden;
}

.agua-slide{
  position:relative;
  overflow:hidden;
}

.agua-slide img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .35s ease;
}

.agua-slide__overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:22px;
  background:linear-gradient(
    to top,
    rgba(0,0,0,.78) 0%,
    rgba(0,0,0,.45) 18%,
    rgba(0,0,0,.12) 32%,
    rgba(0,0,0,0) 48%
  );
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
}

.agua-slide__overlay h3{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  line-height:1.15;
  color:#fff;
}

.agua-slide__overlay p{
  margin:0;
  font-size:14px;
  line-height:1.35;
  color:rgba(255,255,255,.88);
  max-width:90%;
}

.agua-slide:hover .agua-slide__overlay{
  opacity:1;
}

.agua-slide:hover img{
  transform:scale(1.04);
}

.agua-slide__overlay h3{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  line-height:1.15;
  color:#fff;

  display:flex;
  align-items:center;
  gap:10px;
}

.agua-slide__overlay h3::before{
  content:"";
  display:block;
  width:5px;
  height:22px;
  background:var(--green);
  border-radius:999px;
  flex:0 0 auto;
}