/* DWX Portfolio Grid - lightweight, widget-scoped styles */
.dwx-portfolio-wrap{
  --dwx-cols: 3;
  --dwx-gap: 20px;
}

.dwx-portfolio-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 16px;
}
.dwx-portfolio-filter{
  border:1px solid rgba(0,0,0,.15);
  background:transparent;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  line-height:1;
  font-size:14px;
}
.dwx-portfolio-filter.is-active{
  background: rgba(0,0,0,.08);
}

.dwx-portfolio-grid{
  display:grid;
  grid-template-columns: repeat(var(--dwx-cols), minmax(0, 1fr));
  gap: var(--dwx-gap);
}

.dwx-portfolio-wrap.layout-masonry .dwx-portfolio-grid{
  display:block;
  column-count: var(--dwx-cols);
  column-gap: var(--dwx-gap);
}
.dwx-portfolio-wrap.layout-masonry .dwx-portfolio-card{
  break-inside: avoid;
  margin: 0 0 var(--dwx-gap);
}

.dwx-portfolio-card{
  overflow:hidden;
  border-radius: 16px;
  background: transparent;
}
.dwx-portfolio-card__link{
  display:block;
  color: inherit;
  text-decoration:none;
}

.dwx-portfolio-card__media{
  position:relative;
  overflow:hidden;
  border-radius: 16px;
  background: rgba(0,0,0,.05);
}
.dwx-portfolio-card__img{
  display:block;
  width:100%;
  height:auto;
  transform: translateZ(0);
  transition: transform .35s ease;
}
.dwx-portfolio-card__placeholder{
  width:100%;
  padding-top: 70%;
}
.dwx-portfolio-card__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.25);
  opacity:0;
  transition: opacity .35s ease;
}

/* Content box */
.dwx-portfolio-card__content{
  padding: 14px 14px 16px;
  background: transparent;
}
.dwx-portfolio-card__title{
  margin:0 0 6px;
  font-size: 18px;
  line-height: 1.25;
}
.dwx-portfolio-card__caption{
  margin:0;
  font-size: 14px;
  line-height: 1.5;
  opacity: .9;
}

/* Equal height for grid cards */
.dwx-portfolio-wrap.is-equal.layout-grid .dwx-portfolio-card{
  height: 100%;
}
.dwx-portfolio-wrap.is-equal.layout-grid .dwx-portfolio-card__link{
  height: 100%;
  display:flex;
  flex-direction: column;
}
.dwx-portfolio-wrap.is-equal.layout-grid .dwx-portfolio-card__media{
  flex: 0 0 auto;
}
.dwx-portfolio-wrap.is-equal.layout-grid .dwx-portfolio-card__content{
  flex: 1 1 auto;
}

/* Hover effects (controlled by wrapper class) */
.dwx-portfolio-wrap.hover-zoom .dwx-portfolio-card:hover .dwx-portfolio-card__img{
  transform: scale(1.05);
}
.dwx-portfolio-wrap.hover-fade .dwx-portfolio-card:hover .dwx-portfolio-card__overlay{
  opacity:1;
}
.dwx-portfolio-wrap.hover-zoom_fade .dwx-portfolio-card:hover .dwx-portfolio-card__img{
  transform: scale(1.05);
}
.dwx-portfolio-wrap.hover-zoom_fade .dwx-portfolio-card:hover .dwx-portfolio-card__overlay{
  opacity:1;
}

/* Pagination */
.dwx-portfolio-pagination{
  margin-top: 18px;
}
.dwx-portfolio-pagination ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:0;
  margin:0;
}
.dwx-portfolio-pagination a,
.dwx-portfolio-pagination span{
  display:inline-block;
  padding:8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.15);
  text-decoration:none;
}
.dwx-portfolio-pagination .current{
  background: rgba(0,0,0,.08);
}

/* Load more */
.dwx-portfolio-loadmore{
  display:flex;
  flex-direction: column;
  gap:10px;
  align-items:center;
  margin-top: 18px;
}
.dwx-portfolio-loadmore__btn{
  border:1px solid rgba(0,0,0,.15);
  padding:10px 16px;
  border-radius: 12px;
  background: transparent;
  cursor: pointer;
}
.dwx-portfolio-loadmore__status{
  font-size: 14px;
  opacity: .85;
}
