/* Aeoleaf · Works list (North Star · Phase 2)
 *
 * Loaded on /works only (via index.ejs-style extraCss). Does NOT extend
 * public/css/works.css — that file stays for legacy search-result markup.
 * Markup contract: .work-card + .card-v2 + data-tags="..." ; filter
 * buttons keep .tag-btn + data-tag + .active to reuse main.js filter JS.
 */

/* ===================================================================== */
/* Page intro                                                             */
/* ===================================================================== */
.works-page {
  /* Works page uses the dark-stage gradient to separate chapters; no-op
     on light mode thanks to token-driven aurora in tokens.css. */
}
.works-intro {
  max-width: var(--content-max, 1200px);
  margin: 0 auto;
  padding: clamp(72px, 10vw, 140px) clamp(16px, 3vw, 24px) clamp(24px, 3vw, 40px);
}
.works-intro__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  background: color-mix(in oklab, var(--bg-elev-1) 60%, transparent);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 11px;
  color: var(--text-muted);
  margin-bottom: clamp(18px, 1.8vw, 24px);
}
.works-intro__eyebrow::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-alt-rose);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent-alt-rose) 20%, transparent);
}
.works-intro__title {
  font-family: var(--font-display);
  font-size: clamp(48px, 8vw, 112px);
  line-height: 0.96;
  letter-spacing: -0.03em;
  font-weight: 400;
  color: var(--text);
  margin: 0 0 clamp(12px, 1.5vw, 20px);
}
.works-intro__desc {
  color: var(--text-muted);
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.55;
  max-width: 640px;
  margin: 0;
}

/* ===================================================================== */
/* Tag filter — scrollable pill bar                                       */
/* ===================================================================== */
.works-page .works-tagbar {
  max-width: var(--container-max, 1800px);
  margin: 0 auto clamp(24px, 3vw, 40px);
  padding: 0 clamp(16px, 3vw, 24px);
}
.works-page .works-tagbar__inner {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding-bottom: 8px;
  overflow-x: auto;
  scrollbar-width: thin;
  scroll-snap-type: x proximity;
  /* Invisible gutters at ends so first/last chip never clips */
  scroll-padding: 0 12px;
}

/* When the chip row overflows horizontally, justify-content: center would
   clip the first chip off-screen. Fall back to left alignment in that case
   by letting the flex row grow to its content width inside the scroll
   container. */
.works-page .works-tagbar__inner > * { flex: 0 0 auto; }
.works-page .works-tagbar__inner::-webkit-scrollbar { height: 6px; }
.works-page .works-tagbar__inner::-webkit-scrollbar-thumb {
  background: var(--border-strong);
  border-radius: 999px;
}

/* Override legacy .tag-btn on this page to match v2 look. Keep .tag-btn
   so main.js filter logic (querySelectorAll('.tag-btn')) keeps working. */
.works-page .tag-btn {
  appearance: none;
  flex-shrink: 0;
  scroll-snap-align: start;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: 8px 14px;
  height: 36px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  line-height: 1;
  transition:
    color var(--transition),
    background var(--transition),
    border-color var(--transition),
    transform var(--transition);
}
.works-page .tag-btn__label { white-space: nowrap; }
.works-page .tag-btn__count {
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  color: var(--text-subtle);
  padding: 2px 6px;
  background: var(--bg-elev-2);
  border-radius: var(--radius-pill);
}
.works-page .tag-btn:hover,
.works-page .tag-btn:focus-visible {
  color: var(--text);
  border-color: color-mix(in oklab, var(--accent) 50%, var(--border-strong));
  outline: none;
}
.works-page .tag-btn:focus-visible {
  box-shadow: var(--focus-ring);
}
.works-page .tag-btn.active {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: color-mix(in oklab, var(--accent) 45%, var(--border));
}
.works-page .tag-btn.active .tag-btn__count {
  background: transparent;
  color: color-mix(in oklab, var(--accent) 75%, var(--text));
}

/* ===================================================================== */
/* Bento shell                                                            */
/* ===================================================================== */
.works-bento {
  max-width: var(--container-max, 1800px);
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 24px) clamp(80px, 10vw, 140px);
}

/* ===================================================================== */
/* Card variants                                                          */
/* ===================================================================== */
/* Common: reset legacy .work-card positioning so card-v2 flex layout wins
   (main.js filter toggles inline display:block/none — acceptable since
   flow layout still stacks the cover and text correctly). */
.works-bento .work-card {
  /* explicit reset of legacy rules from old works.css if someone accidentally
     re-adds that stylesheet; cheap defensive code. */
  aspect-ratio: auto;
  padding: 0;
  width: auto;
}

/* Shared cover wrapper */
.work-card__cover-v2 {
  margin: calc(-1 * clamp(20px, 2.2vw, 32px));
  margin-bottom: clamp(16px, 1.8vw, 22px);
  overflow: hidden;
  background: var(--bg-elev-2);
  border-bottom: 1px solid var(--border);
}
.work-card__cover-v2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms var(--ease-emphasis);
}
a.card-v2:hover .work-card__cover-v2 img { transform: scale(1.04); }

/* Standard (span 4) card — 16:10 top image then text */
.work-card-v2 {
  /* marker class so nth rules don't affect featured overlay cards */
}
.work-card-v2 .work-card__cover-v2 {
  aspect-ratio: 16 / 10;
}

/* Monogram fallback (no cover_image) */
.work-card__mono-v2 {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: clamp(56px, 6vw, 96px);
  color: color-mix(in oklab, var(--tone, var(--accent)) 70%, var(--text));
  background:
    radial-gradient(80% 80% at 50% 30%, color-mix(in oklab, var(--tone, var(--accent)) 18%, transparent), transparent 70%),
    var(--bg-elev-2);
}

/* Featured overlay card — magazine style, full bleed cover + text veil */
.work-card--feature-v2 {
  min-height: 420px;
  justify-content: flex-end;
  overflow: hidden;
}
.work-card--feature-v2 .work-card__cover-v2 {
  position: absolute;
  inset: 0;
  margin: 0;
  border-bottom: none;
  z-index: -2;
  aspect-ratio: auto;
}
.work-card--feature-v2 .work-card__cover-v2 img {
  filter: saturate(0.9);
}
.work-card--feature-v2::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.1) 0%,
    rgba(0,0,0,0.55) 55%,
    rgba(0,0,0,0.78) 100%
  );
}
.work-card--feature-v2 .card-v2__eyebrow,
.work-card--feature-v2 .card-v2__title,
.work-card--feature-v2 .card-v2__desc,
.work-card--feature-v2 .card-v2__meta { color: #fff; }
.work-card--feature-v2 .card-v2__eyebrow { color: rgba(255,255,255,0.78); }
.work-card--feature-v2 .card-v2__desc    { color: rgba(255,255,255,0.82); }
.work-card--feature-v2 .card-v2__meta    { color: rgba(255,255,255,0.68); }
.work-card--feature-v2 .card-v2__title {
  font-size: clamp(28px, 3vw, 44px);
  text-shadow: 0 2px 20px rgba(0,0,0,0.35);
}

/* Featured badge — small amber pill at top-right */
.work-card__badge-v2 {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 1;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--accent-tertiary);
  color: #1a1510;
  border-radius: var(--radius-pill);
}

/* ===================================================================== */
/* Tag list inside a standard card                                        */
/* ===================================================================== */
.work-card__tags-v2 {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: 14px;
}
.work-card__tags-v2 .tag-v2 {
  font-size: 11px;
  height: 22px;
  padding: 0 8px;
}

/* ===================================================================== */
/* Empty state                                                            */
/* ===================================================================== */
.works-empty-v2 {
  max-width: 480px;
  margin: 80px auto;
  text-align: center;
  padding: 48px 24px;
  border: 1px dashed var(--border);
  border-radius: var(--radius-card);
  color: var(--text-muted);
}
.works-empty-v2 h3 {
  font-family: var(--font-display);
  font-size: 28px;
  color: var(--text);
  margin: 0 0 8px;
}

/* ===================================================================== */
/* Responsive                                                             */
/* ===================================================================== */
@media (max-width: 640px) {
  .work-card--feature-v2 { min-height: 300px; }
}
