/* -------------------------------------------------------------------------- */
/* file: wp-content/themes/YOUR_THEME/assets/css/style-services-photography.css */
/* Services - Photography                                                     */
/* -------------------------------------------------------------------------- */ :root {
  /* Desktop target image column max width (782px) */
  --nf-photo-img-max: 48.875rem;
  --nf-photo-gap: 1.5rem;
}
/* Fabric SVG background + tile fills (your group classes) */
.service-template-service-photography .site-main > .header-tiles {
  background: #f9f9f4;
}
.service-template-service-photography .site-main > .header-tiles .light_tiles path {
  fill: #f1f1ed;
}
.service-template-service-photography .site-main > .header-tiles .dark_tiles path {
  fill: #d4d4d0;
}
.nf-services-photo {
  position: relative;
  overflow: hidden;
  padding: 3rem 1.5rem; /* mobile first */
  max-width: 1440px;
  margin: 0 auto;
}
/* Desktop section spacing */
@media (min-width: 768px) {
  .nf-services-photo {
    padding: 3.75rem 0;
  }
}
/* Fabric should sit behind content (your .header-tiles is absolute + z-index:0) */
.nf-services-photo > .nf-fabric, .nf-services-photo > .header-tiles {
  z-index: 0;
}
.nf-services-photo__inner {
  position: relative;
  z-index: 1;
}
/* Blocks stack */
.nf-services-photo__block {
  margin: 0 0 3rem;
}
@media (min-width: 768px) {
  .nf-services-photo__block {
    margin-bottom: 7.5rem;
  }
}
/* -------------------------------------------------------------------------- */
/* Top rows                                                                   */
/* -------------------------------------------------------------------------- */
.nf-services-photo__top {
  display: grid;
  gap: var(--nf-photo-gap);
  align-items: start;
}
.nf-services-photo__top--two, .nf-services-photo__top--three {
  grid-template-columns: 1fr; /* mobile: stack */
}
.nf-services-photo__col {
  min-width: 0;
}
/* Desktop: two-col layout where the image column caps at 782px (shrinks down) */
@media (min-width: 768px) {
  .service-template-service-photography .site-main .service-photography-header {
    padding-bottom: 6rem;
		margin-bottom: 0;
  }
	.service-template-service-photography .site-main .service-photography-header h1 {
		margin-bottom: 0 !important;
	}
	.service-template-service-photography .site-main .logo-bar {
		padding: 3.25rem 1.5rem;
	}
  /* Ratio-based columns (text | image) */
  .nf-services-photo__top--two {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.234fr);
    align-items: center;
  }
  /* Cap + align the main image inside its column */
  .nf-services-photo__col--image {
    display: grid;
    justify-items: end; /* image sits to the right edge */
  }
  .nf-services-photo__img {
    width: 100%;
    max-width: var(--nf-photo-img-max, 48.875rem);
    height: auto;
  }
  /* Flip for text_right (image | text) */
  .nf-services-photo__block--text-right .nf-services-photo__top--two {
    grid-template-columns: minmax(0, 1.234fr) minmax(0, 1fr)
  }
  .nf-services-photo__block--text-right .nf-services-photo__col--image {
    justify-items: start; /* image sits to the left edge */
  }
}
/* Desktop: 3 columns for center layout */
@media (min-width: 1024px) {
  .nf-services-photo__top--three {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
    align-items: center;
  }
}
/* -------------------------------------------------------------------------- */
/* Client/description                                                         */
/* -------------------------------------------------------------------------- */
.nf-services-photo__client {
  display: grid;
  gap: 1.5rem;
}
.nf-services-photo__client-logo {
  display: block;
  max-width: 11.125rem;
  width: 100%;
  height: auto;
  margin: 0 auto;
}
.nf-services-photo__desc {
  max-width: 30rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.nf-services-photo__desc p {
  color: var(--Primary-Director-Black, #252525);
  text-align: center;
  font-feature-settings: "liga"off;
  font: var(--Mobile-P1);
  margin: 0;
}
.nf-services-photo__desc p strong {
  font: var(--Mobile-P1-Bold);
}
@media (min-width: 768px) {
  .nf-services-photo__desc p {
    font: var(--Desktop-P1);
    margin: 0;
  }
  .nf-services-photo__desc p strong {
    font: var(--Desktop-P1-Bold);
  }
}
/* -------------------------------------------------------------------------- */
/* Main images                                                                */
/* -------------------------------------------------------------------------- */
.nf-services-photo__img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
}
.nf-services-photo__img--placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 0.5rem;
  background: rgba(0, 0, 0, 0.06);
}
/* -------------------------------------------------------------------------- */
/* Additional images (gallery)                                                */
/* Mobile: ALWAYS stack (1 col). Desktop: 1/2/3 cols based on count class.    */
/* -------------------------------------------------------------------------- */
.nf-services-photo__gallery-wrap {
  margin-top: var(--nf-photo-gap);
}
.nf-services-photo__gallery {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--nf-photo-gap);
  /* mobile default = stack */
  grid-template-columns: 1fr;
}
/* Desktop switches based on count class */
@media (min-width: 768px) {
  .nf-services-photo__gallery--1 {
    grid-template-columns: 1fr;
  }
  .nf-services-photo__gallery--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .nf-services-photo__gallery--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.nf-services-photo__gallery-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
}