/* @import url('https://fonts.googleapis.com/css2?family=Maven+Pro:wght@400..900&display=swap'); */
/* @import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&family=Poiret+One&display=swap'); */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Orbitron:wght@400..900&family=Play:wght@400;700&family=Titillium+Web:ital,wght@0,200;0,300;0,400;0,600;0,700;0,900;1,200;1,300;1,400;1,600;1,700&display=swap');

:root {
    --project-numcols: 2;
    --project-gutter: 10px;
  }
.grid-project {
	display: grid;
	grid-template-columns: repeat(var(--project-numcols, 3), 1fr);
	grid-auto-rows: calc(
		(9 / 16) *
		(100vw - (var(--project-gutter, 1rem) * (var(--project-numcols, 3) + 1))) /
		var(--project-numcols, 3)
	);
	grid-auto-flow: dense;
	grid-column-gap: var(--project-gutter, 1rem);
	grid-row-gap: var(--project-gutter, 1rem);
}

@media (min-width: 769px) and (max-width: 1440px) {
  :root {
    --project-numcols: 3;
    --project-gutter: 20px;
  }
  .grid-project {
	  display: grid;
	  grid-template-columns: repeat(var(--project-numcols, 3), 1fr);
	  grid-auto-rows: calc(
		(9 / 16) *
		  (100vw - (var(--project-gutter, 1rem) * (var(--project-numcols, 3) + 1))) /
		  var(--project-numcols, 3)
	  );
	  grid-auto-flow: dense;
	  grid-column-gap: var(--project-gutter, 1rem);
	  grid-row-gap: var(--project-gutter, 1rem);
	}
}

@media (min-width: 1441px) {
  :root {
    --project-numcols: 3;
    --project-gutter: 20px;
  }
  .grid-project {
	  display: grid;
	  grid-template-columns: repeat(var(--project-numcols, 3), 1fr);
	  grid-auto-rows: 320px;
	  grid-auto-flow: dense;
	  grid-column-gap: var(--project-gutter, 1rem);
	  grid-row-gap: var(--project-gutter, 1rem);
	}
}

.grid-project.grid-project--4columns {
  --project-numcols: 4;
  grid-auto-rows: calc(
    (15 / 16) *
      (100vw - (var(--project-gutter, 1rem) * (var(--project-numcols, 3)))) /
      var(--project-numcols, 3)
  );
}

@media (max-width: 1199.98px) {
  .grid-project.grid-project--4columns {
    grid-auto-rows: calc(
      (15 / 16) *
        (
          100vw -
            (var(--project-gutter, 1rem) * (var(--project-numcols, 3) - 5))
        ) / var(--project-numcols, 3)
    );
  }
}

@media (max-width: 767.98px) {
  .grid-project.grid-project--4columns {
    --project-numcols: 2;
  }
}

.grid-project .grid-project-item {
  grid-column-end: span 1;
  grid-row-end: span 1;
}
.grid-project .grid-project-item.grid-project-item--width2 {
  grid-column-end: span 2;
  grid-row-end: span 2;
}
body.archive.post-type-archive-project .grid-project .grid-project-item.grid-project-item--width2 {
    grid-column-end: span 1;
    grid-row-end: span 1;
}

.card-project {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden; /* Ensure the overlay stays within bounds */
}

.card-project::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(4, 111, 120, 0.7); /* Overlay color */
  transition: background-color 0.3s ease;
}

.card-project:hover::before {
  background-color: transparent; /* Remove overlay on hover */
}


.card-project__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 15px;
  bottom: 0;
  left: 15px;
  color: #fff;
  visibility: visible;
  /* transition: 0.3s all; */
  /* opacity: 0; */
  transform: translate3d(0, 10px, 0);
  text-transform: capitalize;
}

.card-project:hover .card-project__content {
  visibility: hidden;
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

/* baray baraks kardan neveshte roy hover:
134 active
135 active
133 hidden
141 visible
 */

.card-project__location,
.card-project__year {
  font-size: 14px;
}

@media screen and (max-width: 767.98px) {
  .card-project__location,
  .card-project__year {
    font-size: 12px;
  }
}

.card-project__name {
  font-size: 40px;
  line-height: 1em;
  font-weight: 400;
  text-transform: uppercase;
  font-family: "Orbitron", sans-serif;
}
@media screen and (max-width: 767.98px) {
  .card-project__name {
    font-size: 16px;
    line-height: 24px;
  }
}
