/* Portfolio category badge colors (Figma) */
.zg3-portfolio-badge {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 6px 10px;
  border-radius: var(--zg3-r-full);
  color: var(--zg3-white);
  background: var(--zg3-secondary);
}
.zg3-portfolio-badge.zg3-badge--cat-weddings,
.zg3-portfolio-badge.zg3-badge--cat-wedding  { background: #ed699d; }
.zg3-portfolio-badge.zg3-badge--cat-corporate,
.zg3-portfolio-badge.zg3-badge--cat-corporate-events { background: var(--zg3-primary); }
.zg3-portfolio-badge.zg3-badge--cat-business,
.zg3-portfolio-badge.zg3-badge--cat-business-events { background: #3f3ac5; }
.zg3-portfolio-badge.zg3-badge--cat-kids,
.zg3-portfolio-badge.zg3-badge--cat-kids-parties { background: #ed699d; }

/* Section header: portfolio-specific h2 */
#portfolio .zg3-h2,
#portfolio .zg3-section-header--flex h2 {
  font-size: 42px;
  font-weight: 600;
  letter-spacing: -0.04em;
  text-transform: none;
}



/* Desktop: 4 equal columns */
.zg3-portfolio-grid-v2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--zg3-sp-16);
}

/* Card v2 */
.zg3-portfolio-card-v2 {
  display: flex;
  flex-direction: column;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
}
.zg3-portfolio-card-v2:hover { transform: translateY(-4px); }

.zg3-portfolio-card-v2__image {
  position: relative;
  overflow: hidden;
  border-radius: var(--zg3-r-lg);
  aspect-ratio: 4/5;
}
.zg3-portfolio-card-v2__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.22,1,0.36,1);
}
.zg3-portfolio-card-v2:hover .zg3-portfolio-card-v2__image img {
  transform: scale(1.05);
}

.zg3-portfolio-card-v2__badges {
  position: absolute;
  bottom: var(--zg3-sp-12);
  left: var(--zg3-sp-12);
  display: flex;
  flex-wrap: wrap;
  gap: var(--zg3-sp-4);
}

.zg3-portfolio-card-v2__body {
  padding: var(--zg3-sp-16) 0 0;
}
.zg3-portfolio-card-v2__title {
  font-size: 20px;
  font-weight: var(--zg3-fw-semibold);
  margin-bottom: var(--zg3-sp-4);
  line-height: 1.3;
}
.zg3-portfolio-card-v2__excerpt {
  font-size: var(--zg3-fs-small);
  color: var(--zg3-gray);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Tablet: 2 cols */
@media (max-width: 1023px) {
  .zg3-portfolio-grid-v2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile Swiper */
.zg3-portfolio-swiper { padding-bottom: var(--zg3-sp-48); }
.zg3-portfolio-swiper .swiper-slide { width: 65vw; }
@media (max-width: 767px) {
  .zg3-portfolio-swiper { overflow: visible; }
  .zg3-portfolio-card-v2__image { aspect-ratio: 4/5; }

  /* ── Native scroll mode ─────────────────────── */
  .zg3-portfolio-swiper.zg3-scroll-mode {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 16px;
    padding-bottom: 0;
  }
  .zg3-portfolio-swiper.zg3-scroll-mode::-webkit-scrollbar { display: none; }
  .zg3-portfolio-swiper.zg3-scroll-mode .swiper-wrapper {
    display: flex;
    flex-wrap: nowrap;
    padding-left: 16px;
    padding-right: 16px;
    gap: 12px;
  }
  .zg3-portfolio-swiper.zg3-scroll-mode .swiper-slide {
    scroll-snap-align: start;
    flex-shrink: 0;
  }
}
