/* ── projects page ──────────────────────────────────────────────────── */

.proj-accordion {
  display: flex;
  flex-direction: column;
}

/* ── status badges ──────────────────────────────────────────────────── */

.proj-status {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--font-mono);
  font-size: .8rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .3rem .75rem;
  border-radius: 999px;
  white-space: nowrap;
  flex-shrink: 0;
}

.proj-status::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

.proj-status--active {
  color: var(--c-ok);
  background: color-mix(in srgb, var(--c-ok) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--c-ok) 25%, transparent);
}

.proj-status--completed {
  color: var(--c-muted);
  background: color-mix(in srgb, var(--c-muted) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--c-muted) 20%, transparent);
}

.proj-status--paused {
  color: var(--c-warn);
  background: color-mix(in srgb, var(--c-warn) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--c-warn) 25%, transparent);
}

/* ── detail page properties grid ───────────────────────────────────── */

.proj-props {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .5rem 2rem;
  align-items: start;
}

.proj-props dt {
  color: var(--c-muted);
  font-size: .875rem;
  white-space: nowrap;
}

.proj-props dd {
  color: var(--c-text);
  font-size: .875rem;
  margin: 0;
}

/* ── grant type filter bar ──────────────────────────────────────────── */

.proj-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.5rem;
  align-items: center;
}

.proj-filter-tab {
  font-family: var(--font-mono);
  font-size: .875rem;
  letter-spacing: .03em;
  padding: .3rem .85rem;
  border-radius: 999px;
  border: 1px solid var(--c-border);
  background: transparent;
  color: var(--c-muted);
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap;
}

.proj-filter-tab:hover {
  border-color: var(--c-highlight);
  color: var(--c-highlight);
}

.proj-filter-tab.is-active {
  background: color-mix(in srgb, var(--c-highlight) 12%, transparent);
  border-color: var(--c-highlight);
  color: var(--c-highlight);
}

.proj-filter-empty {
  display: none;
  font-family: var(--font-mono);
  font-size: .875rem;
  color: var(--c-muted);
  padding: 2rem 0;
  text-align: center;
}

/* ── mobile ─────────────────────────────────────────────────────────── */

@media (max-width: 640px) {
  .proj-item__header {
    flex-wrap: wrap;
    row-gap: .4rem;
  }

  .proj-item__years {
    order: 4;
    width: 100%;
    font-size: .7rem;
    padding-left: 0;
  }
}
