/* styles/projects.css */

#projects { background: var(--surface); }

.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5px;
  background: var(--mid);
}

.project-card {
  background: var(--surface);
  padding: 2.5rem 2rem;
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  transition: background .25s;
}
.project-card:hover { background: var(--bg); }

.project-num {
  font-family: var(--serif); font-size: 3rem; line-height: 1;
  color: rgba(20,20,19,.08);
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-style: italic; pointer-events: none;
}

.project-type {
  font-size: .66rem; font-weight: 500; letter-spacing: .18em;
  text-transform: uppercase; color: var(--ink-muted); margin-bottom: .8rem;
}

.project-title {
  font-family: var(--serif); font-size: 1.3rem;
  line-height: 1.25; margin-bottom: 1rem;
}

.project-desc {
  color: var(--ink-muted); font-size: .88rem;
  flex: 1; margin-bottom: 1.5rem;
}

.project-tech { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: 1.5rem; }
.tech-badge {
  font-size: .67rem; font-weight: 500; letter-spacing: .06em;
  padding: .22rem .6rem;
  background: rgba(20,20,19,.08); color: var(--ink-muted);
}

.project-link {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .78rem; font-weight: 500; color: var(--ink);
  text-decoration: none; letter-spacing: .04em;
  transition: gap .2s;
}
.project-link:hover { gap: .8rem; }

@media (max-width: 480px) {
  .projects-grid { grid-template-columns: 1fr; }
}
