/* ── Projects page — extends style.css ───────────────────────────────────── */

.page-header {
  margin-bottom: 1.75rem;
}
.page-header .badge { margin-bottom: 1rem; }
.page-header h1 {
  font-size: 26px; font-weight: 600; letter-spacing: -0.5px;
  color: var(--text-primary);
}
.page-header p {
  font-size: 14px; color: var(--text-secondary);
  margin-top: 8px; line-height: 1.6; max-width: 56ch;
}

.back-link { margin-bottom: 1.25rem; }

/* ── Project cards ── */
.project-list {
  display: flex; flex-direction: column; gap: 1rem;
}

.project-card {
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.project-header {
  padding: 1.1rem 1.25rem;
  display: flex; align-items: flex-start; gap: 14px;
  cursor: pointer; user-select: none;
}
.project-icon {
  width: 40px; height: 40px; border-radius: var(--radius-md);
  background: var(--teal-light);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--teal-dark);
}
.project-header-text { flex: 1; min-width: 0; }
.project-title-row {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.project-title { font-size: 15px; font-weight: 500; color: var(--text-primary); }
.project-status {
  font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 20px;
  flex-shrink: 0;
}
.project-status.status-live { background: var(--teal-light); color: var(--teal-dark); }
.project-status.status-progress { background: #FEF3C7; color: #92610B; }
.project-status.status-planned { background: var(--input-bg); color: var(--text-tertiary); }

@media (prefers-color-scheme: dark) {
  .project-status.status-progress { background: #2a230f; color: #E8C26A; }
}

.project-value { font-size: 13px; color: var(--text-secondary); margin-top: 4px; line-height: 1.5; }

.project-chevron {
  color: var(--text-tertiary); transition: transform 0.2s; flex-shrink: 0; margin-top: 4px;
}
.project-header[aria-expanded="true"] .project-chevron { transform: rotate(180deg); }

.project-body {
  padding: 0 1.25rem 1.25rem;
  border-top: 0.5px solid var(--border);
  margin-top: 0;
}
.project-body[hidden] { display: none; }

.project-section { margin-top: 1rem; }
.project-section-title {
  font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-tertiary); margin-bottom: 8px;
}

.project-diagram {
  background: var(--input-bg);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1rem;
  font-size: 12px; color: var(--text-secondary);
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  min-height: 80px;
  line-height: 1.6;
}

.project-decisions {
  display: flex; flex-direction: column; gap: 8px;
}
.decision-item {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 13px; color: var(--text-secondary); line-height: 1.55;
}
.decision-icon {
  flex-shrink: 0; margin-top: 2px; color: var(--teal);
}

.project-tags { display: flex; flex-wrap: wrap; gap: 6px; }

.project-links {
  display: flex; gap: 10px; flex-wrap: wrap; margin-top: 1rem;
}
.project-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500;
  color: var(--text-secondary);
  background: var(--input-bg);
  border: 0.5px solid var(--border);
  border-radius: 20px; padding: 6px 13px;
  text-decoration: none;
  transition: all 0.15s;
}
.project-link:hover { background: var(--teal-light); color: var(--teal-dark); border-color: var(--teal); }
.project-link.disabled {
  opacity: 0.5; cursor: default; pointer-events: none;
}

.ask-chatbot-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500;
  color: var(--teal-dark);
  background: var(--teal-light);
  border: none;
  border-radius: 20px; padding: 6px 13px;
  cursor: pointer; transition: opacity 0.15s;
  font-family: inherit;
}
.ask-chatbot-link:hover { opacity: 0.85; }

@media (max-width: 480px) {
  .page-header h1 { font-size: 22px; }
  .project-header { padding: 1rem; gap: 10px; }
  .project-icon { width: 36px; height: 36px; }
}

/* ── Search bar ── */
.search-bar {
  display: flex; align-items: center; gap: 10px;
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 11px 16px;
  margin-bottom: 1.25rem;
  color: var(--text-tertiary);
  transition: border-color 0.15s;
}
.search-bar:focus-within { border-color: var(--teal); color: var(--teal); }
.search-bar input {
  flex: 1; border: none; outline: none; background: none;
  font-family: inherit; font-size: 14px; color: var(--text-primary);
}
.search-bar input::placeholder { color: var(--text-tertiary); }

.no-results {
  text-align: center; font-size: 13px; color: var(--text-secondary);
  padding: 2rem 0;
}

/* ── Loading state (shared look with resume-loading) ── */
.resume-loading { font-size: 13px; color: var(--text-tertiary); padding: 0.75rem 0; }
.resume-error { font-size: 13px; color: var(--text-secondary); padding: 0.75rem 0; }

/* ── Project media (image / gif / video) ── */
.project-media-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--input-bg);
  overflow: hidden;
}
.project-media-wrap img,
.project-media-wrap video {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  border: none;
  transition: transform 1.2s ease;
}
.project-media-wrap iframe {
  width: 100%; height: 100%;
  display: block;
  border: none;
}
.project-media-wrap:hover img,
.project-media-wrap:hover video {
  transform: scale(1.08);
}
@media (prefers-reduced-motion: reduce) {
  .project-media-wrap img,
  .project-media-wrap video {
    transition: none;
  }
}
.project-icon-badge {
  position: absolute; bottom: 10px; left: 10px;
  width: 34px; height: 34px; border-radius: var(--radius-md);
  background: var(--surface);
  border: 0.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--teal-dark);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

/* Hide a card entirely when filtered out */
.project-card[hidden] { display: none; }

@media (max-width: 480px) {
  .search-bar { padding: 10px 14px; }
}
