:root{
  --b: rgba(0,0,0,.10);
  --shadow: 0 12px 30px rgba(0,0,0,.12);
}

*{ box-sizing:border-box; }
body{ margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; background:#fff; }

/* GRID */
.wrap{ max-width:1200px; margin:0 auto; padding:14px; }
.grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
@media(min-width:720px){ .grid{ grid-template-columns:repeat(4,1fr); gap:14px; } }

.card{
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow);
  cursor:pointer;
  background:#fff;
}

.thumb{
  aspect-ratio: 1 / 1;
  background:#eee;
  overflow:hidden;
  line-height:0;
}

.thumb img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
  max-width:none !important;
  max-height:none !important;
}

/* LOADER */
.sentinel{ text-align:center; padding:24px 0 32px; }
.loader{ font-weight:700; color:#666; }

/* MODAL */
.m-bg{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999999;
}

.m{
  width:min(92vw, 980px);
  height:min(92vh, 900px);
  background:#fff;
  border-radius:18px;
  position:relative;
  overflow:hidden;
}

/* X */
.m-top-bar{
  position:absolute;
  top:0;
  left:0;
  right:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 12px;
  z-index:1000000;
  pointer-events:none;
}
.m-top-bar > *{ pointer-events:auto; }

.m-dl-buttons{
  display:flex;
  gap:6px;
}
.m-dl-btn{
  padding:8px 14px;
  border-radius:10px;
  border:0;
  background:rgba(255,255,255,.92);
  cursor:pointer;
  font-size:13px;
  font-weight:600;
  color:#1a1a2e;
  backdrop-filter:blur(6px);
  transition:background .2s;
}
.m-dl-btn:hover{ background:#fff; }

.m-close{
  width:44px;
  height:44px;
  border-radius:12px;
  border:0;
  background:#fff;
  cursor:pointer;
  font-size:24px;
  line-height:44px;
  font-weight:900;
  pointer-events:auto;
}

/* cuerpo */
.m-body{
  position:absolute;
  inset:0;
  padding:14px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.carousel{
  width:100%;
  height:100%;
  display:flex;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.carousel::-webkit-scrollbar{ display:none; }

.slide{
  flex:0 0 100%;
  scroll-snap-align:start;
  display:flex;
  align-items:center;
  justify-content:center;
}

.slide img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  display:block;
}

/* NAV */
.nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:12px;
  background:#fff;
  border:0;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
  z-index:999999;
  pointer-events:auto;
}
.nav-left{ left:10px; }
.nav-right{ right:10px; }

/* DOTS */
.dots{
  position:absolute;
  bottom:12px;
  left:0; right:0;
  display:flex;
  justify-content:center;
  gap:6px;
  z-index:999999;
}
.dot{
  width:7px; height:7px;
  border-radius:50%;
  background:#bbb;
}
.dot.on{ background:#000; }
