
/* CPTUR Mosaic Gallery (Airbnb style) */
.cptur-mosaic{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:16px;
  align-items:stretch;
}

/* Main (left) defines the height of the whole section */
.cptur-mosaic__main{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:16/9;
  min-height:460px; /* desktop min */
}

/* Right grid stretches to the exact height of the main image */
.cptur-mosaic__grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  grid-template-rows:repeat(2,1fr);
  gap:16px;
  height:100%;
  min-height:0;
}

.cptur-mosaic__tile{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  min-height:0;
}

.cptur-mosaic__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:translateZ(0);
}

/* Fill */
.cptur-mosaic a.cptur-mosaic__item{display:block;height:100%;}
.cptur-mosaic__main a.cptur-mosaic__item,
.cptur-mosaic__tile a.cptur-mosaic__item{position:absolute;inset:0;}

/* Button */
.cptur-mosaic__allbtn{
  position:absolute;
  right:14px;
  bottom:14px;
  height:auto;
  z-index:2;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  padding:10px 14px;
  font-size:14px;
  font-weight:600;
  line-height:1;
  display:inline-flex;
  gap:8px;
  align-items:center;
  box-shadow:0 8px 24px rgba(0,0,0,.14);
  cursor:pointer;
  text-decoration:none;
  color:inherit;
}
.cptur-mosaic__allbtn i{font-size:18px;line-height:1;}

.cptur-mosaic__overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
  font-size:16px;
  text-align:center;
  padding:12px;
}
.cptur-mosaic__overlay span{
  background:rgba(0,0,0,.32);
  padding:10px 12px;
  border-radius:999px;
}

/* Hidden anchors */
.cptur-mosaic__hidden{display:none !important;}

/* max_tiles variants */
.cptur-mosaic--3 .cptur-mosaic__grid{
  grid-template-columns:1fr;
  grid-template-rows:repeat(2,1fr);
}
.cptur-mosaic--2 .cptur-mosaic__grid{
  grid-template-columns:1fr;
  grid-template-rows:1fr;
}

/* Responsive min-heights */
@media(max-width:1200px){
  .cptur-mosaic__main{min-height:420px;}
}
@media(max-width:1024px){
  .cptur-mosaic{gap:14px;}
  .cptur-mosaic__grid{gap:14px;}
  .cptur-mosaic__main{min-height:360px;}
}
@media(max-width:768px){
  .cptur-mosaic{
    grid-template-columns:1fr;
    gap:12px;
  }
  .cptur-mosaic__grid{
    gap:12px;
    height:auto;
  }
  .cptur-mosaic__main{
    min-height:240px;
    aspect-ratio:16/10;
  }
  .cptur-mosaic__tile{
    aspect-ratio:1/1;
  }
  .cptur-mosaic__tile a.cptur-mosaic__item{position:relative;}
  .cptur-mosaic__allbtn{right:10px;bottom:10px;padding:9px 12px;font-size:13px;}
}
@media(max-width:480px){
  .cptur-mosaic__main{min-height:200px;}
}
