:root{ --chip-active:#FFBF1C; --gap:12px; }

.cslib-grid-wrap{ margin:1rem 0; }
.cslib-tabs{
  display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:1rem;
  justify-content:center; /* center the tabs */
}
.cslib-tab{
  padding:.5rem .9rem; border:1px solid rgba(0,0,0,.12);
  border-radius:9999px; background:#fff; cursor:pointer; user-select:none;
  font-weight:700; line-height:1; display:inline-flex; align-items:center; gap:.4rem;
  font-size:18px; /* requested size */
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.cslib-tab-count{
  font-size:14px; /* Smaller font for the count */
  font-weight: 500;
  color: #888;
}
.cslib-tab.active{ background:var(--chip-active); color:#000; border-color:transparent; }
.cslib-tab:not(.active):hover{ background:rgba(0,0,0,.05); }

/* Grid base */
.cslib-grid{
  --cols: 5;
  display:grid;
  grid-template-columns: repeat(var(--cols), minmax(0,1fr));
  gap: var(--gap, 12px);
  grid-auto-flow: dense;
}
@media (max-width:1024px){ .cslib-grid{ --cols: 3; } } /* tablet */
@media (max-width:560px){ .cslib-grid{ --cols: 2; } }   /* mobile */

/* Cards */
.cslib-card{
  position:relative; overflow:hidden; background:#111; color:#fff;
  border-radius: var(--radius, 12px);
  aspect-ratio: var(--ar, 1 / 1); /* square by default; JS sets for pattern */
  transform:translateZ(0);
}
.cslib-card-inner{ position:relative; width:100%; height:100%; }
.cslib-card img{ width:100%; height:100%; object-fit:cover; display:block; }
.cslib-card .ph{ display:grid; place-items:center; background:#e6e6e6; color:#666; font-weight:600 }

/* Group badges (upper-left) */
.cslib-badges{ position:absolute; left:8px; top:8px; z-index:2; display:flex; gap:6px; flex-wrap:wrap; }
.cslib-badge{
  background: var(--badge-bg, rgba(0,0,0,.65));
  color:#fff; padding:.22rem .5rem; border-radius:8px; font-size:.78rem;
  line-height:1; white-space:nowrap;
  transition: background .25s ease;
}
.cslib-title{
  position:absolute; inset:auto 8px 8px 8px; z-index:2;
  text-align:center; font-weight:700; font-size: var(--title-px, 18px);
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}

/* Hover effects */
.cslib-hover-none .cslib-card{ transition:transform .25s ease; }
.cslib-hover-lift-zoom .cslib-card{ transition:transform .25s ease; }
.cslib-hover-lift-zoom .cslib-card:hover{ transform:translateY(-4px) scale(1.02); }
.cslib-hover-glow .cslib-card{ transition:box-shadow .25s ease, transform .25s ease; }
.cslib-hover-glow .cslib-card:hover{ box-shadow:0 10px 24px rgba(0,0,0,.35); transform:translateY(-2px); }
.cslib-hover-tilt .cslib-card{ transition:transform .25s ease; }
.cslib-hover-tilt .cslib-card:hover{ transform:perspective(600px) rotateX(2deg) rotateY(-2deg) scale(1.01); }
.cslib-hover-shadow-pop .cslib-card{ transition:box-shadow .25s ease, transform .25s ease; }
.cslib-hover-shadow-pop .cslib-card:hover{ box-shadow:0 16px 30px rgba(0,0,0,.3); transform:translateY(-3px); }

/* Load More Button */
.cslib-load-more{
  display:block; width:fit-content; margin:2rem auto 0;
  padding:1rem 2rem; border:2px solid transparent; border-radius:99px;
  background:#FFBF1C; color:#000; font-size:16px; font-weight:700;
  cursor:pointer; transition:background .2s ease, transform .2s ease;
}
.cslib-load-more:hover{
  background:#FFD60A;
}
