/* ============================================================
   Option 3 — Category Mosaic, explored four ways.
   Pairs with css/system.css (tokens, nav, fonts).
   Brand: Playfair Display + Inter, sage (#43594A) / bronze (#B28C57)
   ============================================================ */

body { background: var(--bg); }

/* ---- shared masthead bits ---- */
.mz-eyebrow {
  display: flex; align-items: center; gap: 18px;
  font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--accent); font-weight: 500;
}
.mz-eyebrow .rule { flex: 1; height: 1px; background: var(--border); max-width: 220px; }
.mz-eyebrow .meta { color: var(--text-muted); letter-spacing: 0.14em; }

.mz-h1 {
  font-family: var(--font-display);
  font-weight: 500; line-height: 0.98; letter-spacing: -0.024em;
}
.mz-h1 .line1 { white-space: nowrap; }
.mz-h1 em { font-style: italic; font-weight: 400; color: var(--accent); }
.mz-sub { color: var(--text-muted); line-height: 1.7; }

/* ---- shared tile internals ---- */
.mz-tile {
  position: relative; overflow: hidden; display: block;
  background: var(--bg-deep); cursor: pointer;
}
.mz-tile img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1s cubic-bezier(0.2,0.8,0.2,1);
}
.mz-tile:hover img { transform: scale(1.05); }
.mz-tile .tile-meta {
  position: absolute; inset: 0; z-index: 2;
  padding: clamp(15px, 1.3vw, 22px);
  display: flex; flex-direction: column; justify-content: space-between;
  color: #fff;
}
.mz-tile .tile-num {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 500; letter-spacing: 0.14em;
  color: rgba(255,255,255,0.85);
}
.mz-tile .tile-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.mz-tile .tile-name {
  font-family: var(--font-display);
  font-size: clamp(18px, 1.6vw, 25px);
  font-weight: 500; letter-spacing: -0.01em; line-height: 1.04;
  text-shadow: 0 1px 12px rgba(0,0,0,0.45);
}
.mz-tile .tile-count {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.82); font-weight: 600; white-space: nowrap; margin-bottom: 4px;
}
.mz-tile .tile-arrow {
  position: absolute; top: clamp(15px,1.3vw,22px); right: clamp(15px,1.3vw,22px); z-index: 3;
  font-size: 18px; color: #fff; opacity: 0; transform: translateX(-4px);
  transition: opacity 0.25s, transform 0.25s;
}
.mz-tile:hover .tile-arrow { opacity: 1; transform: translateX(0); }
.mz-tile.is-commercial .tile-count {
  font-family: var(--font-display); font-style: italic; text-transform: none;
  letter-spacing: 0.02em; font-size: 13px;
}

/* (entry reveal intentionally omitted from these comparison mockups —
   a tested staggered reveal gets added to the final chosen page) */

/* ============================================================
   VARIANT A — Polished mosaic
   Container masthead, full-bleed mosaic with thin warm gaps,
   numbered tiles, gradient scrim, bronze count on hover.
   ============================================================ */
.va { padding: clamp(40px, 5vw, 60px) 0 0; }
.va-head {
  display: grid; grid-template-columns: 1fr auto; gap: 28px clamp(40px,6vw,96px); align-items: end;
  margin-bottom: clamp(46px, 5.2vw, 70px);
}
.va .mz-eyebrow { margin-bottom: clamp(16px,1.8vw,24px); }
.va .mz-eyebrow .rule { max-width: none; }
.va .mz-h1 { font-size: clamp(46px, 5.9vw, 86px); }
.va .mz-sub { font-size: clamp(16px,1.3vw,19px); max-width: 46ch; margin-top: clamp(18px,1.9vw,26px); }
.va-headnote { text-align: right; align-self: end; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted); font-weight: 500; line-height: 1.7; white-space: nowrap; }
.va-headnote strong { display: block; font-family: var(--font-display); font-size: 35px; letter-spacing: -0.01em; color: var(--text); text-transform: none; font-weight: 500; margin-bottom: 2px; }

.va-mosaic {
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(176px, 17.5vw, 236px);
  gap: 0; background: var(--bg-deep); padding: 0;
}
.va-mosaic .mz-tile::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,13,11,0.04) 0%, rgba(15,13,11,0.10) 42%, rgba(15,13,11,0.72) 100%);
  transition: background 0.3s ease;
}
.va-mosaic .mz-tile:hover::after { background: linear-gradient(180deg, rgba(67,89,74,0.14) 0%, rgba(15,13,11,0.30) 45%, rgba(15,13,11,0.80) 100%); }
.va-mosaic .mz-tile:hover .tile-count { color: var(--cta); }
.t-wide { grid-column: span 6; grid-row: span 2; }
.t-tall { grid-column: span 3; grid-row: span 2; }
.t-sq   { grid-column: span 3; grid-row: span 1; }
.t-half { grid-column: span 6; grid-row: span 1; }

/* ============================================================
   VARIANT B — Seamless gallery wall
   Edge-to-edge, hairline-thin black seams, persistent labels
   with a bronze tick + top-rule. Cinematic, darker.
   ============================================================ */
.vb { padding: clamp(40px, 5vw, 60px) 0 0; }
.vb-head { max-width: 720px; margin: 0 auto clamp(32px,4vw,48px); text-align: center; }
.vb .mz-eyebrow { justify-content: center; margin-bottom: 18px; }
.vb .mz-eyebrow .rule { max-width: 60px; }
.vb .mz-h1 { font-size: clamp(40px, 5.2vw, 76px); }
.vb .mz-h1 .line1 { white-space: normal; }
.vb .mz-sub { font-size: clamp(15px,1.1vw,17px); max-width: 56ch; margin: clamp(16px,1.6vw,22px) auto 0; }

.vb-mosaic {
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(160px, 17vw, 230px);
  gap: 2px; background: var(--text);
}
.vb-mosaic .mz-tile::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,13,11,0) 30%, rgba(15,13,11,0.30) 60%, rgba(15,13,11,0.85) 100%);
}
.vb-mosaic .mz-tile .tile-meta { justify-content: flex-end; }
.vb-mosaic .mz-tile .tile-num {
  position: absolute; top: clamp(15px,1.3vw,22px); left: clamp(15px,1.3vw,22px);
}
.vb-mosaic .mz-tile .tile-foot { flex-direction: column; align-items: flex-start; gap: 9px; }
.vb-mosaic .mz-tile .tile-name { position: relative; padding-top: 12px; }
.vb-mosaic .mz-tile .tile-name::before {
  content: ''; position: absolute; top: 0; left: 0; width: 30px; height: 2px; background: var(--cta);
  transition: width 0.35s cubic-bezier(0.2,0.8,0.2,1);
}
.vb-mosaic .mz-tile:hover .tile-name::before { width: 60px; }
.vb-mosaic .mz-tile .tile-count { margin-bottom: 0; }

/* ============================================================
   VARIANT C — Editorial overlap
   Oversized headline drops down over the top of a full-bleed
   mosaic; the type layers in front. Dramatic, magazine cover.
   ============================================================ */
.vc { padding: clamp(36px, 4.5vw, 56px) 0 0; position: relative; }
.vc-head { position: relative; z-index: 5; }
.vc .mz-eyebrow { margin-bottom: clamp(14px,1.6vw,20px); }
.vc .mz-h1 {
  font-size: clamp(52px, 8vw, 128px);
  line-height: 0.9; letter-spacing: -0.03em;
  margin-bottom: clamp(-44px, -3vw, -28px); /* pull mosaic up under the type */
}
.vc-headrow { display: flex; align-items: flex-end; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.vc .mz-sub { font-size: clamp(15px,1.1vw,17px); max-width: 46ch; margin-top: 12px; }
.vc-mosaic {
  position: relative;
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(150px, 16vw, 205px);
  gap: 7px; background: var(--bg-deep); padding: 7px;
}
.vc-mosaic .mz-tile::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,13,11,0.10) 0%, rgba(15,13,11,0.12) 42%, rgba(15,13,11,0.74) 100%);
  transition: background 0.3s ease;
}
.vc-mosaic .mz-tile:hover::after { background: linear-gradient(180deg, rgba(67,89,74,0.16) 0%, rgba(15,13,11,0.34) 45%, rgba(15,13,11,0.82) 100%); }
/* first (wide) tile sits under the headline — push its label down so type doesn't collide */
.vc-mosaic .mz-tile.t-wide .tile-num { margin-top: clamp(40px, 3.4vw, 64px); }

/* ============================================================
   VARIANT D — Hybrid: numbered index list + feature mosaic
   Left: the numbered index you liked (all 8, the selector).
   Right: a compact asymmetric mosaic of feature shots.
   Merges Option 1's structure with Option 3's imagery.
   ============================================================ */
.vd { padding: clamp(40px, 5vw, 64px) 0 clamp(56px,7vw,88px); }
.vd .mz-eyebrow { margin-bottom: clamp(26px,3.2vw,40px); }
.vd .mz-eyebrow .rule { max-width: 280px; }
.vd-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(40px,5vw,72px); align-items: start; }
.vd-left { display: flex; flex-direction: column; }
.vd .mz-h1 { font-size: clamp(40px, 4.8vw, 68px); }
.vd .mz-sub { font-size: clamp(15px,1.1vw,17px); max-width: 38ch; margin-top: clamp(18px,2vw,26px); }
.vd-index { display: flex; flex-direction: column; border-top: 1px solid var(--text); margin-top: clamp(28px,3.4vw,44px); }
.vd-row {
  display: grid; grid-template-columns: 34px 1fr auto 22px; align-items: center; gap: 16px;
  padding: 15px 0; border-bottom: 1px solid var(--border); color: var(--text);
  transition: padding-left 0.24s ease, color 0.24s ease; cursor: pointer;
}
.vd-row:hover { padding-left: 9px; color: var(--accent); }
.vd-row .num { font-family: var(--font-display); font-size: 12px; font-weight: 500; color: var(--accent); letter-spacing: 0.14em; }
.vd-row .name { font-family: var(--font-display); font-size: clamp(17px,1.4vw,21px); font-weight: 500; letter-spacing: -0.005em; }
.vd-row .count { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); font-weight: 500; white-space: nowrap; }
.vd-row .arrow { font-size: 16px; color: var(--text-muted); text-align: right; transition: transform 0.24s, color 0.24s; }
.vd-row:hover .arrow { transform: translateX(5px); color: var(--accent); }
.vd-row.is-commercial .count { font-family: var(--font-display); font-style: italic; text-transform: none; font-size: 13px; letter-spacing: 0.02em; }

.vd-mosaic {
  display: grid; grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: clamp(118px, 11vw, 150px);
  gap: 7px;
}
.vd-mosaic .mz-tile::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,13,11,0.02) 0%, rgba(15,13,11,0.08) 45%, rgba(15,13,11,0.66) 100%);
  transition: background 0.3s ease;
}
.vd-mosaic .mz-tile:hover::after { background: linear-gradient(180deg, rgba(67,89,74,0.12) 0%, rgba(15,13,11,0.28) 45%, rgba(15,13,11,0.76) 100%); }
.vd-mosaic .mz-tile .tile-name { font-size: clamp(15px,1.2vw,19px); }
.vd-m-wide { grid-column: span 4; grid-row: span 2; }
.vd-m-tall { grid-column: span 2; grid-row: span 2; }
.vd-m-sq   { grid-column: span 2; grid-row: span 1; }
.vd-m-half { grid-column: span 3; grid-row: span 1; }

@media (max-width: 900px) {
  .va-head, .vc-headrow { grid-template-columns: 1fr; }
  .va-headnote { text-align: left; }
  .vd-grid { grid-template-columns: 1fr; gap: 32px; }
  .t-wide,.t-tall,.t-sq,.t-half { grid-column: span 6; grid-row: span 1; }
  .vc .mz-h1 { margin-bottom: 16px; }
  .vc-mosaic .mz-tile.t-wide .tile-num { margin-top: 0; }
}
