/* ============================================================
   Projects index page (/projects.html)
   ============================================================ */
.page--projects { background: var(--cream); }

.proj-hero {
  padding: calc(var(--nav-h) + 80px) 0 60px;
  background: var(--cream-warm);
  text-align: center;
}
.proj-hero .eyebrow { margin-bottom: 16px; }
.proj-hero__title {
  font-family: var(--ff-heading);
  font-size: 64px;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -1px;
  color: var(--text-dark);
  margin-bottom: 18px;
}
.proj-hero__sub {
  font-size: 17px;
  color: var(--text-mid);
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.7;
}

/* Filter bar */
.proj-filter {
  background: var(--cream);
  padding: 40px 0 16px;
  position: sticky;
  top: var(--nav-h);
  z-index: 50;
  border-bottom: 1px solid var(--border-light);
}
.proj-filter__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.proj-filter__pill {
  font-family: var(--ff-body);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 10px 20px;
  border-radius: 999px;
  background: transparent;
  color: var(--text-mid);
  border: 1px solid var(--border-light);
  transition: background var(--t-fast) ease, color var(--t-fast) ease, border-color var(--t-fast) ease;
}
.proj-filter__pill:hover {
  color: var(--text-dark);
  border-color: var(--gold-dark);
}
.proj-filter__pill.is-active {
  background: var(--text-dark);
  color: var(--white);
  border-color: var(--text-dark);
}
.proj-filter__count {
  text-align: center;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-mid);
  margin-top: 14px;
  min-height: 18px;
}

.proj-main { padding: 60px 0 120px; }
.proj-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

/* Empty / error states */
.proj-empty,
.proj-error {
  text-align: center;
  padding: 80px 24px;
  color: var(--text-mid);
}
.proj-empty i,
.proj-error i {
  font-size: 56px;
  color: var(--gold-dark);
  margin-bottom: 18px;
}
.proj-empty h2,
.proj-error h2 {
  font-family: var(--ff-heading);
  font-size: 32px;
  color: var(--text-dark);
  margin-bottom: 10px;
}
.proj-empty p,
.proj-error p {
  max-width: 480px;
  margin: 0 auto 24px;
}

@media (max-width: 1024px) {
  .proj-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}
@media (max-width: 640px) {
  .proj-hero        { padding-top: calc(var(--nav-h) + 56px); }
  .proj-hero__title { font-size: 44px; }
  .proj-grid        { grid-template-columns: 1fr; gap: 20px; }
}
