/* HERO */
.hero { padding: var(--block-gap) var(--side); }
.hero-title {
  letter-spacing: 0;
  color: var(--text);
  transition: color var(--transition);
  max-width: 50vw; /* half the viewport = visual page center */
}

/* FILTER BAR */
.filter-wrap { padding: 0 var(--side) var(--block-gap); }

.filter-bar {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.filter-btn {
  font-family: var(--base);
  font-size: 0.75rem; /* 12px — Figma label size */
  font-weight: 400;
  line-height: 1.12;
  color: var(--muted);
  background: none;
  border: none;
  padding: 0;
  white-space: nowrap;
  cursor: pointer;
  transition: color .2s;
  position: relative;
}
.filter-btn::after {
  content: '';
  position: absolute;
  bottom: -0.25rem;
  left: 0; right: 0;
  height: 1px;
  background: var(--text);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
.filter-btn:hover { color: var(--text); }
.filter-btn.active { color: var(--text); }
.filter-btn.active::after { transform: scaleX(1); }

/* MOBILE SELECT FILTER */
.filter-select-wrap {
  display: none; /* shown on mobile via media query below */
  align-items: center; /* vertically center arrow glyph with select text (#101) */
}
.filter-select-wrap::after {
  content: '\2304'; /* ⌄ down arrowhead — rendered in GT Standard so it aligns with the select text (#81) */
  margin-left: 4px; /* tightened from 6px (#101) */
  font-family: var(--base);
  font-size: 0.75rem;
  color: var(--text);
  pointer-events: none;
}
.filter-select {
  font-family: var(--base);
  font-size: 0.75rem;
  font-weight: 400;
  background: none;
  border: none;
  color: var(--text);
  width: auto;
  -webkit-appearance: none;
  appearance: none;
  padding: 0;
}
/* Safari shows a native focus ring on <select> after the picker closes — suppress it (#99) */
.filter-select:focus { outline: none; }

/* GRID */
.grid-wrap { padding: 0 var(--side) 1.5rem; }
.grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: var(--col-gap);
  row-gap: 1.5rem;
  align-items: start;
}

/* CARD */
.project-card {
  display: flex;
  flex-direction: column;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .44s ease, transform .44s ease;
  text-decoration: none;
  color: inherit;
}
.project-card.visible { opacity: 1; transform: translateY(0); }
.project-card.hidden  { display: none !important; }
.grid:has(.project-card:hover) .project-card:not(:hover) { opacity: 0.8; transition: opacity 0.2s ease; }

/* THUMB */
.thumb { width: 100%; overflow: hidden; }
.thumb img,
.thumb video { display: block; width: 100%; height: auto; }
.thumb img { transition: opacity .3s ease; }
.thumb img.loading { opacity: 0; }

.thumb-ph {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.625rem; color: var(--muted);
}

/* CARD INFO */
.card-info {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.375rem; /* 6px — was 8px (#50) */
}
.card-caption {
  display: flex;
  flex-direction: column;
  gap: var(--gap-stacked-titles-sm); /* 0 in untrimmed engines (leading covers it), 4px when trimmed */
}
.card-client {
  font-family: var(--display);
  font-size: 0.875rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.24;
  color: var(--text);
  transition: color var(--transition);
}
.card-title {
  font-family: var(--display);
  font-size: 0.875rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.24;
  color: var(--muted);
  opacity: 0;
  transition: color var(--transition), opacity .25s ease;
}
.card-title--solo { color: var(--text); opacity: 1; }
.project-card:hover .card-title { opacity: 1; }
.card-cat {
  font-family: var(--base);
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.12;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
  transition: color var(--transition);
}

/* COMING SOON */
.cs-badge {
  font-family: var(--base);
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--muted);
  display: inline-block;
  margin-bottom: .4rem;
  opacity: .7;
}

/* MOBILE */
@media (max-width: 767px) {
  .hero { padding: 2rem var(--side) var(--block-gap); } /* top: 2rem matches Figma 94px title position on mobile; bottom: shared block-gap */
  .hero-title { max-width: 100%; }
  .filter-bar        { display: none; }
  .filter-select-wrap { display: inline-flex; }
  .grid { row-gap: 0; }
  .card-client,
  .card-title    { font-size: 1rem; } /* 16px on mobile */
  .card-cat      { display: none; }
}
