 :root{
      --cyan: #00BCD4;
      --cyan-2: #E6FAFD;
      --ink: #0B1F2A;
      --muted: #5B6B73;
      --border: #E9EEF1;
    }
    body{ color: var(--ink); background: #fff; }
    .text-muted-2{ color: var(--muted); }

    .btn-cta{
      background: var(--cyan);
      color: #001319;
      border: 1px solid rgba(0,0,0,.04);
      font-weight: 600;
      border-radius: 999px;
      padding: .6rem 1rem;
    }
    .btn-cta:hover{ filter: brightness(0.97); }
    .btn-ghost{
      border-radius: 999px;
      border: 1px solid var(--border);
      font-weight: 600;
      padding: .6rem 1rem;
    }

    .hero{
      position: relative;
      overflow: hidden;
      border-bottom: 1px solid var(--border);
    }
    /* .hero::before{
      content:"";
      position:absolute; inset:0;
      background:
        linear-gradient(90deg, rgba(0,188,212,.18), rgba(0,188,212,.05) 60%, rgba(255,255,255,0) 100%),
        url("<?= h($hero_img) ?>") center/cover no-repeat;
    } */
    .hero .hero-inner{
      position:relative;
      padding: 5.5rem 0 4.5rem;
    }
    .hero-card{
      background: rgba(255,255,255,.92);
      border: 1px solid var(--border);
      border-radius: 1.25rem;
      padding: 2rem;
      box-shadow: 0 10px 30px rgba(0,0,0,.06);
      backdrop-filter: blur(4px);
    } 

    .section{ padding: 4rem 0; }
    .section-cyan{ background: var(--cyan-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .kpi{
      border: 1px solid var(--border);
      border-radius: 1rem;
      background:#fff;
      padding: 1rem 1.25rem;
      height: 100%;
    }
    .icon-pill{
      width: 44px; height: 44px;
      border-radius: 999px;
      background: rgba(0,188,212,.18);
      display:flex; align-items:center; justify-content:center;
      font-weight: 800;
      color:#003542;
      flex: 0 0 auto;
    }
    .card-soft{
      border: 1px solid var(--border);
      border-radius: 1.25rem;
      background: #fff;
      height: 100%;
    }
    .card-soft .card-body{ padding: 1.25rem; }
    .badge-cyan{
      background: rgba(0,188,212,.18);
      color:#003542;
      border: 1px solid rgba(0,188,212,.25);
      font-weight: 600;
    }

  .hero-image-wrapper{
  background: #fff;
  border-radius: 1.25rem;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}

.hero-image{
  width: 100%;
  height: auto;
  display: block;
}

/* Ajustes responsive */
@media (max-width: 991px){
  .hero{
    padding-bottom: 2rem;
  }
}

    .hero::before{
  background:
    linear-gradient(180deg,
      rgba(0,188,212,.22),
      rgba(0,188,212,.10) 60%,
      rgba(255,255,255,0) 100%
    );   
} */

/* CTA over image: text ALWAYS on top (right) */
.cta-over{
  padding: 0;
}

.cta-over-wrap{
  position: relative;
  border-radius: 1.5rem;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 16px 36px rgba(0,0,0,.10);

  /* Background image */
  background-size: cover;
  background-repeat: no-repeat;
  background-position: left center;

  /* Height of the CTA block */
  min-height: 360px;
}

/* Overlay to ensure readability */
.cta-over-overlay
{
  position: absolute;
  inset: 0;

  display: flex;
  align-items: center;
  justify-content: flex-end; /* RIGHT */

  padding: 2rem;

  /* Right-side readable panel effect */
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0.00) 30%,
    rgba(255,255,255,0.85) 70%
  );
}

.cta-over-content{
  max-width: 520px;
}

/* Mobile: center content and increase overlay opacity */
@media (max-width: 768px){
  .cta-over-wrap{
    min-height: 420px;
    background-position: center;
  }

  .cta-over-overlay{
    justify-content: center;
    padding: 1.25rem;
    background: rgba(255,255,255,.90);
  }

  .cta-over-content{
    max-width: 100%;
    text-align: center !important;
  }

  .cta-over-content .d-flex{
    justify-content: center !important;
  }
}

/* Footer social buttons */
.footer-social .social-btn{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  background: #fff;
  transition: all .2s ease;
}

.footer-social .social-btn svg{
  fill: currentColor;
}

.footer-social .social-btn:hover{
  color: #003542;
  border-color: rgba(0,188,212,.6);
  background: rgba(0,188,212,.12);
}

 .hero .hero-inner {
    position: relative;
    padding: 2rem 0 2rem;
} 

element.style {
background-color: #7a7e7e;
}





