/* =========================================================
   PAGE REALISATIONS
   ========================================================= */

.projects-page {
  display: flex;
  flex-direction: column;
}

.projects-wall {
  padding: 32px 0 40px;
  flex: 1;
}

.projects-wall__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  align-items: stretch;
}

/* =========================================================
   BLOCS TEXTE
   ========================================================= */

.projects-copy {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  padding: 6vh 3vw 6vh 3vw;
  overflow: hidden;
  isolation: isolate;
}

.projects-copy > * {
  position: relative;
  z-index: 1;
}

.projects-copy__eyebrow {
  margin: 0 0 18px;
  color: rgb(var(--color-brand));
  font-size: var(--contact-eyebrow-size);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.projects-copy__title {
  max-width: 40ch;
  margin: 0;
  font-size: clamp(1rem, 3vw, 2rem);
  letter-spacing: -0.04em;
  font-weight: 800;
  text-wrap: balance;
}

.projects-copy__list {
  display: grid;
  gap: 10px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.projects-copy__list li {
  position: relative;
  padding-left: 24px;
  font-weight: 500;
}

.projects-copy__list li::before {
  content: "✓";
  position: absolute;
  top: 0;
  left: 0;
  font-size: 0.82rem;
  font-weight: 700;
}

.projects-copy--industry::before,
.projects-copy--animation::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgb(var(--color-grid)) 1px, transparent 1px),
    linear-gradient(90deg, rgb(var(--color-grid)) 1px, transparent 1px);
  background-size: 80px 80px;
  background-position: 0 0;
}

.projects-copy--animation::before {
  background-position: calc(100% - 1px) calc(100% - 1px);
}

/* =========================================================
   GALERIES
   ========================================================= */

.projects-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-self: start;
}

.project-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  border: 1px solid rgb(var(--color-grid));
  background: rgb(var(--color-bg));
  isolation: isolate;
}

/* image 4:3 paysage en haut */
.project-tile__image {
  display: block;
  margin-inline: auto;
  width: 90%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center;
  filter: grayscale(1) contrast(1.04) brightness(0.82);
  flex-shrink: 0;
  padding: 15px 10px 5px 10px;
  transition: filter 260ms ease;
  -webkit-user-drag: none;
  user-select: none;
}

/* bloc texte en bas */
.project-tile__overlay {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 5px;
  flex: 1;
  padding: 7px 10px 0px;
  overflow: hidden;
  background: white;
}

.project-tile__title,
.project-tile__text {
  position: relative;
  z-index: 1;
  transition: color 260ms ease;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

.project-tile__title {
  margin: 0;
  font-size: clamp(0.65rem, 0.95vw, 0.85rem);
  font-weight: 600;
  line-height: 0.8;
  color: rgb(var(--color-muted));
  text-align: left;

}

.project-tile__text {
  margin: 0;
  font-size: clamp(0.6rem, 0.85vw, 0.75rem);
  line-height: 1.45;
  color: rgb(var(--color-muted));
  text-align: left;
}

/* =========================================================
   HOVER
   ========================================================= */

@media (hover: hover) and (pointer: fine) {
  .project-tile:hover .project-tile__image,
  .project-tile:focus-within .project-tile__image {
    filter: grayscale(0) contrast(1) brightness(1);
  }

  .project-tile:hover .project-tile__overlay::before,
  .project-tile:focus-within .project-tile__overlay::before {
    opacity: 0;
  }

  .project-tile:hover .project-tile__title,
  .project-tile:focus-within .project-tile__title,
  .project-tile:hover .project-tile__text,
  .project-tile:focus-within .project-tile__text {
    color: rgb(20 20 20);
  }
}

@media (hover: none), (pointer: coarse) {
  .project-tile__image {
    filter: grayscale(0) contrast(1) brightness(1);
  }

  .project-tile__title,
  .project-tile__text {
    color: rgb(20 20 20);
  }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 1200px) {
  .projects-copy__title {
    max-width: 40ch;
    font-size: clamp(1.8rem, 2.6vw, 2.6rem);
  }
}

@media (max-width: 920px) {
  .projects-wall {
    padding: 20px 0 28px;
  }

  .projects-wall__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .projects-copy,
  .projects-gallery {
    height: auto;
  }

  .projects-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .projects-copy--industry {
    order: 1;
  }

  .projects-gallery--industry {
    order: 2;
  }

  .projects-copy--animation {
    order: 3;
  }

  .projects-gallery--animation {
    order: 4;
  }
  
  .projects-copy--industry::before,
  .projects-copy--animation::before {
    background-size: 60px 60px;
  }
  
  .project-tile__overlay {
	  gap: 10px;
	  padding: 10px 20px 0px;
	}
  
  .project-tile__title {
    font-size: clamp(0.7rem, 2vw, 2.5rem);
  }

  .project-tile__text {
	 font-size: clamp(0.6rem, 1.8vw, 2rem);
   }
  
}

@media (max-width: 640px) {
  .projects-copy {
    padding: 24px 20px;
    border-radius: 20px;
  }
  
  .projects-copy__title {
    max-width: 40ch;
    font-size: clamp(1rem, 4vw, 2.8rem);
  }
  
  .projects-copy__list li {
	  font-size: clamp(0.8rem, 2.5vw, 3rem);
	}

  .projects-gallery {
    /* grid-template-columns: 2fr; */
    gap: 10px;
  }

  .project-tile__overlay {
    padding: 16px 16px 18px;
  }

  .project-tile__title {
    font-size: 0.94rem;
  }

  .project-tile__text {
    font-size: 0.81rem;
  }
  
  .projects-copy--industry::before,
  .projects-copy--animation::before {
    background-size: 50px 50px;
  }
  
  .project-tile__overlay {
	  gap: 2px;
      padding: 2px 10px 0px;
	}
  
  .project-tile__title {
	line-height: 1.3;
	text-align: center;
	margin: auto;
    font-size: clamp(0.7rem, 2.8vw, 1rem);
  }

  .project-tile__text {
	  display:none;
	 font-size: clamp(0.5rem, 2vw, 2.5rem);
   }
}