:root{
  --uinl-azul:#174675;
  --uinl-dorado:#f6b21a;
  --uinl-texto:#1f2937;
  --uinl-noche:#081222;
}

/* Galería */
.uinl-galeria{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr))!important;
  gap:24px!important;
  margin:32px 0!important;
  font-family:inherit!important;
}

.uinl-card{
  appearance:none!important;
  -webkit-appearance:none!important;
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-height:270px!important;
  padding:0!important;
  border:0!important;
  border-radius:30px!important;
  overflow:hidden!important;
  background:#fff!important;
  cursor:pointer!important;
  text-align:left!important;
  box-shadow:0 14px 34px rgba(23,70,117,.18)!important;
  transition:transform .35s ease,box-shadow .35s ease!important;
  isolation:isolate!important;
}

.uinl-card:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  border-radius:30px!important;
  background:linear-gradient(180deg,rgba(0,0,0,0) 20%,rgba(0,0,0,.32) 58%,rgba(0,0,0,.88) 100%)!important;
  pointer-events:none!important;
}

.uinl-card:after{
  content:"Ver descripción"!important;
  position:absolute!important;
  top:16px!important;
  right:16px!important;
  z-index:3!important;
  padding:8px 13px!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.36)!important;
  background:rgba(255,255,255,.16)!important;
  color:#fff!important;
  font-size:12px!important;
  font-weight:900!important;
  line-height:1!important;
  letter-spacing:.02em!important;
  opacity:0!important;
  transform:translateY(-8px)!important;
  box-shadow:0 8px 24px rgba(0,0,0,.16)!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
  transition:opacity .35s ease,transform .35s ease!important;
  pointer-events:none!important;
}

.uinl-card:hover,
.uinl-card:focus{
  transform:translateY(-8px) scale(1.012)!important;
  box-shadow:0 24px 58px rgba(23,70,117,.28)!important;
  outline:none!important;
}

.uinl-card:hover:after,
.uinl-card:focus:after{
  opacity:1!important;
  transform:translateY(0)!important;
}

.uinl-card img{
  display:block!important;
  width:100%!important;
  height:290px!important;
  object-fit:cover!important;
  border-radius:30px!important;
  transition:transform .55s ease,filter .35s ease!important;
  filter:saturate(1.04) contrast(1.02)!important;
}

.uinl-card:hover img,
.uinl-card:focus img{
  transform:scale(1.08)!important;
  filter:saturate(1.12) contrast(1.06)!important;
}

.uinl-card span{
  position:absolute!important;
  left:18px!important;
  right:auto!important;
  bottom:18px!important;
  z-index:2!important;
  display:block!important;
  width:max-content!important;
  max-width:calc(100% - 36px)!important;
  padding:10px 15px!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.32)!important;
  background:rgba(7,18,34,.88)!important;
  color:#fff!important;
  font-size:21px!important;
  line-height:1.18!important;
  font-weight:950!important;
  text-shadow:0 2px 14px rgba(0,0,0,.9)!important;
  box-shadow:0 10px 25px rgba(0,0,0,.32)!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
}

/* Modal */
.uinl-modal{
  display:none!important;
  position:fixed!important;
  inset:0!important;
  z-index:999999!important;
  padding:32px!important;
  overflow:auto!important;
  background:radial-gradient(circle at top left,rgba(246,178,26,.13),transparent 32%),rgba(8,18,34,.84)!important;
  backdrop-filter:blur(9px)!important;
  -webkit-backdrop-filter:blur(9px)!important;
  animation:uinlFade .25s ease!important;
}

.uinl-modal.is-open{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}

.uinl-modal-box{
  position:relative!important;
  display:grid!important;
  grid-template-columns:minmax(0,1.22fr) minmax(330px,.78fr)!important;
  width:min(1180px,100%)!important;
  gap:0!important;
  align-items:stretch!important;
  overflow:hidden!important;
  border-radius:34px!important;
  background:#fff!important;
  box-shadow:0 30px 95px rgba(0,0,0,.42)!important;
  animation:uinlZoom .34s cubic-bezier(.2,.8,.2,1)!important;
}

.uinl-modal-img{
  position:relative!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:540px!important;
  overflow:hidden!important;
  border-radius:34px 0 0 34px!important;
  background:linear-gradient(135deg,#071222,#0d1d36)!important;
}

.uinl-modal-img:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  background:radial-gradient(circle at 28% 20%,rgba(61,137,255,.24),transparent 25%),radial-gradient(circle at 70% 82%,rgba(246,178,26,.14),transparent 28%)!important;
  pointer-events:none!important;
}

.uinl-modal-img img{
  position:relative!important;
  z-index:1!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-height:82vh!important;
  object-fit:contain!important;
  border-radius:30px!important;
  padding:14px!important;
  box-sizing:border-box!important;
}

.uinl-modal-text{
  position:relative!important;
  z-index:1!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  padding:82px 56px 54px!important;
  border-left:1px solid rgba(23,70,117,.08)!important;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)!important;
}

.uinl-modal-text:before{
  content:"Galería institucional"!important;
  display:inline-block!important;
  width:max-content!important;
  max-width:100%!important;
  margin-bottom:20px!important;
  padding:9px 14px!important;
  border-radius:999px!important;
  border:1px solid rgba(246,178,26,.45)!important;
  background:rgba(246,178,26,.18)!important;
  color:#9a6500!important;
  font-size:12px!important;
  font-weight:900!important;
  line-height:1!important;
  letter-spacing:.06em!important;
  text-transform:uppercase!important;
}

.uinl-modal-text h2{
  margin:0 0 18px!important;
  color:#2b2b2b!important;
  font-size:clamp(29px,3.4vw,46px)!important;
  line-height:1.08!important;
  font-weight:950!important;
  letter-spacing:-.03em!important;
}

.uinl-modal-text h2:before{
  content:""!important;
  display:block!important;
  width:46px!important;
  height:4px!important;
  margin-bottom:20px!important;
  border-radius:999px!important;
  background:var(--uinl-dorado)!important;
}

.uinl-modal-text p{
  max-width:52ch!important;
  margin:0!important;
  padding:0!important;
  color:var(--uinl-texto)!important;
  font-size:18px!important;
  line-height:1.75!important;
  white-space:pre-line!important;
}

/* Botones redondos y transparentes */
.uinl-modal button.uinl-close,
.uinl-modal button.uinl-nav{
  appearance:none!important;
  -webkit-appearance:none!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:0!important;
  min-height:0!important;
  padding:0!important;
  margin:0!important;
  border-radius:999px!important;
  cursor:pointer!important;
  text-decoration:none!important;
  box-shadow:0 12px 30px rgba(0,0,0,.20)!important;
  backdrop-filter:blur(12px)!important;
  -webkit-backdrop-filter:blur(12px)!important;
  transition:transform .25s ease,background .25s ease,border-color .25s ease,color .25s ease!important;
}

.uinl-modal button.uinl-close{
  position:absolute!important;
  top:18px!important;
  right:18px!important;
  z-index:10!important;
  width:48px!important;
  height:48px!important;
  border:1px solid rgba(23,70,117,.18)!important;
  background:rgba(23,70,117,.08)!important;
  color:var(--uinl-azul)!important;
  font-size:31px!important;
  font-weight:800!important;
  line-height:1!important;
}

.uinl-modal button.uinl-nav{
  position:absolute!important;
  top:50%!important;
  z-index:8!important;
  width:54px!important;
  height:54px!important;
  border:1px solid rgba(255,255,255,.36)!important;
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
  font-size:34px!important;
  font-weight:700!important;
  line-height:1!important;
  transform:translateY(-50%)!important;
}

.uinl-modal button.uinl-prev{left:22px!important;right:auto!important;}
.uinl-modal button.uinl-next{right:22px!important;left:auto!important;}

.uinl-modal button.uinl-close:hover,
.uinl-modal button.uinl-close:focus{
  background:rgba(23,70,117,.14)!important;
  border-color:rgba(23,70,117,.30)!important;
  color:var(--uinl-azul)!important;
  transform:rotate(90deg) scale(1.06)!important;
  outline:none!important;
}

.uinl-modal button.uinl-nav:hover,
.uinl-modal button.uinl-nav:focus{
  background:rgba(255,255,255,.22)!important;
  border-color:rgba(255,255,255,.58)!important;
  color:#fff!important;
  transform:translateY(-50%) scale(1.08)!important;
  outline:none!important;
}

@keyframes uinlFade{from{opacity:0}to{opacity:1}}
@keyframes uinlZoom{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Tablet y celular */
@media(max-width:860px){
  .uinl-galeria{
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;
    gap:16px!important;
  }

  .uinl-card{
    min-height:220px!important;
    border-radius:26px!important;
  }

  .uinl-card:before,
  .uinl-card img{
    border-radius:26px!important;
  }

  .uinl-card img{
    height:230px!important;
  }

  .uinl-card span{
    left:14px!important;
    right:auto!important;
    bottom:14px!important;
    max-width:calc(100% - 28px)!important;
    padding:9px 13px!important;
    font-size:18px!important;
  }

  .uinl-card:after{
    display:none!important;
  }

  .uinl-modal{
    padding:12px!important;
  }

  .uinl-modal.is-open{
    align-items:flex-start!important;
    justify-content:center!important;
  }

  .uinl-modal-box{
    grid-template-columns:1fr!important;
    width:100%!important;
    margin:10px 0 24px!important;
    border-radius:26px!important;
    overflow:hidden!important;
  }

  .uinl-modal-img{
    min-height:300px!important;
    border-radius:26px 26px 0 0!important;
  }

  .uinl-modal-img img{
    max-height:48vh!important;
    padding:10px!important;
    border-radius:24px!important;
  }

  .uinl-modal-text{
    padding:34px 22px 32px!important;
    border-left:0!important;
  }

  .uinl-modal-text:before{
    margin-bottom:16px!important;
    font-size:10px!important;
  }

  .uinl-modal-text h2{
    font-size:30px!important;
  }

  .uinl-modal-text p{
    font-size:16px!important;
    line-height:1.65!important;
  }

  .uinl-modal button.uinl-close{
    top:18px!important;
    right:18px!important;
    width:42px!important;
    height:42px!important;
    border-color:rgba(255,255,255,.36)!important;
    background:rgba(255,255,255,.13)!important;
    color:#fff!important;
    font-size:28px!important;
  }

  .uinl-modal button.uinl-nav{
    width:42px!important;
    height:42px!important;
    font-size:27px!important;
    background:rgba(255,255,255,.13)!important;
  }

  .uinl-modal button.uinl-prev{left:18px!important;}
  .uinl-modal button.uinl-next{right:18px!important;}
}

@media(max-width:480px){
  .uinl-galeria{
    grid-template-columns:1fr!important;
  }

  .uinl-card{
    border-radius:24px!important;
  }

  .uinl-card:before,
  .uinl-card img{
    border-radius:24px!important;
  }

  .uinl-card img{
    height:240px!important;
  }

  .uinl-modal{
    padding:8px!important;
  }

  .uinl-modal-box{
    border-radius:24px!important;
  }

  .uinl-modal-img{
    min-height:260px!important;
    border-radius:24px 24px 0 0!important;
  }

  .uinl-modal-img img{
    max-height:42vh!important;
    border-radius:22px!important;
  }

  .uinl-modal-text{
    padding:30px 18px 28px!important;
  }

  .uinl-modal-text h2{
    font-size:27px!important;
  }

  .uinl-modal-text p{
    font-size:15.5px!important;
  }

  .uinl-modal button.uinl-close{
    top:12px!important;
    right:12px!important;
  }

  .uinl-modal button.uinl-prev{left:12px!important;}
  .uinl-modal button.uinl-next{right:12px!important;}
}
