/* Gallery (portfolio) page styles, extracted from the static design. */

/* Hero: compact, editorial — image left, text right */
.gal-hero {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  min-height: 420px;
}

.gal-hero__media {
  position: relative;
  overflow: hidden;
}

.gal-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  transition: transform 8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gal-hero__media:hover .gal-hero__img {
  transform: scale(1.05);
}

.gal-hero__text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--sp-64);
  background: var(--color-bg-dark);
  color: var(--color-text-inverse);
}

.gal-hero__label {
  font-family: var(--ff-sans);
  font-size: var(--fs-11);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  color: var(--color-gold);
  margin-bottom: var(--sp-20);
}

.gal-hero__heading {
  font-family: var(--ff-serif);
  font-size: clamp(var(--fs-32), 3.5vw, var(--fs-48));
  font-weight: var(--fw-light);
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-20);
}

.gal-hero__body {
  font-size: var(--fs-15);
  line-height: var(--lh-normal);
  color: rgba(245, 240, 232, 0.7);
  max-width: 440px;
}

.gal-hero__count {
  display: flex;
  gap: var(--sp-32);
  margin-top: var(--sp-32);
  padding-top: var(--sp-24);
  border-top: 1px solid rgba(245, 240, 232, 0.1);
}

.gal-hero__count-item {
  display: flex;
  flex-direction: column;
}

.gal-hero__count-num {
  font-family: var(--ff-serif);
  font-size: var(--fs-28);
  font-weight: var(--fw-light);
  line-height: 1;
  color: var(--color-text-inverse);
}

.gal-hero__count-label {
  font-family: var(--ff-sans);
  font-size: var(--fs-11);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: rgba(245, 240, 232, 0.5);
  margin-top: var(--sp-4);
}

/* Filter bar */
.gal-filters {
  background: var(--color-bg-cream);
  border-bottom: 1px solid var(--color-border);
  padding: var(--sp-20) 0;
  position: sticky;
  top: var(--header-height);
  z-index: 10;
  transition: box-shadow 0.3s var(--ease-out);
}

.gal-filters--shadow {
  box-shadow: 0 4px 20px rgba(43, 40, 32, 0.08);
}

.gal-filters__inner {
  display: flex;
  align-items: center;
  gap: var(--sp-12);
  flex-wrap: wrap;
}

.gal-filters__label {
  font-family: var(--ff-sans);
  font-size: var(--fs-12);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--color-text-light);
  margin-right: var(--sp-8);
}

.gal-filter-btn {
  font-family: var(--ff-sans);
  font-size: var(--fs-13);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  background: transparent;
  border: 1px solid var(--color-border);
  padding: var(--sp-8) var(--sp-20);
  cursor: pointer;
  transition: all 0.3s var(--ease-out);
  white-space: nowrap;
  position: relative;
}

.gal-filter-btn:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.gal-filter-btn.active {
  background: var(--color-bg-dark);
  border-color: var(--color-bg-dark);
  color: var(--color-text-inverse);
}

.gal-filter-btn__count {
  font-size: var(--fs-11);
  font-weight: var(--fw-regular);
  opacity: 0.5;
  margin-left: var(--sp-4);
}

.gal-filter-btn.active .gal-filter-btn__count {
  opacity: 0.7;
}

/* Gallery grid */
.gal-grid {
  padding: var(--sp-64) 0 var(--sp-96);
}

.gal-grid__inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-20);
}

/* Project card — with animated filter transitions */
.gal-card {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: var(--color-bg-dark);
  transition:
    opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.gal-card.hiding {
  opacity: 0;
  transform: scale(0.94);
  pointer-events: none;
}

.gal-card.hidden {
  display: none;
}

.gal-card.showing {
  animation: cardReveal 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes cardReveal {
  0% {
    opacity: 0;
    transform: scale(0.94) translateY(16px);
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.gal-card--tall {
  grid-row: span 2;
}

.gal-card--wide {
  grid-column: span 2;
}

/* Image shimmer loading */
.gal-card__img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: linear-gradient(110deg, #E5E0D7 0%, #EDEAD4 40%, #E5E0D7 60%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
}

.gal-card__img-wrap.loaded {
  animation: none;
  background: none;
}

@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.gal-card .gal-card__img[loading="lazy"],
.gal-card .gal-card__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--color-bg-cream);
  aspect-ratio: 4 / 3;
  display: block;
  opacity: 0;
  transform: scale(1.01);
  transition:
    transform 2s cubic-bezier(0.4, 0, 0.2, 1),
    filter 1.2s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.6s var(--ease-out);
}

.gal-card .gal-card__img.loaded {
  opacity: 1;
  transform: scale(1);
}

.gal-card--tall .gal-card__img {
  aspect-ratio: 2 / 3;
}

.gal-card--wide .gal-card__img {
  aspect-ratio: 16 / 9;
}

.gal-card:hover .gal-card__img[loading="lazy"],
.gal-card:hover .gal-card__img {
  transform: scale(1.04);
  filter: brightness(0.55);
}

/* Overlay — layered entrance: gradient first, then text slides up */
.gal-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--sp-28);
  background: linear-gradient(to top, rgba(43, 40, 32, 0.92) 0%, rgba(43, 40, 32, 0.25) 45%, rgba(43, 40, 32, 0) 65%);
  opacity: 0;
  transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.15s;
}

.gal-card:hover .gal-card__overlay {
  opacity: 1;
}

.gal-card__overlay-inner {
  transform: translateY(14px);
  opacity: 0;
  transition:
    transform 0.7s cubic-bezier(0.4, 0, 0.2, 1) 0.3s,
    opacity 0.7s cubic-bezier(0.4, 0, 0.2, 1) 0.3s;
}

.gal-card:hover .gal-card__overlay-inner {
  transform: translateY(0);
  opacity: 1;
}

.gal-card__tag {
  font-family: var(--ff-sans);
  font-size: var(--fs-11);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--color-gold);
  margin-bottom: var(--sp-8);
}

.gal-card__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-24);
  font-weight: var(--fw-light);
  line-height: var(--lh-snug);
  color: var(--color-text-inverse);
  margin-bottom: var(--sp-4);
}

.gal-card__desc {
  font-family: var(--ff-sans);
  font-size: var(--fs-13);
  line-height: var(--lh-normal);
  color: rgba(245, 240, 232, 0.6);
}

/* Expand icon on hover */
.gal-card__expand {
  position: absolute;
  top: var(--sp-16);
  right: var(--sp-16);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(43, 40, 32, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 50%;
  color: var(--color-text-inverse);
  opacity: 0;
  transform: scale(0.7) translateY(4px);
  transition:
    opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1) 0.4s,
    transform 0.6s cubic-bezier(0.4, 0, 0.2, 1) 0.4s;
}

.gal-card:hover .gal-card__expand {
  opacity: 0.9;
  transform: scale(1) translateY(0);
}

/* Staggered scroll reveal for cards */
.gal-card[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out);
}

.gal-card[data-reveal].revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Featured project — full-width with parallax overlay */
.gal-featured {
  position: relative;
  overflow: hidden;
  margin-bottom: var(--sp-20);
  cursor: pointer;
}

.gal-featured .gal-featured__img[loading="lazy"],
.gal-featured .gal-featured__img {
  width: 100%;
  height: 440px;
  object-fit: cover;
  display: block;
  filter: brightness(0.4);
  transition:
    transform 2s cubic-bezier(0.4, 0, 0.2, 1),
    filter 1s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.6s var(--ease-out);
}

.gal-featured:hover .gal-featured__img {
  transform: scale(1.04);
  filter: brightness(0.3);
}

.gal-featured__content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: var(--sp-40);
  color: var(--color-text-inverse);
}

.gal-featured__label {
  font-family: var(--ff-sans);
  font-size: var(--fs-11);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  color: var(--color-gold);
  margin-bottom: var(--sp-16);
}

.gal-featured__heading {
  font-family: var(--ff-serif);
  font-size: clamp(var(--fs-32), 3.5vw, var(--fs-48));
  font-weight: var(--fw-light);
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-12);
}

.gal-featured__text {
  font-size: var(--fs-15);
  line-height: var(--lh-normal);
  color: rgba(245, 240, 232, 0.7);
  max-width: 560px;
  margin-bottom: var(--sp-24);
}

.gal-featured__cta {
  font-family: var(--ff-sans);
  font-size: var(--fs-12);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--color-gold);
  border: 1px solid rgba(130, 119, 75, 0.4);
  padding: var(--sp-12) var(--sp-28);
  transition:
    background 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.1s,
    border-color 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.1s,
    color 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.1s;
  text-decoration: none;
  display: inline-block;
}

.gal-featured:hover .gal-featured__cta {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-text-inverse);
}

/* Stat band */
.gal-stats {
  position: relative;
  padding: var(--sp-64) 0;
  overflow: hidden;
}

.gal-stats__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.3);
}

.gal-stats__inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-56);
}

.gal-stat {
  text-align: center;
  color: var(--color-text-inverse);
}

.gal-stat__number {
  font-family: var(--ff-serif);
  font-size: clamp(var(--fs-36), 4vw, var(--fs-60));
  font-weight: var(--fw-light);
  line-height: 1;
  margin-bottom: var(--sp-8);
}

.gal-stat__label {
  font-family: var(--ff-sans);
  font-size: var(--fs-12);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: rgba(245, 240, 232, 0.6);
}

.gal-stat__sep {
  width: 1px;
  height: 48px;
  background: rgba(245, 240, 232, 0.15);
}

/* ---- Lightbox — Premium ---- */
.gal-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(43, 40, 32, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-40);
  pointer-events: none;
  transition: background 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.gal-lightbox.active {
  pointer-events: auto;
  background: rgba(43, 40, 32, 0.96);
}

.gal-lightbox__close {
  position: absolute;
  top: var(--sp-24);
  right: var(--sp-24);
  background: rgba(245, 240, 232, 0.08);
  border: 1px solid rgba(245, 240, 232, 0.1);
  color: var(--color-text-inverse);
  cursor: pointer;
  padding: var(--sp-12);
  border-radius: 50%;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s var(--ease-out);
  opacity: 0;
  transform: translateY(-8px);
}

.gal-lightbox.active .gal-lightbox__close {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.2s;
}

.gal-lightbox__close:hover {
  background: rgba(245, 240, 232, 0.15);
  border-color: rgba(245, 240, 232, 0.2);
}

.gal-lightbox__stage {
  position: relative;
  max-width: 85vw;
  max-height: 75vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gal-lightbox__img {
  max-width: 85vw;
  max-height: 75vh;
  object-fit: contain;
  opacity: 0;
  transform: scale(0.96);
  transition:
    opacity 0.45s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: zoom-in;
  user-select: none;
  -webkit-user-select: none;
}

.gal-lightbox__img.zoomed {
  cursor: zoom-out;
  max-width: none;
  max-height: none;
}

.gal-lightbox.active .gal-lightbox__img {
  opacity: 1;
  transform: scale(1);
}

.gal-lightbox__img.transitioning {
  opacity: 0;
  transform: scale(0.96);
}

.gal-lightbox__info {
  position: absolute;
  bottom: var(--sp-40);
  left: 50%;
  transform: translateX(-50%) translateY(12px);
  text-align: center;
  color: var(--color-text-inverse);
  opacity: 0;
  transition: all 0.4s var(--ease-out);
  white-space: nowrap;
}

.gal-lightbox.active .gal-lightbox__info {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  transition-delay: 0.15s;
}

.gal-lightbox__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-24);
  font-weight: var(--fw-light);
  margin-bottom: var(--sp-4);
}

.gal-lightbox__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-16);
}

.gal-lightbox__desc {
  font-family: var(--ff-sans);
  font-size: var(--fs-13);
  color: rgba(245, 240, 232, 0.6);
}

.gal-lightbox__counter {
  font-family: var(--ff-sans);
  font-size: var(--fs-12);
  font-weight: var(--fw-medium);
  color: rgba(245, 240, 232, 0.35);
  letter-spacing: var(--ls-wide);
}

.gal-lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(245, 240, 232, 0.06);
  border: 1px solid rgba(245, 240, 232, 0.08);
  border-radius: 50%;
  color: var(--color-text-inverse);
  cursor: pointer;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s var(--ease-out);
  opacity: 0;
}

.gal-lightbox.active .gal-lightbox__nav {
  opacity: 1;
  transition-delay: 0.25s;
}

.gal-lightbox__nav:hover {
  background: rgba(245, 240, 232, 0.12);
  border-color: rgba(245, 240, 232, 0.15);
  transform: translateY(-50%) scale(1.05);
}

.gal-lightbox__nav--prev {
  left: var(--sp-24);
}

.gal-lightbox__nav--next {
  right: var(--sp-24);
}

/* Lightbox dots */
.gal-lightbox__dots {
  position: absolute;
  bottom: var(--sp-16);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--sp-8);
  opacity: 0;
  transition: opacity 0.4s var(--ease-out);
}

.gal-lightbox.active .gal-lightbox__dots {
  opacity: 1;
  transition-delay: 0.3s;
}

.gal-lightbox__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(245, 240, 232, 0.2);
  transition: all 0.3s var(--ease-out);
  cursor: pointer;
  border: none;
  padding: 0;
}

.gal-lightbox__dot.active {
  background: var(--color-gold);
  transform: scale(1.3);
}

/* ---- Responsive ---- */
@media (max-width: 1100px) {
  .gal-grid__inner {
    grid-template-columns: repeat(2, 1fr);
  }

  .gal-card--wide {
    grid-column: span 1;
  }

  .gal-card--wide .gal-card__img {
    aspect-ratio: 4 / 3;
  }
}

@media (max-width: 768px) {
  .gal-hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .gal-hero__media {
    aspect-ratio: 16 / 10;
  }

  .gal-hero__text {
    padding: var(--sp-40) var(--container-pad);
  }

  .gal-hero__count {
    gap: var(--sp-24);
  }

  .gal-grid__inner {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-12);
  }

  .gal-card--tall {
    grid-row: span 1;
  }

  .gal-card--tall .gal-card__img {
    aspect-ratio: 4 / 3;
  }

  .gal-card__overlay {
    opacity: 1;
    background: linear-gradient(to top, rgba(43, 40, 32, 0.85) 0%, rgba(43, 40, 32, 0) 55%);
    padding: var(--sp-16);
  }

  .gal-card__overlay-inner {
    transform: translateY(0);
  }

  .gal-card__expand {
    display: none;
  }

  .gal-card__title {
    font-size: var(--fs-18);
  }

  .gal-card__desc {
    font-size: var(--fs-12);
  }

  .gal-featured__img {
    height: 300px;
  }

  .gal-stats__inner {
    gap: var(--sp-32);
  }

  .gal-filters__inner {
    gap: var(--sp-8);
  }

  .gal-filter-btn {
    padding: var(--sp-8) var(--sp-16);
    font-size: var(--fs-12);
  }

  .gal-lightbox__img {
    max-width: 95vw;
    max-height: 70vh;
  }

  .gal-lightbox__nav {
    width: 40px;
    height: 40px;
  }

  .gal-lightbox__nav--prev {
    left: var(--sp-8);
  }

  .gal-lightbox__nav--next {
    right: var(--sp-8);
  }
}

@media (max-width: 480px) {
  .gal-hero__text {
    padding: var(--sp-32) var(--sp-20);
  }

  .gal-hero__heading {
    font-size: var(--fs-28);
  }

  .gal-hero__count {
    flex-wrap: wrap;
    gap: var(--sp-20);
  }

  .gal-grid__inner {
    grid-template-columns: 1fr;
    gap: var(--sp-12);
  }

  .gal-grid {
    padding: var(--sp-40) 0 var(--sp-64);
  }

  .gal-stats__inner {
    flex-wrap: wrap;
    gap: var(--sp-24);
    justify-content: space-around;
  }

  .gal-stat__sep {
    display: none;
  }

  .gal-featured__img {
    height: 240px;
  }

  .gal-featured__heading {
    font-size: var(--fs-28);
  }

  .gal-lightbox {
    padding: var(--sp-12);
  }

  .gal-lightbox__info {
    bottom: var(--sp-56);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .gal-card,
  .gal-card__img,
  .gal-card__overlay,
  .gal-card__overlay-inner,
  .gal-card__expand,
  .gal-featured__img,
  .gal-lightbox,
  .gal-lightbox__img,
  .gal-lightbox__close,
  .gal-lightbox__nav,
  .gal-lightbox__info,
  .gal-lightbox__dots,
  .gal-hero__img {
    transition-duration: 0.01s !important;
    animation-duration: 0.01s !important;
  }

  .gal-card[data-reveal] {
    opacity: 1;
    transform: none;
  }
}
