/* ==========================================================================
   Opus AV — Our work (project gallery)
   /assets/css/pages/work.css
   Image-overlay cards with sector-coloured pill tags. Always-visible text.
   Featured card spans full width on desktop; standard cards in a 3-col grid.
   ========================================================================== */


/* ── Section wrapper (dark) ─────────────────────────────────────────────── */

.work-grid-section {
  padding-block: var(--space-6) var(--space-8);
  background: var(--opus-charcoal);
  position: relative;
  overflow: hidden;
}

.work-grid-section .ambient {
  opacity: 0.65;
}


/* ── Grid — featured spans full row, then 3-col below ──────────────────── */

.work-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2px;
}

.work-card--featured {
  grid-column: 1 / -1;
  min-height: clamp(420px, 48vw, 620px);
}

@media (max-width: 960px) {
  .work-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .work-card--featured {
    grid-column: 1 / -1;
    min-height: clamp(360px, 56vw, 520px);
  }
}

@media (max-width: 600px) {
  .work-grid {
    grid-template-columns: 1fr;
  }
  .work-card--featured {
    grid-column: auto;
  }
}


/* ── Card — image fills, text overlays via gradient ────────────────────── */

.work-card {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  min-height: clamp(300px, 32vw, 420px);
  cursor: pointer;
  isolation: isolate;
}

.work-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: -2;
  transition: transform 0.65s var(--ease-opus);
  transform-origin: center;
}

.work-card:hover .work-card__img {
  transform: scale(1.05);
}

/* Gradient overlay — dark at bottom for text legibility */
.work-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    to top,
    rgba(18, 18, 18, 0.92) 0%,
    rgba(18, 18, 18, 0.50) 50%,
    rgba(18, 18, 18, 0.10) 100%
  );
  transition: background var(--dur-base) var(--ease-opus);
}

.work-card:hover::before {
  background: linear-gradient(
    to top,
    rgba(18, 18, 18, 0.96) 0%,
    rgba(18, 18, 18, 0.60) 55%,
    rgba(18, 18, 18, 0.18) 100%
  );
}

/* Sector accent line slides in from left on hover */
.work-card::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--sector-accent, var(--accent));
  z-index: 2;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s var(--ease-opus);
}

.work-card:hover::after {
  transform: scaleX(1);
}


/* ── Card body — text content over the gradient ────────────────────────── */

.work-card__body {
  position: relative;
  z-index: 1;
  padding: var(--space-4) var(--space-4) var(--space-4);
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.work-card--featured .work-card__body {
  padding: var(--space-5) var(--space-5) var(--space-5);
  max-width: 60ch;
}


/* Sector tag — pill chip with the sector accent */
.work-card__tag {
  align-self: flex-start;
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  font-weight: var(--fw-medium);
  color: var(--opus-white);
  background: color-mix(in srgb, var(--sector-accent, var(--accent)) 80%, transparent);
  padding: 0.35rem 0.7rem;
  border-radius: var(--radius-pill);
  backdrop-filter: blur(2px);
}


/* Headline */
.work-card h2,
.work-card h3 {
  color: var(--opus-white);
  font-weight: var(--fw-light);
  line-height: 1.2;
  margin: 0;
  letter-spacing: -0.01em;
}

.work-card h3 {
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
}

.work-card--featured h2 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
}


/* Body copy */
.work-card p {
  font-size: var(--fs-small);
  color: rgba(242, 242, 242, 0.82);
  line-height: 1.55;
  margin: 0;
  max-width: 50ch;
}


/* Featured-card "see our X work" link — only on featured */
.work-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin-top: var(--space-1);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--sector-accent, var(--accent));
  text-decoration: none;
  transition: gap var(--dur-fast) var(--ease-opus);
}

.work-card:hover .work-card__cta {
  gap: 0.7em;
}

.work-card__cta .cta__arrow {
  transition: transform var(--dur-fast) var(--ease-opus);
}

.work-card:hover .work-card__cta .cta__arrow {
  transform: translateX(4px);
}


/* ── Cover link — entire card is clickable ──────────────────────────────── */

.work-card__link {
  position: absolute;
  inset: 0;
  z-index: 3;
}


/* ── Closing CTA section ────────────────────────────────────────────────── */

.closing-cta {
  padding-block: clamp(var(--space-6), 8vw, var(--space-8));
  background: var(--surface-default);
  text-align: center;
}

.closing-cta .section-intro--centered {
  max-width: 60ch;
  margin: 0 auto;
}

.closing-cta h2 {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  font-weight: var(--fw-light);
  letter-spacing: var(--ls-h1);
  color: var(--text-strong);
  margin: var(--space-2) 0 var(--space-3);
}

.closing-cta p {
  color: var(--text-default);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  margin: 0 auto var(--space-4);
}

.closing-cta .cta {
  margin-top: var(--space-2);
}


/* ── Reduced motion ─────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .work-card__img,
  .work-card::after,
  .work-card::before,
  .work-card__cta,
  .work-card__cta .cta__arrow {
    transition: none;
  }
  .work-card:hover .work-card__img {
    transform: none;
  }
}
