/* ========================
   ABOUT HERO
======================== */

.about-hero {
  position: relative;
  width: 100%;
  height: 100vh; /* full screen */
  overflow: hidden;
}

/* IMAGE */
.about-hero-img {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.about-hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* OVERLAY CENTER BOX */
.about-hero-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  background: rgba(29, 29, 29, 0.2); /* #1D1D1D with 20% opacity */
  padding: 20px 60px;

  z-index: 2;
}

/* TEXT */
.about-hero-overlay h1 {
  font-size: 64px;
  color: #fff;
  text-align: center;
}

/* ========================
   FADE EFFECT (REUSABLE)
======================== */

/* DEFAULT VISIBLE (SAFE) */
.fade-in {
  opacity: 1;
  transform: translateY(0);
}

/* ONLY animate when JS adds this */
.fade-in.animate {
  opacity: 0;
  transform: translateY(20px);
}

/* FINAL STATE */
.fade-in.show {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

/* ========================
   RESPONSIVE
======================== */

@media (max-width: 768px) {

  .about-hero {
    height: 70vh; /* better for mobile */
  }

  .about-hero-overlay {
    padding: 12px 12px;
  }

  .about-hero-overlay h1 {
    font-size: 40px;
  }
}




/* ========================
   PROJECT SECTION
======================== */

.projects-section {
  background: #F5F0E6;
  padding: 80px 0;
}

/* ========================
   FILTERS
======================== */

.project-filters {
  display: flex;
  justify-content: center;
  gap: 40px;

  margin-bottom: 40px;
}

/* BUTTONS */
.filter-btn {
  background: none;
  border: none;

  font-size: 24px;
  font-family: 'Cormorant Garamond', serif;

  color: #1d1d1d;
  cursor: pointer;

  transition: 0.3s ease;
}

.filter-btn:hover,
.filter-btn.active {
  color: #764537;
}

/* ========================
   PROJECT WRAPPER
======================== */

.projects-wrapper {
  display: flex;
  flex-direction: column;
  gap: 16px;

  padding: 0 20px;
}

/* ========================
   PROJECT CARD
======================== */

.project-card {
  position: relative;
  overflow: hidden;

  text-decoration: none;
  color: inherit;

  display: block;
}

.filter-btn.active {
  color: #764537;
}

/* IMAGE */
.project-card img {
  width: 100%;
  aspect-ratio: 16 / 7;
  object-fit: cover;
  display: block;
}

/* ========================
   OVERLAY
======================== */

.project-overlay {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;

  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

/* LEFT INFO */
.project-info {
  background: rgba(0,0,0,0.4);

  padding: 16px;
  max-width: 500px;
}

/* TITLE */
.project-info h3 {
  color: #fff;
  font-size: 32px;
  margin-bottom: 8px;
}

/* DESCRIPTION */
.project-info p {
  color: #fff;
  font-size: 22px;
  line-height: 1.4;
}

/* BUTTON */
.project-btn {
  background: #FFF4DA;
  color: #764537;

  padding: 12px 32px;
  border-radius: 40px;

  font-size: 22px;

  transition: 0.3s ease;
}

.project-btn:hover {
  background: #764537;
  color: #fff;
}

/* ========================
   RESPONSIVE
======================== */

@media (max-width: 768px) {

  .projects-section {
    padding: 40px 0;
  }

  /* FILTERS */
  .project-filters {
    flex-direction: column;
    align-items: flex-start;

    gap: 14px;

    padding: 0 20px;
    margin-bottom: 24px;
  }

  .filter-btn {
    font-size: 14px;
  }

  /* PROJECT LIST */
  .projects-wrapper {
    gap: 12px;
    padding: 0 20px;
  }

  /* CARD */
  .project-card img {
    aspect-ratio: 4 / 3;
  }

  /* OVERLAY */
  .project-overlay {
    left: 12px;
    right: 12px;
    bottom: 12px;

    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  /* INFO */
  .project-info {
    max-width: 100%;
    padding: 12px;
  }

  .project-info h3 {
    font-size: 24px;
  }

  .project-info p {
    font-size: 14px;
  }

  /* BUTTON */
  .project-btn {
    font-size: 14px;
    padding: 8px 24px;
  }
}