/* Tablet — 2 columns */
@media (min-width: 768px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .site-footer__inner {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }

  .portfolio-hero__content {
    width: min(400px, 46vw);
    margin-left: 75px;
  }
}

@media (hover: hover) and (pointer: fine) {
  .portfolio-card__link:hover .portfolio-card__image,
  .portfolio-card__link:focus-visible .portfolio-card__image {
    transform: scale(1.03) translateZ(0);
  }

  .portfolio-card__link:hover .portfolio-card__meta,
  .portfolio-card__link:focus-visible .portfolio-card__meta {
    opacity: 1;
  }
}

/* Desktop — 3 columns */
@media (min-width: 1024px) {
  .portfolio-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1279px) {
  .portfolio-gallery-wrapper__main {
    padding: 0 20px;
  }
  .portfolio-gallery__back-to-top {
    left: -10px;
  }
  .portfolio-gallery__scroll-to-bottom {
    right: -10px;
  }
}
/* Mobile navigation */
@media (max-width: 1023px) {
  .site-nav {
    display: none;
  }

  .site-header__toggle {
    display: flex;
  }
  .portfolio-hero__media {
    height: 70vh;
  }
  section.portfolio-gallery::before {
    height: 440px;
  }
}

/* Tablet — gallery navigation spacing */
@media (max-width: 991px) and (min-width: 768px) {
  .portfolio-gallery__scroll-to-bottom::before,
  .portfolio-gallery__back-to-top::before {
    height: 32px;
  }
}

/* GLightbox — tablet & mobile */
@media (max-width: 991px) {
  .glightbox-container,
  .glightbox-container .gcontainer,
  .glightbox-container .gslider {
    max-width: 100%;
    overflow-x: hidden;
  }

  .glightbox-container .ginner-container {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    padding-top: calc(44px + max(12px, env(safe-area-inset-top, 0px)));
    padding-inline: max(8px, env(safe-area-inset-left, 0px))
      max(8px, env(safe-area-inset-right, 0px));
    padding-bottom: max(8px, env(safe-area-inset-bottom, 0px));
    overflow: hidden;
  }

  .gslide-image img {
    max-width: 100%;
    max-height: calc(
      100vh - 56px - env(safe-area-inset-top, 0px) -
        env(safe-area-inset-bottom, 0px)
    );
    width: auto;
    height: auto;
    object-fit: contain;
  }

  .gclose,
  .gprev,
  .gnext {
    min-width: 44px;
    min-height: 44px;
  }

  .glightbox-clean .gclose {
    top: max(12px, env(safe-area-inset-top, 0px));
    right: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .glightbox-clean .gclose svg {
    width: 18px;
    height: auto;
  }

  .glightbox-clean .gprev,
  .glightbox-clean .gnext {
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .glightbox-clean .gprev {
    left: max(8px, env(safe-area-inset-left, 0px));
    right: auto;
  }

  .glightbox-clean .gnext {
    right: max(8px, env(safe-area-inset-right, 0px));
    left: auto;
  }

  .glightbox-clean .gprev svg,
  .glightbox-clean .gnext svg {
    width: 22px;
    height: auto;
  }
}

@media (max-width: 991px) and (orientation: landscape) {
  .glightbox-container .ginner-container {
    padding-top: max(8px, env(safe-area-inset-top, 0px));
    padding-bottom: max(8px, env(safe-area-inset-bottom, 0px));
  }

  .gslide-image img {
    max-height: calc(
      100vh - 16px - env(safe-area-inset-top, 0px) -
        env(safe-area-inset-bottom, 0px)
    );
  }

  .glightbox-clean .gclose {
    top: max(8px, env(safe-area-inset-top, 0px));
    right: max(8px, env(safe-area-inset-right, 0px));
  }
}

/* Mobile spacing adjustments */
@media (max-width: 767px) {
  .portfolio-listing {
    padding-block: var(--space-md) var(--space-lg);
  }

  .portfolio-single {
    --section-gap: var(--space-lg);
  }

  .portfolio-hero {
    display: grid;
    grid-template-columns: 1fr;
  }

  .portfolio-hero__media {
    grid-area: 1 / 1;
    width: 100%;
  }

  .portfolio-hero__content {
    position: relative;
    grid-area: 1 / 1;
    place-self: center;
    z-index: 1;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    transform: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
    max-width: none;
    min-height: auto;
    padding: 36px 32px;
    background: transparent;
    box-shadow: none;
  }

  .portfolio-hero__description,
  .portfolio-hero__separator,
  .portfolio-hero__published,
  .portfolio-hero__eyebrow::before {
    display: none;
  }
  .portfolio-hero__eyebrow,
  .portfolio-hero__title {
    color: var(--color-white);
  }

  .portfolio-gallery__pagination {
    flex-direction: row;
  }

  .portfolio-gallery-wrapper__main {
    flex-direction: column;
    align-items: stretch;
  }

  .portfolio-gallery__scroll-to-bottom {
    order: -1;
  }

  .portfolio-gallery-wrapper__main > .gallery {
    order: 0;
  }

  .portfolio-gallery__back-to-top {
    order: 1;
  }

  /* Portfolio card — mobile overlay */
  .portfolio-card__meta {
    background: transparent;
    opacity: 1;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0;
  }

  .portfolio-card__names {
    color: #ffffff;
  }

  .portfolio-card__names::before {
    display: none;
  }

  .portfolio-card__location {
    color: #ffffff;
    text-align: center;
  }

  .portfolio-card__separator,
  .portfolio-card__cta {
    display: none;
  }
  .portfolio-hero__title {
    margin-bottom: 0;
  }
  .topMenus,
  .portfolio-single {
    padding-top: var(--space-md);
  }
  .topMenus ul {
    flex-wrap: wrap;
    row-gap: 10px;
  }
  section.portfolio-gallery::before {
    height: 370px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .portfolio-card__image,
  .portfolio-hero__image {
    transform: none !important;
  }

  .gslideInRight,
  .gslideInLeft,
  .gslideOutLeft,
  .gslideOutRight {
    animation: none !important;
  }
}
