/* ===== Paleta ===== */
:root{
  --c-azul:#00247d;
  --c-verde:#008923;
  --c-verde-text:#75d48d;
  --c-rojo:#cf142b;
  --c-copy:#031633;
  --c-accent:#3ead3c;  
  --ease: cubic-bezier(.4,0,.2,1);
  --docs-bg: #eef3f9;      /* fondo de la sección */
  --docs-blue: #00247d;    /* azul del botón */
  --docs-badge: #cf142b;   /* rojo del badge */
  --docs-ink: #0b1220;
  --docs-muted: #1c2740;
  --wj-dark:#2b303a;     /* tabs inactivos */
  --wj-green:#008923;    /* tab activo */
  --wj-tabs-h: 68px;     /* altura aprox de la barra (para reservar espacio) */
  --ink:#0b1220;
   --bs-font-sans-serif: 'Montserrat', system-ui, -apple-system, 'Segoe UI',
                        Roboto, 'Helvetica Neue', Arial, 'Noto Sans', 'Liberation Sans', sans-serif;
}
html, body{ font-family: var(--bs-font-sans-serif) !important; }
/* ===== Topbar ===== */
.topbar-blue{height:12px;background:var(--c-azul);}
.topbar-red{height:12px;background:var(--c-rojo);}
.topbar-green{background:var(--c-verde);color:#fff;padding-top:1px;padding-bottom:1px}
.topbar-green .link-inverse{color:#fff;text-decoration:none;opacity:.95}
.topbar-green .link-inverse:hover{opacity:1;text-decoration:underline}

.social-icons .nav-link{color:#fff;opacity:.9;padding:.25rem .5rem;font-size:1.05rem}
.social-icons .nav-link:hover{opacity:1}

/* ===== Navbar ===== */
.navbar .nav-link{font-weight:500}
.navbar .nav-link.active{color:var(--c-verde)}

/* ===== Botón Contacto (radios opuestos y sin .btn de Bootstrap) ===== */
.btn-contacto{
  display:inline-block;
  background:var(--c-verde);
  color:#fff;
  padding:.6rem 1.25rem;
  font-weight:600;
  border:0;
  border-top-left-radius:24px;
  border-bottom-right-radius:24px;
  border-top-right-radius:8px;
  border-bottom-left-radius:8px;
  transition:transform .15s ease, box-shadow .15s ease, background-color .15s ease;
  text-decoration:none;
}
.btn-contacto:hover{color:#fff;background:#0a7a26;transform:translateY(-1px);box-shadow:0 .3rem .8rem rgba(0,0,0,.12)}
.btn-contacto:active{transform:translateY(0)}

/* ===== Botón circular “ventana” ===== */
.app-window-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.app-window-btn .win-outer{
  width:56px;height:56px;border-radius:50%;
  border:3px solid #c9c9c9;display:grid;place-items:center;background:#fff
}
.app-window-btn .win-inner{
  width:44px;height:44px;border-radius:50%;background:var(--c-verde);
  display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);
  gap:6px;padding:8px
}
.app-window-btn .pane{background:#fff;display:block}
.app-window-btn .pane.tl{border-top-left-radius:10px}
.app-window-btn .pane.tr{border-top-right-radius:10px}
.app-window-btn .pane.bl{border-bottom-left-radius:10px}
.app-window-btn .pane.br{border-bottom-right-radius:10px}
.app-window-btn:hover .win-outer{box-shadow:0 .25rem .8rem rgba(0,0,0,.12)}
.app-window-btn:active .win-outer{transform:scale(.98)}

/* ===== Utilidades ===== */
.object-fit-contain{object-fit:contain}
@media (max-width: 991.98px){
  .btn-contacto{padding:.55rem 1rem}
  .app-window-btn .win-outer{width:48px;height:48px}
  .app-window-btn .win-inner{width:38px;height:38px}
}

/* Asegurar que el botón circular se vea alineado en navbar */
@media (max-width: 991.98px){
  .navbar .app-window-btn{margin-top:.5rem;margin-bottom:.5rem}
}

/* ===== Orden al Contador Público ===== */
.orden-intro{
  background:#f0f3f9;
}
.orden-intro .orden-media{
  background:#fff;
  border-radius:24px;
  padding:1.25rem;
  border:6px solid var(--c-azul);
  display:flex;
  justify-content:center;
  align-items:center;
  position:relative;
  overflow:hidden;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease);
  animation:ordenSlideMedia .8s var(--ease) .1s both;
}
.orden-intro .orden-media img{
  border-radius:18px;
  width:100%;
  height:auto;
  object-fit:cover;
  transition:transform .35s var(--ease);
}
.orden-intro .orden-media::after{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:16px;
  border:2px solid rgba(0,36,125,.18);
  pointer-events:none;
  transition:opacity .3s var(--ease);
}
.orden-intro .orden-media:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 1.5rem 2.5rem rgba(0,36,125,.18);
}
.orden-intro .orden-media:hover img{
  transform:scale(1.03);
}
.orden-intro .orden-media:hover::after{
  opacity:0;
}
.orden-intro .orden-copy{
  color:var(--docs-muted);
  line-height:1.7;
  background:rgba(255,255,255,.9);
  border-radius:22px;
  padding:2rem 2.5rem;
  border:1px solid rgba(0,36,125,.14);
  box-shadow:0 .85rem 2rem rgba(3,22,51,.08);
  position:relative;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  animation:ordenSlideCopy .85s var(--ease) .25s both;
}
.orden-intro .orden-heading{
  color:var(--c-azul);
  letter-spacing:.02em;
  margin-bottom:1rem;
}
.orden-intro .orden-copy p + p{
  margin-top:1rem;
}

.orden-intro .orden-copy:hover{
  transform:translateY(-6px);
  box-shadow:0 1.6rem 3rem rgba(3,22,51,.12);
}
.orden-intro .orden-copy:hover::before{
  opacity:1;
}
@media (max-width: 767.98px){
  .orden-intro .orden-copy{
    padding:1.75rem;
  }
  .orden-intro .orden-copy::before{
    left:1.2rem;
  }
}
@keyframes ordenSlideMedia{
  0%{opacity:0;transform:translateX(-42px) scale(.95);}
  100%{opacity:1;transform:translateX(0) scale(1);}
}
@keyframes ordenSlideCopy{
  0%{opacity:0;transform:translateX(46px) scale(.96);}
  100%{opacity:1;transform:translateX(0) scale(1);}
}
@media (prefers-reduced-motion: reduce){
  .orden-intro .orden-media,
  .orden-intro .orden-copy{
    animation:none;
  }
}

.orden-docs{
  background:#f5f8ff;
  padding:3rem 0 3.5rem;
}
.orden-docs-hero{
  background:var(--c-azul);
  padding:1.25rem 0;
  text-align:center;
  border-bottom:6px solid var(--c-verde);
  box-shadow:0 .8rem 1.8rem rgba(0,0,0,.18);
}
.orden-docs-title{
  color:#fff;
  font-weight:700;
  letter-spacing:.04em;
  margin:0;
  font-size:1.15rem;
}
.orden-docs-list{
  margin-top:2.2rem;
  display:grid;
  gap:1.1rem;
}
.orden-docs-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:#fff;
  border:2px solid rgba(0,36,125,.2);
  border-radius:2.75rem;
  padding:.75rem 1.2rem .75rem 1.4rem;
  min-height:80px;
  text-decoration:none;
  color:var(--docs-muted);
  box-shadow:0 .5rem 1.3rem rgba(3,22,51,.08);
  transition:transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
}
.orden-docs-item:hover{
  transform:translateY(-6px);
  border-color:var(--c-azul);
  box-shadow:0 1.15rem 2.4rem rgba(3,22,51,.14);
}
.orden-docs-body{
  display:flex;
  align-items:center;
  gap:1rem;
}
.orden-docs-icon{
  width:56px;
  height:56px;
  border-radius:18px;
  background:linear-gradient(145deg,#edf1f8,#d9e2f3);
  border:2px solid rgba(0,36,125,.18);
  display:grid;
  place-items:center;
  box-shadow:inset 0 .3rem .8rem rgba(0,0,0,.06);
}
.orden-docs-icon img{
  width:32px;
  height:auto;
}
.orden-docs-text{
  font-weight:600;
  font-size:.96rem;
  color:var(--c-copy);
  line-height:1.3;
}
.orden-docs-year{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:104px;
  padding:.7rem 1.2rem;
  background:var(--c-azul);
  color:#fff;
  font-weight:700;
  border-radius:999px;
  letter-spacing:.03em;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
  text-transform:uppercase;
  font-size:1rem;
}
@media (max-width: 991.98px){
  .orden-docs-item{
    flex-direction:column;
    align-items:flex-start;
    gap:.85rem;
    padding:1.1rem 1.3rem;
    border-radius:24px;
  }
  .orden-docs-year{
    align-self:stretch;
    justify-content:center;
    font-size:.94rem;
    padding:.65rem 1rem;
  }
}
@media (max-width: 575.98px){
  .orden-docs{
    padding:2.5rem 0;
  }
  .orden-docs-item{
    padding:1rem 1.1rem;
  }
  .orden-docs-text{
    font-size:.92rem;
  }
  .orden-docs-icon{
    width:52px;
    height:52px;
  }
}

.contact-touch{
  background:linear-gradient(180deg,#ffffff 0%,#eaf8ef 100%);
}
.contact-card{
  background:#fff;
  border-radius:30px;
  padding:2.4rem;
  border:1px solid rgba(0,137,35,.18);
  box-shadow:0 1.4rem 3.2rem rgba(0,137,35,.12);
  animation:contactSlideLeft .7s var(--ease) both;
}
.contact-title{
  color:var(--c-verde);
  letter-spacing:.03em;
}
.contact-lead{
  color:rgba(3,22,51,.7);
}
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
}
.contact-alert{
  margin-top:.75rem;
  padding:.85rem 1.1rem;
  border-radius:16px;
  font-weight:600;
  font-size:.92rem;
  display:none;
}
.contact-alert.success{
  display:block;
  background:rgba(0,137,35,.12);
  border:1px solid rgba(0,137,35,.35);
  color:#0f4f28;
}
.contact-alert.error{
  display:block;
  background:rgba(207,20,43,.1);
  border:1px solid rgba(207,20,43,.35);
  color:#7b1121;
}
.contact-grid{
  display:grid;
  gap:1.1rem;
  grid-template-columns:repeat(2, minmax(0,1fr));
}
.contact-field{
  display:flex;
  flex-direction:column;
  gap:.45rem;
}
.contact-field label{
  font-weight:600;
  font-size:.9rem;
  color:#225730;
}
.contact-field input,
.contact-field textarea{
  width:100%;
  border:1px solid rgba(0,137,35,.25);
  border-radius:16px;
  padding:.75rem 1rem;
  font-size:.95rem;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
  background:rgba(255,255,255,.95);
}
.contact-field textarea{
  resize:vertical;
  min-height:140px;
}
.contact-field input:focus,
.contact-field textarea:focus{
  border-color:var(--c-verde);
  outline:none;
  box-shadow:0 0 0 .25rem rgba(0,137,35,.18);
}
.contact-btn{
  align-self:flex-start;
  background:var(--c-verde);
  color:#fff;
  border:0;
  border-radius:999px;
  padding:.75rem 2.2rem;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 1rem 2.2rem rgba(0,137,35,.35);
}

.contact-info-card{
  background:#fff;
  border-radius:30px;
  padding:2.6rem 2.4rem;
  border:1px solid rgba(0,137,35,.14);
  box-shadow:0 1.3rem 3rem rgba(0,137,35,.12);
  position:relative;
  overflow:hidden;
  animation:contactSlideRight .75s var(--ease) .15s both;
}
.contact-info-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 0%,rgba(0,137,35,.15),transparent 55%);opacity:.28;pointer-events:none;}
.contact-info-card>*{
  position:relative;
  z-index:1;
}
.contact-info-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.45rem .95rem;
  background:var(--c-verde);
  color:#fff;
  font-size:.75rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  border-radius:999px;
  margin-bottom:1rem;
}
.contact-info-title{
  color:#124825;
  letter-spacing:.03em;
  margin-bottom:.5rem;
}
.contact-info-lead{
  color:#1f3a2a;
  opacity:.85;
  margin-bottom:1.5rem;
}
.contact-info-list{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
}
.contact-info-item{
  display:flex;
  align-items:flex-start;
  gap:1rem;
  padding:1rem 1.15rem;
  background:rgba(255,255,255,.9);
  border-radius:20px;
  border:1px solid rgba(0,137,35,.12);
  transition:transform .2s var(--ease), border-color .2s var(--ease);
}
.contact-info-item:hover{
  transform:translateX(6px);
  border-color:var(--c-verde);
}
.contact-info-icon{
  width:46px;
  height:46px;
  border-radius:15px;
  background:var(--c-verde);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.25rem;
  box-shadow:0 .6rem 1.4rem rgba(0,137,35,.25);
}
.contact-info-item h4{
  font-size:1.05rem;
  font-weight:700;
  margin-bottom:.1rem;
  color:#1a3e29;
}
.contact-info-item p{
  margin-bottom:0;
  color:rgba(3,22,51,.65);
}
.contact-info-item a{
  color:inherit;
  text-decoration:none;
}
.contact-info-item a:hover{
  color:var(--c-verde);
}
.contact-social{
  display:flex;
  gap:.75rem;
  margin-top:2rem;
}
.contact-social a{
  width:44px;
  height:44px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:1.2rem;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-social a:hover{
  transform:translateY(-3px);
  box-shadow:0 1rem 2rem rgba(0,0,0,.2);
}
.contact-social .whatsapp{ background:#25d366; }
.contact-social .instagram{ background:linear-gradient(135deg,#2ecc71,#27ae60,#1e8449); }
.contact-social .facebook{ background:#1f8a44; }
.contact-social .youtube{ background:#2ecc71; }

.contact-map{margin-top:1rem;}
.contact-map-canvas{
  position:relative;
  width:100%;
  height:460px;
  border-radius:0;
  overflow:hidden;
  filter:saturate(1.05);
}

@keyframes contactSlideLeft{
  0%{opacity:0;transform:translateX(-42px) scale(.96);}
  100%{opacity:1;transform:translateX(0) scale(1);}
}
@keyframes contactSlideRight{
  0%{opacity:0;transform:translateX(42px) scale(.96);}
  100%{opacity:1;transform:translateX(0) scale(1);}
}
@media (max-width: 991.98px){
  .contact-card,
  .contact-info-card{
    padding:2.1rem;
  }
  .contact-grid{
    grid-template-columns:1fr;
  }
  .contact-map-canvas{height:400px;}
}
@media (max-width: 575.98px){
  .contact-card,
  .contact-info-card{
    padding:1.65rem 1.7rem;
  }
  .contact-map-canvas{height:320px;}
}

.gallery-showcase{
  background:linear-gradient(180deg,#f6fbff 0%,#eef8f1 100%);
}
.gallery-title{
  color:var(--c-azul);
  letter-spacing:.03em;
}
.gallery-lead{
  color:rgba(3,22,51,.75);
  max-width:540px;
}
.gallery-counter{
  display:inline-flex;
  align-items:center;
  gap:.75rem;
  padding:.75rem 1.25rem;
  border-radius:999px;
  background:#ffffff;
  border:2px solid rgba(0,137,35,.18);
  box-shadow:0 1rem 2.5rem rgba(0,137,35,.12);
}
.gallery-count{
  font-size:1.8rem;
  font-weight:800;
  color:var(--c-verde);
  line-height:1;
}
.gallery-count-label{
  font-size:.85rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--c-copy);
}
.gallery-card{
  display:block;
  text-decoration:none;
  color:inherit;
}
.gallery-thumb{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 1.35rem 3rem rgba(3,22,51,.12);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.gallery-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.gallery-zoom{
  position:absolute;
  inset:auto 16px 16px auto;
  width:48px;
  height:48px;
  border-radius:50%;
  background:rgba(0,137,35,.85);
  display:grid;
  place-items:center;
  color:#fff;
  font-size:1.3rem;
  box-shadow:0 .85rem 1.6rem rgba(0,137,35,.25);
  opacity:0;
  transform:translate3d(0,12px,0);
  transition:opacity .22s var(--ease), transform .22s var(--ease);
}
.gallery-card:hover .gallery-thumb{
  transform:translateY(-8px) rotate3d(0,1,0,6deg);
  box-shadow:0 1.9rem 3.8rem rgba(3,22,51,.18);
}
.gallery-card:hover .gallery-thumb img{
  transform:scale(1.08) rotate3d(1,0,0,3deg);
}
.gallery-card:hover .gallery-zoom{
  opacity:1;
  transform:translate3d(0,0,0);
}
.gallery-caption{
  display:block;
  margin-top:.75rem;
  font-weight:600;
  font-size:.95rem;
  color:#1f3a2a;
  text-transform:capitalize;
}
@media (max-width: 575.98px){
  .gallery-counter{
    margin-top:.5rem;
  }
  .gallery-thumb{
    border-radius:18px;
  }
}

.glightbox-container.glightbox-clean .ginner-container{max-width:1080px;width:calc(100% - 32px);}
.glightbox-container.glightbox-clean .gslide-inner-content{background:transparent;box-shadow:none;}
.glightbox-container.glightbox-clean .gslide-media{
  border-radius:20px 20px 0px 0px;
  overflow:hidden;
  box-shadow:0 2.2rem 4.6rem rgba(3,22,51,.28);
}
.glightbox-container.glightbox-clean .gdesc{
  position:absolute;
  left:5%;
  right:5%;
  bottom:-250px;
  display:flex;
  pointer-events:none;
}
.glightbox-container.glightbox-clean .gdesc-inner{
  width:100%;
  padding:14px 28px;
  font-weight:600;
  font-size:1rem;
  color:#fff;
  background:rgba(4,11,22,.55);
  backdrop-filter:blur(8px);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  border-radius: 0px 0px 20px 20px;
  box-shadow:0 1.4rem 2.8rem rgba(0,0,0,.35);
}
.glightbox-container.glightbox-clean .gslide-description{background:none;}
.glightbox-container.glightbox-clean .gslide-title{color:#fff;}
.glightbox-container.glightbox-clean .gprev,
.glightbox-container.glightbox-clean .gnext{
  width:52px;
  height:52px;
  border-radius:50%;
  backdrop-filter:blur(2px);
  background:rgba(0,36,125,.4);
}
.glightbox-container.glightbox-clean .gprev:hover,
.glightbox-container.glightbox-clean .gnext:hover{
  background:rgba(0,137,35,.85);
}

.leyes-grid{
  background:linear-gradient(180deg,#f8fbff 0%,#eef4ff 100%);
  padding:3.5rem 0 4rem;
}
.ley-card{
  position:relative;
  background:#fff;
  border-radius:28px;
  padding:2.25rem 2.4rem;
  border:1px solid rgba(0,36,125,.12);
  box-shadow:0 1.4rem 3.2rem rgba(3,22,51,.08);
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  animation:leyCardEntrance .75s var(--ease) both;
}
.ley-card.alt{
  background:#fff;
  border:1px solid rgba(0,137,35,.12);
}
.ley-card.alt::after{display:none;}
.ley-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at -10% 0%,rgba(0,36,125,.12),transparent 55%);
  opacity:.65;
  pointer-events:none;
}
.ley-card:hover{
  transform:translateY(-12px);
  box-shadow:0 1.9rem 3.6rem rgba(3,22,51,.12);
}
.ley-card-header{
  position:relative;
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1.3rem;
  z-index:1;
}
.ley-card-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.45rem .9rem;
  background:var(--c-verde);
  color:#fff;
  font-weight:600;
  border-radius:999px;
  font-size:.78rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  box-shadow:0 .45rem 1rem rgba(0,137,35,.25);
}
.ley-card-title{
  margin:0;
  color:var(--c-azul);
  letter-spacing:.03em;
}
.ley-card-lead{
  position:relative;
  z-index:1;
  color:var(--docs-muted);
  font-weight:600;
  margin-bottom:1rem;
}
.ley-card-list{
  position:relative;
  z-index:1;
  counter-reset:ley;
  list-style:none;
  padding-left:0;
  margin:0 0 1.3rem;
  display:grid;
  gap:.75rem;
}
.ley-card-list li{
  counter-increment:ley;
  background:rgba(255,255,255,.82);
  border-radius:18px;
  padding:.65rem 1rem;
  border:1px solid rgba(0,36,125,.08);
  display:flex;
  align-items:center;
  gap:.75rem;
  transition:transform .2s var(--ease), border-color .2s var(--ease);
}
.ley-card-list li::before{
  content:counter(ley, decimal-leading-zero);
  min-width:42px;
  height:42px;
  border-radius:50%;
  background:var(--c-azul);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
}
.ley-card-list li a{
  color:var(--c-copy);
  font-weight:600;
  text-decoration:none;
}
.ley-card-list li span{
  color:var(--c-copy);
  font-weight:600;
}
.ley-card-list li:hover{
  transform:translateX(6px);
  border-color:var(--c-azul);
}
.ley-card-list li a:hover{
  color:var(--c-azul);
}
.ley-card-body{
  position:relative;
  z-index:1;
  color:var(--docs-muted);
  margin-bottom:0;
  line-height:1.6;
}
@keyframes leyCardEntrance{
  0%{opacity:0;transform:translateY(30px) scale(.96);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}
@media (max-width: 991.98px){
  .leyes-grid{
    padding:3rem 0;
  }
  .ley-card{
    padding:2rem;
  }
}
@media (max-width: 575.98px){
  .ley-card{
    padding:1.6rem 1.7rem;
  }
  .ley-card-list li{
    align-items:flex-start;
  }
  .ley-card-list li::before{
    margin-top:.2rem;
  }
}

/* ===== FOOTER ===== */
.site-footer{color:#fff}

/* Bloque que contiene franjas + mapa */
.footer-stripes{
  position:relative;
  min-height: 420px;              /* alto base del bloque */
}
@media (max-width: 991.98px){
  .footer-stripes{ min-height: 520px; }
}

/* Las 3 franjas a todo el ancho y 1/3 de alto cada una */
.footer-stripes .stripes{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  z-index:0;                       /* por debajo del mapa y del contenido */
}
.footer-stripes .stripe{ flex:1 0 33.333%; }
.footer-stripes .stripe-blue{ background:var(--c-azul); }
.footer-stripes .stripe-green{ background:var(--c-verde); }
.footer-stripes .stripe-red{ background:var(--c-rojo); }

/* Mapa como overlay sobre las franjas */
.footer-map{
  position:absolute; inset:0;
  background: center/contain no-repeat url('../img/mapa-footer.png');
  opacity:.52;
  z-index:1;
  pointer-events:none;
}

/* Contenido del footer encima del mapa */
.footer-content{
  position:relative; z-index:2;
  padding-top: 2.25rem; padding-bottom: 2.25rem;
}

/* ===== Footer: tipografía y acentos ===== */
.ft-title{
  color: var(--c-accent);
  text-transform: uppercase;
  letter-spacing: .02em;
  font-weight: 600;
  margin-bottom: .75rem;
}
.ft-subtitle{
  color: #fff;                 /* “UBICACIÓN:” en blanco */
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: .25rem;
}
.ft-accent{ color: var(--c-accent); }
.ft-link{ color:#fff; text-decoration:none; }
.ft-link:hover{ text-decoration:underline; }
.ft-links li{ margin:.35rem 0; }
.ft-links a{ color:#fff; text-decoration:none; }
.ft-links a:hover{ text-decoration:underline; }
.ft-muted{ opacity:.92; }

/* ===== Badge circular para el teléfono ===== */
.ft-badge-outer{
  display:inline-grid; place-items:center;
  width:64px; height:64px; border-radius:50%;
  border:3px solid rgba(255,255,255,.55); background:transparent;
}
.ft-badge-inner{
  display:grid; place-items:center;
  width:48px; height:48px; border-radius:50%;
  background: var(--c-accent); color:#fff; font-size:1.25rem;
}

/* Ajustes responsivos suaves */
@media (max-width: 991.98px){
  .ft-badge-outer{ width:56px; height:56px }
  .ft-badge-inner{ width:42px; height:42px }
}

/* Copyright */
.footer-copy{
  background: var(--c-copy);
}
.footer-copy .social-icons .nav-link{
  color:#fff; opacity:.9; padding:.25rem .5rem; font-size:1.05rem
}
.footer-copy .social-icons .nav-link:hover{opacity:1}

/* ================= HERO SLIDER (versión estable, sin saltos) ================= */

/* Wrapper y altura */
.hero-slider{
  --hero-h: 72vh;
  min-height: 420px;
  background:#0b0f14; /* color base para evitar “flash” si una img tarda */
  position: relative;
}
.hero-slider .carousel-inner,
.hero-slider .carousel-item{ height: var(--hero-h); }

/* Fondo de cada slide */
.hero-slide{
  position: relative;
  background-size: cover;
  background-position: center;
  backface-visibility: hidden;
  transform: translateZ(0); /* evita jank */
  background-color:#0b0f14; /* respalda mientras carga la imagen */
}
.hero-slide::after{ /* overlay suave para legibilidad */
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg,
              rgba(0,0,0,.55) 0%,
              rgba(0,0,0,.35) 40%,
              rgba(0,0,0,.35) 60%,
              rgba(0,0,0,.55) 100%);
}

/* Capa y posiciones del contenido */
.hero-layer{ position:absolute; inset:0; z-index:2; display:flex; align-items:center; padding:2rem 0; }
.hero-layer .container{ width:100%; }
.hero-content{ color:#fff; max-width:min(680px,92vw); margin:0; }
.hero-layer.pos-left   .hero-content{ margin-right:auto; text-align:left; }
.hero-layer.pos-center .hero-content{ margin-left:auto; margin-right:auto; text-align:center; }
.hero-layer.pos-right  .hero-content{ margin-left:auto; text-align:right; }

/* Badge + textos */
.hero-badge{
  display:inline-block; margin-bottom:.75rem; color:#fff;
  border:2px solid var(--c-accent); padding:.35rem .9rem; font-weight:700;
  border-top-left-radius:24px; border-bottom-right-radius:24px;
  border-top-right-radius:8px;  border-bottom-left-radius:8px;
  background: rgba(0,0,0,.18); backdrop-filter: blur(2px);
}
.hero-title{ font-size:clamp(1.8rem,4.5vw,3.2rem); line-height:1.1; font-weight:800; margin:.25rem 0 .75rem; }
.hero-desc { font-size:clamp(.95rem,1.4vw,1.05rem); opacity:.95; margin-bottom:1.25rem; }

/* Botón hero */
.btn-hero{
  display:inline-block; background:var(--c-accent); color:#fff; text-decoration:none; font-weight:800;
  padding:.7rem 1.4rem; border:0;
  border-top-left-radius:24px; border-bottom-right-radius:24px;
  border-top-right-radius:8px;  border-bottom-left-radius:8px;
  transition:transform .15s var(--ease), box-shadow .15s var(--ease), background-color .2s var(--ease);
}
.btn-hero:hover{ color:#fff; background:#2ea631; transform:translateY(-1px); box-shadow:0 .35rem .9rem rgba(0,0,0,.16); }
.btn-hero:active{ transform:none }

/* ---------- MODO SLIDE (derecha = siguiente, izquierda = anterior) ---------- */
#heroSlider .carousel-inner{ overflow:hidden; }
#heroSlider .carousel-item{
  will-change: transform;
  transition: transform .68s var(--ease);
  background-color:#0b0f14;
}
/* Bootstrap agrega estas clases durante la animación */
#heroSlider .carousel-item-next,
#heroSlider .carousel-item-prev{ position:absolute; top:0; }

#heroSlider .carousel-item{ transform: translateX(0); }
#heroSlider .carousel-item-next{ transform: translateX(100%); }  /* entra desde derecha */
#heroSlider .carousel-item-prev{ transform: translateX(-100%); } /* entra desde izquierda */

#heroSlider .carousel-item.active.carousel-item-start{ transform: translateX(-100%); } /* sale a izq */
#heroSlider .carousel-item.active.carousel-item-end{   transform: translateX(100%); }  /* sale a der */
#heroSlider .carousel-item-next.carousel-item-start,
#heroSlider .carousel-item-prev.carousel-item-end{     transform: translateX(0); }     /* finaliza en 0 */

/* (Por si quedó clase fade en HTML, neutralizamos su efecto) */
#heroSlider.carousel.carousel-fade .carousel-item,
#heroSlider.carousel.carousel-fade .carousel-item-next,
#heroSlider.carousel.carousel-fade .carousel-item-prev,
#heroSlider.carousel.carousel-fade .carousel-item-start,
#heroSlider.carousel.carousel-fade .carousel-item-end{
  transition: none !important;
  opacity:1 !important;
  transform:none !important;
}

/* Entrada del bloque de texto */
@keyframes heroIn{
  from{ opacity:0; transform:translateY(10px) }
  to  { opacity:1; transform:none }
}
.carousel-item.active .hero-content{ animation:heroIn .75s var(--ease) .05s both; }

/* Flechas circulares blancas */
.hero-ctrl{
  width:64px; height:64px; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.45);
  border-radius:50%;
  transition:background .18s var(--ease), transform .12s var(--ease);
  z-index:5;
}
.hero-ctrl:hover{ background:rgba(255,255,255,.32); }
.carousel-control-prev{ left:1rem; }
.carousel-control-next{ right:1rem; }

/* Iconos blancos (SVG embebido) */
.carousel-control-prev-icon,
.carousel-control-next-icon{
  background-size:24px 24px; width:24px; height:24px; filter:none;
}
.carousel-control-prev-icon{
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M15 4 7 12l8 8' stroke='%23fff' stroke-width='2.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.carousel-control-next-icon{
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 4l8 8-8 8' stroke='%23fff' stroke-width='2.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Responsive */
@media (max-width: 991.98px){
  .hero-slider{ --hero-h:64vh; }
  .hero-content{ max-width:94vw; }
}
@media (max-width: 575.98px){
  .hero-slider{ --hero-h:56vh; }
}
.features-grid .feature-card{
  color:#0b1220; text-decoration:none;
  transition:transform .15s ease, box-shadow .15s ease;
}
.features-grid .feature-card:hover{
  transform: translateY(-4px);
}
.features-grid .feature-title{
  font-weight:600;
}
.features-grid .feature-desc{
  color:#19243a; opacity:.85;
}

/* Alternar alturas SOLO en desktop */
@media (min-width: 992px){
  .features-grid .feature-card.stagger-odd{ margin-top: 28px; }
  .features-grid .feature-card.stagger-even{ margin-top: 0; }
}

/* Circulo con anillo y sombra */
.circle-wrap{
  position:relative; width:116px; height:116px;
}
.circle-wrap .ring{
  position:relative; display:grid; place-items:center;
  width:100%; height:100%; border-radius:50%;
  background:#fff;
  box-shadow:
    0 8px 24px rgba(0,0,0,.12),
    inset 0 0 0 6px rgba(0,0,0,.04),
    inset 0 0 0 2px rgba(255,255,255,.8);
}
.circle-wrap img{
  width:70%; height:70%; object-fit:contain; border-radius:50%;
}

/* Icono orbitando (verde con ícono blanco) */
.orbit-icon{
  position:absolute; top:-6px; right:-6px;
  width:28px; height:28px; border-radius:50%;
  background: var(--c-accent); color:#fff;
  display:grid; place-items:center;
  box-shadow: 0 4px 12px rgba(0,0,0,.18), 0 0 0 2px #fff;
  font-size:14px;
}

/* Variante: si quieres una leve animación orbital (opcional) */

@keyframes orbit {
  0% { transform: translate(0,0); }
  50% { transform: translate(2px,-2px); }
  100% { transform: translate(0,0); }
}
.orbit-icon{ animation: orbit 2.4s ease-in-out infinite; }


.docs-section{ background: var(--docs-bg); }
.docs-section .doc-card{
  background:#fff; border-radius: 16px;
  box-shadow: 0 6px 22px rgba(0,0,0,.06);
  color: var(--docs-ink); text-decoration:none;
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.docs-section .doc-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
}

/* Badge rojo */
.doc-badge{
  display:inline-block; background: var(--docs-badge); color:#fff;
  font-size:.72rem; font-weight:600; letter-spacing:.02em;
  padding: .25rem .5rem; border-radius: 12px;
}

/* Icono principal */
.doc-icon{
  width:44px; height:44px; border-radius:10px;
  background:#fff; border:1px solid #e8edf4;
  display:grid; place-items:center; flex:0 0 44px;
  box-shadow: inset 0 0 0 2px rgba(0,0,0,.04);
}
.doc-icon i{ font-size:1.1rem; color: var(--docs-blue); }

/* Título/desc */
.doc-title{ font-weight:600; line-height:1.15; }
.doc-desc{ color: var(--docs-muted); opacity:.9; }

/* Botón azul con radios opuestos */
.btn-doc{
  display:inline-block; background: var(--docs-blue); color:#fff; font-weight:500;
  padding:.5rem 1rem;
  border-top-left-radius:18px; border-bottom-right-radius:18px;
  border-top-right-radius:8px;  border-bottom-left-radius:8px;
  transition: transform .1s var(--ease), box-shadow .15s var(--ease), background-color .2s var(--ease);
}
.doc-card:hover .btn-doc{ background:#052a90; box-shadow:0 .35rem .9rem rgba(0,0,0,.12); }

/* Promo derecha */
.promo-card{ min-height: 320px; }
.promo-card img{ display:block; }
.promo-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0) 35%, rgba(0,0,0,.55) 100%);
}
.promo-title{
  position:absolute; left:1rem; bottom:1rem; right:1rem; color:#fff;
  font-weight:600; text-shadow:0 3px 16px rgba(0,0,0,.45);
}

/* Utilidad para imágenes */
.object-fit-cover{ object-fit:cover; }

/* Responsive: spacing */
@media (max-width: 575.98px){
  .promo-card{ min-height: 240px; }
}

/* ===== ¿Por qué colegiarse? ===== */
/* ================= ¿POR QUÉ COLEGIARSE? — FINAL ================= */
/* Section + fondo */
.why-join{
  position:relative;
  min-height:520px;
  padding-bottom:calc(var(--wj-tabs-h) + 18px); /* espacio reservado para la barra */
  color:#fff;
}
.why-join .wj-bg{
  position:absolute; inset:0; z-index:0;
  background:center/cover no-repeat var(--wj-bg, url('/assets/img/banner_tab_1.png'));
   background-image: url('/assets/img/banner_tab_1.png');
  background-size: cover;      /* Ajusta la imagen para cubrir todo el contenedor */
  background-position: center; /* Centra la imagen */
  background-repeat: no-repeat;/* Evita repeticiones */
}
/* Para móviles */
@media (max-width: 768px) {
  .why-join  {
    background-size: cover;          /* sigue siendo cover */
    background-position: center center; /* se centra la imagen */
  }
}
.why-join .wj-overlay{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(270deg, rgba(43,48,58,.85) 0%, rgba(43,48,58,.65) 35%, rgba(43,48,58,0) 100%);
 
  pointer-events:none; /* ¡para que no bloquee clics! */
}

/* Panes de contenido */
.wj-panes{ position:relative; z-index:2; padding:30px; padding-top: 60px; }
.wj-pane{ display:none; }
.wj-pane.active{ display:block; animation:wjFade .6s ease both; }
@keyframes wjFade{ from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none} }

.wj-h1{
  font-weight:600; text-transform:uppercase;
  font-size:clamp(1.2rem, 4.2vw, 1.3rem);
  line-height:1.1; margin-bottom:.5rem;
  
}
.wj-desc{ max-width:50ch; opacity:.95; margin-bottom:1rem; font-size: 12px; text-align: justify;}
.wj-list{ list-style:none; padding:0; margin:0; }
.wj-list li{ position:relative; padding-left:1.5rem; margin:.35rem 0; font-size: 12px;}
.wj-list li::before{
  content:""; position:absolute; left:0; top:.45em; width:.7em; height:.7em;
  border-radius:50%; background:#3ead3c; box-shadow:0 0 0 2px rgba(255,255,255,.6);
}

/* Barra de tabs fija al fondo del SECTION (por encima de la overlay) */
.wj-tabs-bar{
  position:absolute; left:0; right:0; bottom:.75rem; z-index:3;
  pointer-events:auto;
}

/* Botón de tab: misma ALTURA para todos */
.wj-tab{
  display:flex; align-items:center; gap:.75rem;
  width:100%;
  min-height:var(--wj-tabs-h);
  padding:.7rem 1rem;
  background:var(--wj-dark); color:#fff;
  border:0; cursor:pointer; text-align:left;
  border-top-left-radius:18px; border-bottom-right-radius:18px;
  border-top-right-radius:12px; border-bottom-left-radius:12px;
  transition:background-color .2s ease, transform .1s ease, box-shadow .15s ease;
}
.wj-tab .wj-num{ font-weight:900; font-size:1.00rem; line-height:1; }
.wj-tab .wj-label{
  font-weight:500; font-size:.83rem; line-height:1.05;
  text-transform:uppercase; white-space:pre-line;
}
.wj-tab:hover{ transform:translateY(-2px); box-shadow:0 .35rem .9rem rgba(0,0,0,.15); }

/* Activo (verde sutil en diagonal) */
.wj-tab.active{
  background: linear-gradient(90deg, #008923 0%, #0b9130 100%);
}

/* Responsive: mantener 3 columnas también en móvil */
@media (max-width:575.98px){
  :root{ --wj-tabs-h:64px; }
  .why-join{ padding-bottom:calc(var(--wj-tabs-h) + 14px); }
  .wj-tabs-bar .row{ --bs-gutter-x:.5rem; }
  .wj-tab{ padding:.6rem .75rem; }
  .wj-tab .wj-label{ font-size:.55rem!important; }
}

/* ===== Conciencia CPC (grid de valores) ===== */
.values-section{ background:#eef3f9; }

.value-card{
  color:var(--ink);
  transition:transform .15s ease, box-shadow .15s ease;
}
.value-card:hover{ transform:translateY(-3px); }

.value-thumb{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
}
.object-fit-cover{ object-fit:cover; }

/* Badge circular en esquina inferior derecha */
.value-badge{
  position:absolute; right:.5rem; bottom:.5rem;
  width:34px; height:34px; border-radius:50%;
  background:var(--c-accent); color:#fff;
  display:grid; place-items:center;
  box-shadow:0 0 0 3px #fff, 0 6px 16px rgba(0,0,0,.18);
  font-size:16px;
}

/* Título */
.value-title{
  font-weight:600;
  font-size:.92rem;
  line-height:1.1;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* Ajustes de separación en pantallas muy pequeñas */
@media (max-width: 400px){
  .value-badge{ width:32px; height:32px; font-size:15px; }
  .value-title{ font-size:.88rem; }
}
.values-section{ background:#eef3f9; }

.value-card{ color:var(--ink); transition:transform .15s ease, box-shadow .15s ease; }
.value-card:hover{ transform:translateY(-3px); }

.value-thumb{
  position:relative; border-radius:18px; overflow:hidden; background:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
}
.object-fit-cover{ object-fit:cover; }

.value-badge{
  position:absolute; right:.5rem; bottom:.5rem;
  width:34px; height:34px; border-radius:50%;
  background:var(--c-accent); color:#fff; display:grid; place-items:center;
  box-shadow:0 0 0 3px #fff, 0 6px 16px rgba(0,0,0,.18); font-size:16px;
}

.value-title{
  font-weight:600; font-size:.92rem; line-height:1.1;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  min-height: 1.2em; /* asegura alineación de líneas */
}

@media (max-width: 400px){
  .value-badge{ width:32px; height:32px; font-size:15px; }
  .value-title{ font-size:.88rem; }
}
/* === Valores (cards) — se mantiene lo previo === */
/* Cards (igual que antes) */
:root{ --c-accent:#3ead3c; --ink:#0b1220; }
.values-section{ background:#eef3f9; }
.value-card{ color:var(--ink); transition:transform .15s ease, box-shadow .15s ease; }
.value-card:hover{ transform:translateY(-3px); }
.value-thumb{ position:relative; border-radius:18px; overflow:hidden; background:#fff; box-shadow:0 10px 26px rgba(0,0,0,.06); }
.object-fit-cover{ object-fit:cover; }
.value-badge{ position:absolute; right:.5rem; bottom:.5rem; width:34px; height:34px; border-radius:50%; background:var(--c-accent); color:#fff; display:grid; place-items:center; box-shadow:0 0 0 3px #fff, 0 6px 16px rgba(0,0,0,.18); font-size:16px; }
.value-title{ font-weight:600; font-size:.92rem; line-height:1.1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-height:1.2em; }

/* Modal */
.value-modal .modal-content{ border-radius:16px; }
.value-modal .modal-header{ border-bottom:1px solid #eef0f4; }
#valorDesc{ color:#0b1220; }
.P-4{
  padding: 3.5rem !important;
}   
@media (max-width: 768px) {
  .P-4{
  padding: 0.5rem !important;
}  
}

/* ================================== */
/* AUTORIDADES */
/* ================================== */
  .page-hero{
    position:relative;
    min-height: 220px;
    display:flex;
    align-items:center;
    padding: 2.25rem 0;
    overflow:hidden;
  }
  .page-hero__bg{
    position:absolute; inset:0;
    background-size:cover; background-position:center;
    filter: saturate(.95) contrast(1.02);
    transform: translateZ(0);
  }
  .page-hero__overlay{
    position:absolute; inset:0;
    /* Oscuro de izquierda a derecha para mejorar legibilidad */
    background: linear-gradient(90deg, rgba(3,12,24,.62) 0%, rgba(3,12,24,.48) 40%, rgba(3,12,24,.38) 100%);
  }
  .page-hero__title{
    position:relative; z-index:2;
    font-weight:800; letter-spacing:.02em;
  }
  .page-hero__breadcrumb{
    position:relative; z-index:2;
    margin:0;
  }
  .page-hero__breadcrumb .breadcrumb-item a{
    color:#ffffffcc; text-decoration:none;
  }
  .page-hero__breadcrumb .breadcrumb-item a:hover{
    color:#fff; text-decoration:underline;
  }
  .page-hero__breadcrumb .breadcrumb-item.active{
    color:#fff;
  }
  /* Divider del breadcrumb en blanco tenue */
  .breadcrumb{
    --bs-breadcrumb-divider-color: #ffffffa8;
    --bs-breadcrumb-item-active-color: #fff;
  }

  @media (min-width: 992px){
    .page-hero{ min-height: 260px; }
  }

  /* ===== Autoridad destacada (card con fondo + overlay + foto) ===== */
.authority-highlight{ padding: 3rem 0; }

.auth-card{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  min-height: 360px;
  box-shadow: 0 18px 44px rgba(0,0,0,.12);
  isolation: isolate; /* la overlay no tapa el contenido */
}

/* Fondo y overlay */
.auth-bg{
  position:absolute; inset:0;
  background: center/cover no-repeat;
  z-index: 0;
}
.auth-overlay{
  position:absolute; inset:0; z-index:1;
  /* Más oscuro hacia la DERECHA (donde va el texto) */
  background: linear-gradient(90deg,
              rgba(3,12,24,.10) 0%,
              rgba(3,12,24,.35) 35%,
              rgba(3,12,24,.68) 72%,
              rgba(3,12,24,.82) 100%);
}

/* Contenido */
.auth-copy{ position: relative; z-index: 2; color: #fff; }
.auth-name{
  color: var(--c-verde-text);      /* 008923 */
  font-weight: 800;
  letter-spacing: .2px;
}
.auth-role{
  text-transform: uppercase;
  font-weight: 800;
  font-size: clamp(1.1rem, 1.2vw, 1.25rem);
  margin-top: .25rem;
  margin-bottom: .5rem;
}
.auth-lead{ opacity:.92; margin-bottom:.5rem }
.auth-text{ opacity:.92; max-width: 60ch; }

/* Foto */
.auth-photo-wrap{
  position: relative; z-index: 2;
  display: grid; place-items: end start;
  min-height: 320px;
}
.auth-photo{
  max-height: 540px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 18px 36px rgba(0,0,0,.25));
}

/* Responsive */
@media (max-width: 991.98px){
  .auth-card{ min-height: 0; }
  .auth-photo-wrap{ place-items: center; min-height: 0; }
  .auth-photo{ max-height: 300px; }
  .auth-text{ max-width: 100%; }
}
@media (max-width: 575.98px){
  .authority-highlight{ padding: 2rem 0; }
  .auth-photo{ max-height: 260px; }
}

/* ======= Grid de Autoridades (cards) ======= */
.auth-grid{ background:#eef3f9; }

/* Card base */
.ag-card{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  height: 362px; /* alto base; se adapta al grid */
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
  transition: transform .18s var(--ease), box-shadow .18s var(--ease);
  background:#eef3f9;
}
.ag-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
}

/* Imagen de fondo */
.ag-img{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform: translateZ(0);
}

/* Overlay SOLO en la parte inferior (para texto) */
.ag-bottom{
  position:absolute; left:0; right:0; bottom:0;
  height: 52%;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%,
                                        rgba(0,0,0,.25) 35%,
                                        rgba(0,0,0,.72) 100%);
  color:#fff;
  padding: .65rem .75rem .85rem;
  display:flex; flex-direction:column; justify-content:flex-end;
  gap:.1rem;
}

/* Badge opcional (ej. “VIGENTE”) */
.ag-badge{
  display:inline-block;
  background: var(--c-verde);
  color:#fff; font-size:.68rem; font-weight:800; letter-spacing:.02em;
  padding:.15rem .45rem; border-radius:10px;
  margin-bottom:.2rem;
  box-shadow:0 0 0 1px rgba(255,255,255,.2);
  width: fit-content;
}

/* Cargo y nombre */
.ag-role{
  color: var(--c-verde);
  font-weight:800;
  text-transform:uppercase;
  line-height:1; font-size:.78rem;
}
.ag-name{
  font-weight:800;
  line-height:1.05;
  font-size:.9rem;
  text-transform:uppercase;
}

/* Botón que aparece en hover */
.ag-btn{
  position:absolute; left:50%; top:50%;
  transform: translate(-50%, calc(-50% + 6px));
  opacity:0; z-index:2;
  padding:.5rem 1rem;
  background: var(--c-azul);
  color:#fff; text-decoration:none; font-weight:700;
  border-top-left-radius:18px; border-bottom-right-radius:18px;
  border-top-right-radius:8px;  border-bottom-left-radius:8px;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  transition: opacity .18s var(--ease), transform .18s var(--ease), background-color .2s var(--ease);
}
.ag-card:hover .ag-btn{ opacity:1; transform: translate(-50%, -50%); }
.ag-btn:hover{ background:#05308f; }

/* Responsive */
@media (max-width: 575.98px){
  .ag-card{ height: 220px; }
  .ag-bottom{ height: 56%; }
  .ag-name{ font-size:.86rem; }
}


/* === Tab Panel y Contenido === */
/* Estilo de fondo y overlay */
/* ================= Tab Panel Organizacional ================= */
.tab-panel-organizacion{
  background:#f0f3f9;  /* Color de fondo general */
}

/* Superficie con borde redondeado y recorte */
.tab-panel-organizacion .tp-surface {
  position: relative;
  border-radius: 16px;
  overflow: hidden;        /* Recorta la imagen y overlay */
  min-height: 500px;
}

/* Capa de imagen de fondo (dinámica por JS) */
.tab-panel-organizacion .tp-bg {
  position: absolute; 
  inset: 0;
  background: center/cover no-repeat transparent; /* Imagen cargada dinámicamente */
  z-index: 0;
}

/* Overlay oscuro (trasparencia de oscuro a transparente con ángulo de 150 grados) */
/* Overlay que oscurece solo la imagen con el efecto de mezcla */
.tab-panel-organizacion .tp-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    -160deg,
    rgba(43, 48, 58, 1) 0%,
    rgba(43, 48, 58, 1) 80%,
    rgba(43, 48, 58, 0) 100%
  );
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.7; /* Ajusta la opacidad para más o menos oscuridad */
  
  /* Efectos de mezcla */
  mix-blend-mode: multiply; /* Cambia esto por 'screen' o 'overlay' si quieres otros efectos */
}

/* Contenido por encima del overlay */
.tab-panel-organizacion .tp-content {
  position: relative;
  z-index: 2;
  padding: 24px;
}
.tp-nav-container{
  margin-top: 0px!important;
}
/* NAV vertical */
.tab-panel-organizacion .tp-nav {
  background: #fff;
  border-radius: 0px 0px 14px 14px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  overflow: hidden;
}

.tab-panel-organizacion .tp-nav-link {
  display: block;
  padding: 14px 50px;
  font-weight: 500;
  color: #0b1220;
  text-decoration: none;
  transition: background-color 0.15s ease;
}
.tab-panel-organizacion .tp-nav-link:hover {
  background: #f5f7fb;
}
.tab-panel-organizacion .tp-nav-link.active {
  background: var(--c-verde);
  color: #fff;
}

/* Panes (texto sobre la imagen) */
.tab-panel-organizacion .tp-panes {
  color: #fff;
}
.tab-panel-organizacion .tp-title {
  font-weight: 800;
  text-transform: none;
  color: #83ffa2;
}
.tab-panel-organizacion .tp-body p {
  margin-bottom: .6rem;
}
.tab-panel-organizacion .tp-body ul {
  margin: .35rem 0 0 1.25rem;
}
.tab-panel-organizacion .tp-body a {
  color: #d9f2ff;
  text-decoration: underline;
}
.tab-panel-organizacion .tab-content {
  height: 400px;
  display: flex;
  justify-content: center; /* centra horizontalmente */
  align-items: center;
}
/* Responsive tweaks */
@media (max-width: 991.98px) {
  .tab-panel-organizacion .tp-content {
    padding: 18px;
  }
  .tab-panel-organizacion .tp-nav {
    margin-bottom: 14px;
  }
}



/* ================== HISTORIA DEL GREMIO ================== */
/* ===== HISTORIA alternada: 2 filas, col-6/col-6 ===== */
/* ===== HISTORIA alternada ===== */
.hist-alt-section{ background:#fff; }
.hist-alt-title{ color:#0b1220; }
.hist-alt-copy{ color:#0b1220; }
.hist-alt-copy p{ margin-bottom:.7rem; text-align:justify; font-size:13px; }
.hist-alt-copy ul{ margin:.5rem 0 .75rem 1.15rem; }

/* Fotos tipo “cuadro” */
.hist-alt-photo{
  position:relative;
  width:100%; max-width:520px; margin:0;
  background:#eef3f9; border-radius:16px; padding:10px;
  box-shadow:0 10px 26px rgba(0,0,0,.08);
}
.hist-alt-photo img{
  display:block; width:100%; height:auto; aspect-ratio:1/1;
  object-fit:cover; border-radius:12px;
}

/* Botón Play circular */
.hist-alt-play{
  position:absolute; inset:0; display:grid; place-items:center;
  text-decoration:none;
}
.hist-alt-play .play-badge{
  width:72px; height:72px; border-radius:50%; background:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.18);
  display:grid; place-items:center;
}
.hist-alt-play .play-badge::before{
  content:""; display:block; width:0; height:0;
  border-left:16px solid #19a34a; border-top:10px solid transparent; border-bottom:10px solid transparent;
  margin-left:6px;
}

/* CTA + bandera */
.hist2-btn{
  background:var(--c-verde,#008923); color:#fff; font-weight:700;
  border-radius:18px 8px 18px 8px; padding:.6rem 1.15rem; text-decoration:none;
}
.hist2-btn:hover{ color:#fff; background:#0a7a26; }
.hist2-flag{
  background:#fff; border-radius:14px; box-shadow:0 10px 26px rgba(0,0,0,.08);
}
.hist2-flag img{ width:28px; height:18px; object-fit:cover; border-radius:3px; }

/* Responsive */
@media (max-width: 991.98px){
  .hist-alt-photo{ max-width:360px; margin-left:auto; margin-right:auto; }
}

/* ===== Lightbox (vertical reels, 9:16 real) ===== */
.hist-alt-lightbox{
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: none;
  background: rgba(0,0,0,.72);
}
.hist-alt-lightbox.open{
  display: flex;                  /* centra el diálogo */
  align-items: center;
  justify-content: center;
}

/* Contenedor del video con proporción 9:16 */
.hist-alt-dialog{
  position: relative;
  height: 86vh;                   /* alto tipo “reel” */
  aspect-ratio: 9 / 16;           /* mantiene 9:16 */
  width: auto;                    /* el ancho se deriva del alto */
  max-width: 92vw;                /* no excede el viewport en horizontal */
  max-height: 92vh;
  background: #000;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
}

/* Slot del video ocupa todo el diálogo */
.hist-alt-video-slot{
  width: 100%;
  height: 100%;
}
.hist-alt-video-slot video,
.hist-alt-video-slot iframe{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;              /* rellena sin deformar */
}

/* Botón de cerrar dentro del video, esquina superior derecha */
.hist-alt-close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  color: #0b1220;
  font-weight: 900;
  font-size: 22px;
  line-height: 40px;
  text-align: center;
  cursor: pointer;
  z-index: 2;                     /* por encima del video */
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
}

/* Bloquear scroll del body cuando está abierto */
body.hist-no-scroll{ overflow: hidden; }

/* Pequeña seguridad en pantallas muy bajas */
@media (max-height: 560px){
  .hist-alt-dialog{ height: 92vh; }
}
