/* ─────────────────────────────────────────────
   WORK · portfolio · project grid
   X3D Studio — Technical Control Surface
   ───────────────────────────────────────────── */

/* ── WORK HEADER — text only, no hero image ── */

.work-header {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: calc(var(--s-9) + 60px) var(--page-pad) var(--s-5);
}

.work-header__ref {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--accent);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--s-4);
  display: block;
}

.work-header__title {
  font-family: var(--font-serif);
  font-size: var(--t-display-lg);
  font-weight: 400;
  line-height: var(--leading-display);
  letter-spacing: var(--tracking-display);
  color: var(--text);
  margin-bottom: var(--s-5);
}

.work-header__intro {
  max-width: 720px;
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--text-soft);
  line-height: var(--leading-body);
}

@media (max-width: 768px) {
  .work-header {
    padding: calc(var(--s-8) + 60px) var(--s-4) var(--s-4);
  }
  .work-header__title { font-size: var(--t-display-md); }
}

/* ── FEATURED PROJECT — full width lead ────── */

.project-featured {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--s-5) var(--page-pad) var(--s-7);
}

.project-featured__media {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--rule);
}

.project-featured__media img {
  width: 100%;
  aspect-ratio: 2.2 / 1;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-slow) var(--ease);
}

.project-featured:hover .project-featured__media img {
  transform: scale(1.02);
}

.project-featured__idx {
  position: absolute;
  top: var(--s-4);
  left: var(--s-4);
  font-family: var(--font-mono-data);
  font-size: 11px;
  color: var(--accent);
  letter-spacing: var(--tracking-mono);
  background: rgba(17, 18, 20, 0.75);
  padding: 4px 10px;
  z-index: 2;
}

.project-featured__info {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-4);
  align-items: start;
  padding-top: var(--s-5);
}

.project-featured__title {
  font-family: var(--font-serif);
  font-size: var(--t-display-sm);
  font-weight: 400;
  color: var(--text);
  line-height: var(--leading-title);
}

.project-featured__meta {
  font-family: var(--font-mono-data);
  font-size: 12px;
  color: var(--text-mute);
  letter-spacing: var(--tracking-mono);
  white-space: nowrap;
  padding-top: 6px;
}

.project-featured__desc {
  max-width: 680px;
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--text-soft);
  line-height: var(--leading-body);
  margin-top: var(--s-3);
}

@media (max-width: 768px) {
  .project-featured { padding: var(--s-4) var(--s-4) var(--s-6); }
  .project-featured__media img { aspect-ratio: 16 / 9; }
  .project-featured__info { grid-template-columns: 1fr; }
  .project-featured__title { font-size: var(--t-title-lg); }
}

/* ── PROJECT GRID — two column staggered ───── */

.project-grid {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--page-pad);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7) var(--grid-gutter);
}

/* stagger: offset right column down */
.project-grid > .project:nth-child(even) {
  padding-top: var(--s-7);
}

.project__media {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--rule);
}

.project__media img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-slow) var(--ease);
}

.project:hover .project__media img {
  transform: scale(1.03);
}

.project__idx {
  position: absolute;
  top: var(--s-3);
  left: var(--s-3);
  font-family: var(--font-mono-data);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: var(--tracking-mono);
  background: rgba(17, 18, 20, 0.7);
  padding: 2px 6px;
  z-index: 2;
}

.project__info {
  padding-top: var(--s-4);
}

.project__title {
  font-family: var(--font-sans);
  font-size: var(--t-title-md);
  font-weight: 600;
  color: var(--text);
  line-height: var(--leading-title);
}

.project__meta {
  font-family: var(--font-mono-data);
  font-size: 11px;
  color: var(--text-mute);
  letter-spacing: var(--tracking-mono);
  margin-top: 4px;
}

.project__desc {
  font-family: var(--font-sans);
  font-size: var(--t-body-sm);
  color: var(--text-mute);
  line-height: var(--leading-body);
  margin-top: var(--s-3);
}

@media (max-width: 768px) {
  .project-grid {
    grid-template-columns: 1fr;
    padding: 0 var(--s-4);
    gap: var(--s-6);
  }
  .project-grid > .project:nth-child(even) {
    padding-top: 0;
  }
}

/* ── FULL WIDTH BREAK PROJECT ──────────────── */

.project-break {
  max-width: var(--content-max);
  margin: var(--s-7) auto;
  padding: 0 var(--page-pad);
}

.project-break__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--s-7);
  align-items: center;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: var(--s-7) 0;
}

.project-break__media {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--rule);
}

.project-break__media img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-slow) var(--ease);
}

.project-break:hover .project-break__media img {
  transform: scale(1.02);
}

.project-break__idx {
  position: absolute;
  top: var(--s-3);
  left: var(--s-3);
  font-family: var(--font-mono-data);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: var(--tracking-mono);
  background: rgba(17, 18, 20, 0.7);
  padding: 2px 6px;
  z-index: 2;
}

.project-break__content {
  display: grid;
  gap: var(--s-4);
  align-content: center;
}

.project-break__title {
  font-family: var(--font-serif);
  font-size: var(--t-display-sm);
  font-weight: 400;
  color: var(--text);
  line-height: var(--leading-title);
}

.project-break__meta {
  font-family: var(--font-mono-data);
  font-size: 12px;
  color: var(--text-mute);
  letter-spacing: var(--tracking-mono);
}

.project-break__desc {
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--text-soft);
  line-height: var(--leading-body);
}

@media (max-width: 768px) {
  .project-break { padding: 0 var(--s-4); margin: var(--s-6) auto; }
  .project-break__inner {
    grid-template-columns: 1fr;
    gap: var(--s-5);
    padding: var(--s-6) 0;
  }
  .project-break__title { font-size: var(--t-title-lg); }
}
