.portfolio-wrapper {
  width: 90%;
  margin: 0 auto;
  max-width: 80rem;
}
.portfolio-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.project {
  width: 400px;
  height: 400px;
  margin: 1rem;
  border: none;
  background: 0 0;
}
.app-list {
  position: absolute;
  color: #fff;
  bottom: 0;
  display: inline-block;
  width: 100%;
  margin-bottom: 15px;
}
.app-list a {
  padding-left: 5px;
  padding-right: 5px;
  text-decoration: none;
}
.app-list img {
  width: 10%;
  height: 10%;
}
@media screen and (max-width: 64rem) {
  .project {
    width: calc(33.333333% - 2rem);
  }
}
@media screen and (max-width: 48rem) {
  .project {
    width: calc(50% - 2rem);
  }
}
.card,
.customhomeImage {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 32rem) {
  .project {
    width: 100%;
    margin: 0 0 2rem;
  }
}
.subSection img {
  object-fit: contain;
}
.customhomeImage {
  position: absolute;
  transform: rotate(180deg);
  top: -370px;
}
.card__title,
.custom-hero-section {
  position: relative;
}
.custom-hero-section .hero-bg {
  background-image: none;
}
.card {
  display: grid;
  background-size: cover;
  place-items: center;
  overflow: hidden;
  border-radius: 0.625rem;
  box-shadow: 0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.25);
}
.card > * {
  grid-column: 1/2;
  grid-row: 1/2;
}
.card__background {
  object-fit: cover;
  max-width: 100%;
  height: 100%;
}
.card__content {
  --flow-space: 0.9375rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-self: flex-end;
  height: 90%;
  padding: 12% 1.25rem 1.875rem;
  background: linear-gradient(
    180deg,
    rgba(7, 7, 7, 0.081) 0,
    rgba(0, 0, 0, 0.938) 60%,
    #000 100%
  );
}
.card__content--container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  --flow-space: 1.25rem;
}
.card__title {
  width: fit-content;
  font-size: 1.7rem;
  width: -moz-fit-content;
}
.card__title::after {
  content: "";
  position: absolute;
  height: 0.3125rem;
  width: calc(100% + 1.25rem);
  bottom: calc((1.25rem - 0.5rem) * -1);
  left: -1.25rem;
  background-color: #1694d4;
}
.card__button:focus {
  outline: black solid 2px;
  outline-offset: -5px;
}
@media (hover: hover) and (any-pointer: fine) {
  .card__content {
    transform: translateY(62%);
    transition: transform 0.5s ease-out 0.5s;
  }
  .card__title::after {
    opacity: 0;
    transform: scaleX(0);
    transition: opacity 1s ease-in 0.5s, transform 0.5s ease-out 0.5s;
    transform-origin: right;
  }
  .card__background {
    transition: transform 0.5s ease-in;
  }
  .card__button,
  .card__content--container > :not(.card__title) {
    opacity: 0;
    transition: transform 0.5s ease-out, opacity 0.5s ease-out;
  }
  .card:focus-within,
  .card:hover {
    transform: scale(1.05);
    transition: transform 0.5s ease-in;
  }
  .card:focus-within .card__content,
  .card:hover .card__content {
    transform: translateY(0);
    transition: transform 0.5s ease-in;
    height: 100%;
    background: linear-gradient(
      180deg,
      rgba(7, 7, 7, 0.432) 0,
      rgba(0, 0, 0, 0.938) 50%,
      #000 100%
    );
  }
  .card:focus-within .card__content {
    transition-duration: 0s;
  }
  .card:focus-within .card__background,
  .card:hover .card__background {
    transform: scale(1.3);
  }
  .card:focus-within .card__button,
  .card:focus-within .card__content--container > :not(.card__title),
  .card:hover .card__button,
  .card:hover .card__content--container > :not(.card__title) {
    opacity: 1;
    transition: opacity 0.5s ease-in 0.5s;
  }
  .card:focus-within .card__title::after,
  .card:hover .card__title::after {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: left;
    transition: opacity 0.5s ease-in 0.5s, transform 0.5s ease-in 0.5s;
  }
}
@media screen and (max-width: 1024px) {
  .card__content {
    height: 80%;
    transform: translateY(62%);
    transition: transform 0.5s ease-out;
  }
  .app-list,
  .card__button,
  .card__content--container > :not(.card__title) {
    opacity: 0;
    transition: transform 0.5s ease-out, opacity 0.5s ease-out;
  }
  .project.clicked .card__content {
    transform: translateY(0);
    transition: transform 0.5s ease-in;
    height: 100%;
    background: linear-gradient(
      180deg,
      rgba(7, 7, 7, 0.432) 0,
      rgba(0, 0, 0, 0.938) 50%,
      #000 100%
    );
  }
  .project.clicked .app-list,
  .project.clicked .card__button,
  .project.clicked .card__content--container > :not(.card__title) {
    opacity: 1;
    transition: opacity 0.5s ease-in 0.5s;
  }
  .card__title::after {
    opacity: 0;
    transform: scaleX(0);
    transition: opacity 1s ease-in 0.5s, transform 0.5s ease-out 0.5s;
    transform-origin: right;
  }
  .project.clicked .card__title::after {
    opacity: 1;
    transform: scaleX(1);
    transform-origin: left;
    transition: opacity 0.5s ease-in 0.5s, transform 0.5s ease-in 0.5s;
  }
}
.card__description {
  margin-top: 1rem;
  color: #fff;
  font-size: 0.9rem;
  opacity: 0;
  transform: translateX(-100%);
  transition: opacity 0.5s ease-in, transform 0.5s ease-in;
}
.card:focus-within .card__description,
.card:hover .card__description {
  opacity: 1;
  transform: translateX(0);
  transition-delay: 0.5s;
}
