:root{--brand:#0ea5a0;--dark:#0b132b}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#334}
.navbar{box-shadow:0 6px 20px rgba(12,16,31,.06)}
@media (min-width: 992px){
  .navbar .dropdown:hover .dropdown-menu{ display:block; margin-top:0; }
}

/* Logo grande estilo referencia */
.brand-logo{
  height: 64px;           /* prueba 64–72px según tu arte */
  width: auto;
}
.brand-text{
  font-weight: 700;
}

/* Menú centrado en mayúsculas tipo referencia */
.nav-upper{
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
}

/* Hover abre dropdown en desktop */
@media (min-width: 992px){
  .navbar .dropdown:hover .dropdown-menu{ display:block; margin-top:0; }
}

/* Banderita simple (puedes cambiar a un ícono real si quieres) */
.flag{
  display:inline-block; width:18px; height:12px; border:1px solid #ddd; border-radius:2px; overflow:hidden;
  background:#b22234; position:relative;
}
.flag-us::before{
  content:""; position:absolute; left:0; top:0; width:40%; height:55%;
  background:#3c3b6e;
}
.flag-us::after{
  content:""; position:absolute; left:0; top:0; width:100%; height:100%;
  background: repeating-linear-gradient(to bottom, rgba(255,255,255,.9) 0 6px, transparent 6px 12px);
  mix-blend-mode: screen;
}

/* Ajuste responsive: logo más chico en móviles */
@media (max-width: 575.98px){
  .brand-logo{ height:48px; }
}
/* Tamaño base */
.brand-logo{ height:48px; transition:height .2s ease; }
@media (max-width: 575.98px){ .brand-logo{ height:43px; } }

/* Cuando la barra está scrolleada */
.navbar.navbar-shrink .brand-logo{ height:43px; }
/* Mostrar solo el logo (oculta texto de marca) */
.brand-text{ display:none !important; }

/* Tamaño ideal del logo */
.brand-logo{ height:56px; width:auto; }

/* Ajustes por breakpoint */
@media (max-width: 991.98px){ .brand-logo{ height:50px; } }   /* tablet */
@media (max-width: 575.98px){ .brand-logo{ height:44px; } }   /* móvil */

/* Espaciado compactado en la izquierda */
.navbar-brand{ gap:10px !important; }
:root{ --brand:#0ea5a0; --dark:#0b132b; }

/* HERO con imagen + degradé */
.hero-ml{
  position:relative;
  background:
    linear-gradient(180deg, rgba(11,19,43,.66), rgba(11,19,43,.45)),
    url('https://images.unsplash.com/photo-1509099836639-18ba1795216d?q=80&w=1600&auto=format&fit=crop') center/cover no-repeat;
  color:#fff;
}
.hero-ml--lg{ padding:96px 0 88px; }
.hero-ml .badge.bg-white-25{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(6px);
}

/* Stats en el hero */
.hero-ml__stats .stat-num{
  font-weight:800; font-size:40px; line-height:1; color:var(--brand);
  background: rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.25);
  padding:10px 14px; border-radius:12px;
}
.hero-ml__stats .stat-label{ opacity:.9; margin-top:6px; }

/* Cards suaves */
.shadow-soft{ box-shadow:0 18px 40px rgba(0,0,0,.08); border:1px solid #edf2f7; }
.icon-badge{ width:56px;height:56px;border-radius:16px;background:#eef7f7;display:grid;place-items:center;color:var(--brand);font-size:24px }

/* Secciones */
.section{ padding:72px 0; }
.bg-soft{ background:#f7fbfb; }

/* Galería mosaico */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap:10px;
}
.gallery-grid img{
  width:100%; height:180px; object-fit:cover; border-radius:12px;
}
@media (max-width: 991.98px){
  .gallery-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 575.98px){
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }
  .gallery-grid img{ height:140px; }
}

/* Botón marca */
.btn-brand{ background:var(--brand); color:#fff; border:none; }
.btn-brand:hover{ background:#0b8f8b; color:#fff; }
.text-brand{ color:var(--brand)!important; }
/* HERO local (si ya usas otro, omite esta sección) */
.hero-local{
  padding: 96px 0 88px;
  color:#fff;
  background:
    linear-gradient(180deg,rgba(11,19,43,.66),rgba(11,19,43,.45)),
    url('https://images.unsplash.com/photo-1509099836639-18ba1795216d?q=80&w=1600&auto=format&fit=crop')
    center/cover no-repeat;
}

/* Secciones y helpers */
.section{ padding:72px 0; }
.bg-soft{ background:#f7fbfb; }
.shadow-lg-soft{ box-shadow:0 30px 80px rgba(0,0,0,.12); }
.icon-badge{ width:56px;height:56px;border-radius:16px;background:#eef7f7;display:grid;place-items:center;color:var(--brand);font-size:24px }

/* Franjas diagonales tipo referencia */
.angle-top{ position: relative; }
.angle-top::before{
  content:""; position:absolute; left:0; right:0; top:-60px; height:120px; transform:skewY(-4deg);
  transform-origin: 100% 0; z-index:-1;
}
.angle-brand{ background: var(--brand); }
.angle-brand::before{ background: var(--brand); }
.angle-light{ background: #e6f4f3; }
.angle-light::before{ background: #e6f4f3; }

/* Botón marca */
.btn-brand{ background:var(--brand); color:#fff; border:none; }
.btn-brand:hover{ background:#0b8f8b; color:#fff; }
.text-brand{ color:var(--brand)!important; }
:root{ --brand:#0ea5a0; --dark:#0b132b; }

/* -------- HERO POWER -------- */
.hero-x{ position:relative; min-height:86vh; display:grid; align-items:end; background:#000; overflow:hidden; }
.hero-x__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.55; }
.hero-x__overlay{ position:absolute; inset:0;
  background: radial-gradient(60% 60% at 50% 40%, rgba(10,18,40,.1), rgba(10,18,40,.7)),
              linear-gradient(180deg, rgba(10,18,40,.0) 0%, rgba(10,18,40,.65) 100%);
}
.hero-x__content{ position:relative; padding:120px 0 80px; z-index:2; }
.hero-x__badge{ background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(6px); }
.hero-x__stats .kpi{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.25); padding:14px; border-radius:14px; }
.kpi__num{ font-size:40px; font-weight:800; color:var(--brand); line-height:1; display:block; }
.kpi__label{ opacity:.9; font-weight:500; }
.hero-x__wave{ position:absolute; bottom:-1px; left:0; right:0; }

/* -------- Secciones -------- */
.section{ padding:72px 0; }
.bg-soft{ background:#f7fbfb; }
.icon-badge{ width:56px;height:56px;border-radius:16px;background:#eef7f7;display:grid;place-items:center;color:var(--brand);font-size:24px }
.shadow-lg-soft{ box-shadow:0 30px 80px rgba(0,0,0,.12); }
.card-raise{ border:1px solid #edf2f7; transition:.25s; }
.card-raise:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.08); }

/* Tiers */
.tier__amt{ font-size:42px; font-weight:800; color:var(--brand); margin-bottom:6px; }

/* Testi */
.testi{ max-width:760px; background:#fff; border:1px solid #eef2f7; padding:26px; border-radius:16px; box-shadow:0 18px 40px rgba(0,0,0,.06); }
.testi__meta{ margin-top:10px; color:#6b7280; font-weight:600; }

/* Franjas diagonales */
.angle-top{ position:relative; }
.angle-top::before{ content:""; position:absolute; left:0; right:0; top:-60px; height:120px; transform:skewY(-4deg); transform-origin:100% 0; z-index:-1; }
.angle-brand{ background:var(--brand); }
.angle-brand::before{ background:var(--brand); }
.angle-light{ background:#e6f4f3; }
.angle-light::before{ background:#e6f4f3; }

/* Botón marca */
.btn-brand{ background:var(--brand); color:#fff; border:none; }
.btn-brand:hover{ background:#0b8f8b; color:#fff; }
.text-brand{ color:var(--brand)!important; }

/* Marquee */
.marquee{ display:flex; gap:48px; align-items:center; overflow:hidden; }
.marquee img{ height:36px; opacity:.8; filter:grayscale(1); }
@media (prefers-reduced-motion: no-preference){
  .marquee{ animation:scrollX 24s linear infinite; }
  @keyframes scrollX{ from{ transform:translateX(0) } to{ transform:translateX(-50%) } }
}
/* HERO robusto: admite video o imagen */
.hero-x{ position:relative; min-height:86vh; display:grid; align-items:end; background:#000; overflow:hidden; }
.hero-x__video, .hero-x__image{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-x__image{ background-position:center; background-size:cover; }
.hero-x__overlay{ position:absolute; inset:0;
  background: radial-gradient(60% 60% at 50% 40%, rgba(10,18,40,.1), rgba(10,18,40,.7)),
              linear-gradient(180deg, rgba(10,18,40,.0) 0%, rgba(10,18,40,.65) 100%);
}
.hero-x__content{ position:relative; padding:120px 0 80px; z-index:2; color:#fff; }
.hero-x__badge{ background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(6px); }
.hero-x__stats .kpi{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.25); padding:14px; border-radius:14px; }
.kpi__num{ font-size:40px; font-weight:800; color:var(--brand); line-height:1; display:block; }
.kpi__label{ opacity:.9; font-weight:500; }
.hero-x__wave{ position:absolute; bottom:-1px; left:0; right:0; }
.section{ padding:72px 0; }
.bg-soft{ background:#f7fbfb; }
.icon-badge{ width:56px;height:56px;border-radius:16px;background:#eef7f7;display:grid;place-items:center;color:var(--brand);font-size:24px }
.shadow-lg-soft{ box-shadow:0 30px 80px rgba(0,0,0,.12); }
.card-raise{ border:1px solid #edf2f7; transition:.25s; }
.card-raise:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.08); }
.btn-brand{ background:var(--brand); color:#fff; border:none; }
.btn-brand:hover{ background:#0b8f8b; color:#fff; }
.text-brand{ color:var(--brand)!important; }
#mission .rounded-4{ border-radius:18px; }
#values .card-raise{ border:1px solid #edf2f7; transition:.25s; }
#values .card-raise:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.08); }
/* Franjas diagonales suaves */
.angle-top{ position:relative; }
.angle-top::before{ content:""; position:absolute; left:0; right:0; top:-60px; height:120px; transform:skewY(-4deg); transform-origin:100% 0; z-index:-1; }
.angle-light{ background:#e6f4f3; }
.angle-light::before{ background:#e6f4f3; }

/* Tarjetas y badges */
.card-raise{ border:1px solid #edf2f7; transition:.25s; }
.card-raise:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.08); }
.icon-badge{ width:56px;height:56px;border-radius:16px;background:#eef7f7;display:grid;place-items:center;color:var(--brand);font-size:24px }
.shadow-lg-soft{ box-shadow:0 30px 80px rgba(0,0,0,.12); }
.about-band {
  --about-blue: #0b78c6; /* ajusta a tu tono */
  background: var(--about-blue);
  overflow: hidden;
}
.about-band__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: .12; /* sutil; quita si no usas imagen */
}
.about-band__angle-top,
.about-band__angle-bottom {
  position: absolute; left: 0; right: 0; color: #0b78c6;
}
.about-band__angle-top  { top:  -1px; height: 80px; }
.about-band__angle-bottom { bottom: -1px; height: 80px; }
.about-band__angle-top svg,
.about-band__angle-bottom svg { width: 100%; height: 100%; display: block; }
.hero-slogan__top{
  display:inline-block;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.9rem;
  padding:.35rem .75rem;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  backdrop-filter:saturate(140%) blur(2px);
}

.hero-slogan__bottom{
  margin: .75rem 0 0 0;
  font-weight:900;
  line-height:1.1;
  font-size: clamp(2.2rem, 4.6vw, 3.5rem);
  text-shadow: 0 6px 24px rgba(0,0,0,.35);
}

@media (min-width: 992px){
  .hero-slogan__bottom{ font-size: clamp(3rem, 4.8vw, 4rem); }
}
/* Sección Misión / Visión */
.section-mv{
  --mv-bg: linear-gradient(180deg,#eef7f9 0%, #f7fbfd 100%);
  background: var(--mv-bg);
  padding-top: 56px;
  padding-bottom: 72px; /* evita el blanco inferior */
}

/* Grid de imágenes: 2 tarjetas iguales */
.mv-media{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.mv-card{
  position: relative;
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(0,0,0,.12);
  background: #e9eef2;
  /* asegura misma altura sin distorsionar */
  aspect-ratio: 16 / 10;         /* navegadores modernos */
}

/* Soporte para navegadores sin aspect-ratio */
@supports not (aspect-ratio: 1/1) {
  .mv-card::before{
    content:"";
    display:block;
    padding-top:62.5%; /* 10/16 = 0.625 */
  }
  .mv-card > img{
    position:absolute; inset:0;
  }
}

.mv-card > img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}

.mv-card:hover > img{ transform: scale(1.03); }

/* En pantallas pequeñas: apila imágenes */
@media (max-width: 991.98px){
  .mv-media{ grid-template-columns: 1fr; }
}
/* Bloques split de Misión/Visión */
.split-mv{
  --bg1: #eef7f9;
  --bg2: #f7fbfd;
  background: linear-gradient(180deg,var(--bg1) 0%, var(--bg2) 100%);
  padding-top: 64px;
  padding-bottom: 72px;
  border-top: 1px solid rgba(0,0,0,.04);
}
.split-mv.alt{
  /* sutil variación para el segundo bloque */
  --bg1: #f7fbfd;
  --bg2: #ffffff;
}

/* Tarjeta de imagen grande, uniforme */
.mv-split-card{
  position: relative;
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 14px 36px rgba(0,0,0,.12);
  background:#e9eef2;
  aspect-ratio: 16/9;            /* altura uniforme sin distorsión */
}
@supports not (aspect-ratio: 1/1){
  .mv-split-card::before{ content:""; display:block; padding-top:56.25%; }
  .mv-split-card > img{ position:absolute; inset:0; }
}
.mv-split-card > img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition: transform .6s ease;
}
.mv-split-card:hover > img{ transform: scale(1.035); }

@media (max-width: 991.98px){
  /* en móvil: imagen arriba, texto abajo con más aire */
  .split-mv{ padding-top:48px; padding-bottom:56px; }
}
.card .text-muted{
  display:-webkit-box;
  -webkit-line-clamp:6;          /* número de líneas visibles */
  -webkit-box-orient:vertical;
  overflow:hidden;
}
/* ELIMINAR si existe */
.card .text-muted{
  display:-webkit-box;
  -webkit-line-clamp:6;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
<style>
  .values-alt { background: linear-gradient(180deg, #f5f9fc 0%, #ffffff 100%); }
  .value-card  { background:#fff; border-radius:24px; box-shadow:0 10px 30px rgba(0,0,0,.06); overflow:hidden; }
  .value-img   { min-height:280px; background-size:cover; background-position:center; }
  .value-body  { padding:28px; }
  .value-kicker{ font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:#0b79d0; font-weight:700; }
  @media (min-width:992px){
    .value-img { min-height:100%; }
  }
</style>
<style>
  .partners-band { background: linear-gradient(180deg,#f7fbff 0,#fff 100%); }
  .partners-card { background:#fff;border-radius:24px;box-shadow:0 12px 32px rgba(0,0,0,.07); overflow:hidden; }
  .partners-img  { width:100%;height:320px;object-fit:cover; }
  .pill { display:inline-block;padding:.35rem .75rem;border-radius:999px;background:#eef6ff;color:#0b79d0;font-weight:600;font-size:.83rem }
  .logo-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:16px }
  .logo-grid .logo { background:#fff;border-radius:16px;padding:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.06);filter:grayscale(100%);opacity:.8;transition:.2s }
  .logo-grid .logo:hover{ filter:none; opacity:1 }
  .gallery-tiles { display:grid;grid-template-columns:repeat(4,1fr);gap:10px }
  .gallery-tiles div{ padding-top:70%;position:relative;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.08)}
  .gallery-tiles div span{ position:absolute;inset:0;background-size:cover;background-position:center }
  @media (max-width:991.98px){
    .logo-grid{ grid-template-columns:repeat(2,1fr) }
    .gallery-tiles{ grid-template-columns:repeat(2,1fr) }
  }
</style>
.content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: .75rem 0;
  display: block;
}
/* 1) Mantén font-weight estable en todo momento */
.navbar .nav-link,
.navbar .dropdown-item {
  font-weight: 600;        /* o 500, pero MISMO en hover */
}
.navbar .nav-link:hover,
.navbar .nav-link:focus,
.navbar .dropdown-item:hover {
  font-weight: 600;        /* evita pasar a bold en hover */
}

/* 2) Subrayado sin cambiar alto con pseudo-elemento */
.navbar .nav-link {
  position: relative;
}
.navbar .nav-link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px;   /* fuera del flujo */
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .2s ease;
}
.navbar .nav-link:hover::after,
.navbar .nav-link:focus::after {
  transform: scaleX(1);
}

/* 3) Reserva espacio de scrollbar para que no “salte” el layout */
:root { scrollbar-gutter: stable; }
/* fallback (si algún navegador no soporta lo de arriba) */
/* html { overflow-y: scroll; } */

/* Transición suave del navbar y altura estable */
.navbar { transition: padding .2s ease, box-shadow .2s ease; }
.navbar .nav-link { border-bottom: 2px solid transparent; }
.navbar .nav-link:hover { border-bottom-color: currentColor; }

