/* ============================================================
   Ritzi — Catalog VOL. 02 stylesheet
   "Thirteen Ways to Hold Water"
   ============================================================ */

@import url('colors_and_type.css');

/* ---- Theme variables ---------------------------------- */
:root,
[data-theme="light"] {
  --paper: #FFFFFF;
  --paper-soft: #FFFFFF;        /* WHITE — no beige in light mode */
  --paper-shadow: #ECEAE5;
  --ink: #101820;
  --ink-soft: #4A4D52;
  --ink-faint: #9B9C9F;
  --hairline: #E6E4DF;
  --hairline-strong: #2A2A2A;
  --accent-red: #E03340;
  --hero-overlay-tint: rgba(16, 20, 24, 0.0);
  --grain-blend: multiply;
  --swatch-ring: rgba(16,20,24,0.10);
  --emblem-url: url('assets/emblem-black.png');
}

[data-theme="dark"] {
  --paper: #0A0A0B;
  --paper-soft: #0A0A0B;
  --paper-shadow: #18181C;
  --ink: #FFFFFF;
  --ink-soft: rgba(255,255,255,0.72);
  --ink-faint: rgba(255,255,255,0.45);
  --hairline: rgba(255,255,255,0.14);
  --hairline-strong: #FFFFFF;
  --accent-red: #FFFFFF;        /* italic accents read as white in dark mode */
  --hero-overlay-tint: rgba(0, 0, 0, 0.0);
  --grain-blend: screen;
  --swatch-ring: rgba(255,255,255,0.18);
  --emblem-url: url('assets/emblem-white.png');
}

/* ---- Reset / base ------------------------------------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: #000; color: var(--ink); font-family: var(--font-body); }
body { font-feature-settings: "ss01","kern","liga"; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }

/* ---- Theme switcher (chrome) -------------------------- */
.theme-bar {
  position: fixed; top: 16px; right: 16px;
  z-index: 9999;
  display: flex; align-items: center; gap: 0;
  background: rgba(20,20,22,0.78); color: #fff;
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(14px) saturate(160%);
  padding: 6px; border-radius: 999px;
  font-family: var(--font-display);
  font-size: 15px; letter-spacing: 0.18em; text-transform: uppercase;
}
.theme-bar button {
  background: transparent; color: #cfcfcf; border: 0;
  padding: 8px 14px; cursor: pointer; border-radius: 999px;
  font: inherit; letter-spacing: inherit; text-transform: inherit;
  transition: color .2s ease, background .2s ease;
}
.theme-bar button:hover { color: #fff; }
.theme-bar button[aria-pressed="true"] {
  background: #fff; color: #101820;
}

/* ---- Deck overrides ----------------------------------- */
deck-stage { background: #000; }
deck-stage > section {
  background: var(--paper);
  color: var(--ink);
  overflow: hidden;
  position: relative;
}

/* slide page-number ribbon (bottom-left, very small) */
.page-no {
  position: absolute; bottom: 22px; left: 28px;
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint);
  font-variant-numeric: tabular-nums;
}
.page-foot-right {
  position: absolute; bottom: 22px; right: 28px;
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint);
}

/* ============================================================
   SPREAD — base 2-page layout
   ============================================================ */
.spread {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;  /* hero gets ~59% */
  width: 1920px; height: 1080px;
}
.spread > .page {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.spread .page + .page { border-left: 1px solid var(--hairline); }
[data-theme="dark"] .spread .page + .page { border-left: 1px solid rgba(255,255,255,0.04); }
.spread .page-soft   { background: var(--paper-soft); }
.spread .page-paper  { background: var(--paper); }

/* ============================================================
   COVER
   ============================================================ */
.cover {
  width: 1920px; height: 1080px; position: relative;
  background: var(--paper);
  display: grid; grid-template-columns: 1fr 1fr;
}
.cover .cover-type {
  padding: 80px 80px 80px 96px;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; z-index: 2;
}
.cover .cover-img {
  position: relative; overflow: hidden;
  background: var(--paper-soft);
}
.cover .cover-img img {
  width: 100%; height: 100%; object-fit: cover;
}
.cover .vol {
  font-family: var(--font-display);
  font-size: 15px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-soft);
  display: flex; gap: 18px; align-items: center;
}
.cover .vol::before { content: ""; display: block; width: 60px; height: 1px; background: var(--ink); }
.cover h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 168px;
  line-height: 0.86;
  letter-spacing: -0.04em;
  color: var(--ink);
  margin: 0;
}
.cover h1 em {
  font-style: italic; font-weight: 300;
  color: var(--accent-red);
}
.cover .cover-foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px;
}
.cover .cover-foot .lockup {
  width: 96px; height: 96px;
  background-image: url('assets/emblem-red.png');  /* signature red on cover */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left bottom;
}
.cover .cover-foot .meta {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
  text-align: right;
}

/* ============================================================
   FOREWORD / opening statement
   ============================================================ */
.foreword {
  width: 1920px; height: 1080px;
  background: var(--paper);
  padding: 120px 200px;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
  align-items: start;
}
.foreword .label-col {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.foreword .label-col .num {
  display: block; color: var(--ink); margin-top: 8px;
  font-size: 20px; letter-spacing: 0.18em;
}
.foreword .lede {
  font-family: var(--font-display);
  font-size: 56px; line-height: 1.05; letter-spacing: -0.02em;
  color: var(--ink);
  font-weight: 400;
  max-width: 1100px;
  text-wrap: balance;
}
.foreword .lede em { font-style: italic; color: var(--accent-red); font-weight: 300; }
.foreword .small {
  margin-top: 64px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  font-family: var(--font-body); font-size: 22px; line-height: 1.55;
  color: var(--ink-soft); max-width: 1280px;
}

/* ============================================================
   INDEX / contents
   ============================================================ */
.contents {
  width: 1920px; height: 1080px;
  background: var(--paper);
  padding: 100px 120px;
  display: grid; grid-template-columns: 320px 1fr;
  gap: 100px;
}
.contents .meta-col {
  display: flex; flex-direction: column; gap: 28px;
}
.contents .eyebrow {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.contents .title-block {
  font-family: var(--font-display); font-weight: 600;
  font-size: 56px; line-height: 0.95; letter-spacing: -0.02em;
  color: var(--ink);
}
.contents .title-block em { font-style: italic; font-weight: 300; color: var(--accent-red); }
.contents .note {
  font-family: var(--font-body); font-size: 20px; line-height: 1.55;
  color: var(--ink-soft); max-width: 360px;
}

.contents .list {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0 80px;
  align-content: start;
  border-top: 1px solid var(--hairline);
}
.contents .list .item {
  display: grid;
  grid-template-columns: 56px 1fr 100px;
  align-items: baseline;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid var(--hairline);
}
.contents .list .item .no {
  font-family: var(--font-display); font-size: 20px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.1em; color: var(--ink-faint);
}
.contents .list .item .name {
  font-family: var(--font-display); font-weight: 600;
  font-size: 34px; letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: uppercase;
}
.contents .list .item .code {
  font-family: var(--font-display); font-size: 16px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-faint); text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   EDITORIAL SPREAD — hero photography
   ============================================================ */
.spread.editorial { background: var(--paper); }

.spread.editorial .page-left {
  padding: 56px 56px 56px 80px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 32px;
  background: var(--paper-soft);
}
.editorial .top-meta {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.editorial .top-meta .right {
  color: var(--ink);
}

.editorial .family-block { display: flex; flex-direction: column; gap: 28px; }
.editorial .series-pill {
  display: inline-flex; align-items: baseline; gap: 14px;
  font-family: var(--font-display); font-size: 20px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink);
}
.editorial .series-pill .big {
  font-size: 32px; font-weight: 700; letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.editorial .series-pill .label {
  color: var(--ink-soft); font-size: 16px;
}

.editorial .name {
  font-family: var(--font-display);
  font-weight: 700; font-size: 132px; line-height: 0.86;
  letter-spacing: -0.045em;
  color: var(--ink);
  text-transform: uppercase;
  margin: 0;
}
/* Editorial title dot stays Ritzi red on BOTH themes — it's the page's
   signature mark and the only red on the spread. */
.editorial .name .accent { color: #EF3340; font-weight: 300; font-style: italic; }

.editorial .manifesto {
  font-family: var(--font-display); font-weight: 400;
  font-size: 30px; line-height: 1.06; letter-spacing: -0.015em;
  color: var(--ink);
  max-width: 540px;
  text-wrap: balance;
  margin: 0;
}
.editorial .manifesto em { font-style: italic; color: var(--accent-red); font-weight: 300; }

.editorial .blurb {
  font-family: var(--font-body); font-size: 22px; line-height: 1.55;
  color: var(--ink-soft);
  max-width: 600px;
}

/* Left-page product detail on TECHNICAL spread (Dainty / Finesse) —
   a tall chrome cut-out anchored to the bottom-left so it grounds the
   spec page next to the product grid. */
.spread.technical.has-left-hero .page-left {
  position: relative;
  padding-left: 80px;
  padding-right: 64px;
  overflow: hidden;
}
.spread.technical .tech-left-hero {
  position: absolute;
  left: -60px;
  bottom: -180px;
  width: 720px;
  height: auto;
  max-height: 1320px;
  object-fit: contain;
  object-position: bottom left;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  mask-image: linear-gradient(180deg, transparent 0%, #000 10%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 10%, #000 100%);
}
/* Ample uses a tightly-cropped top-angle render that should float
   away from the text, not bleed into it. */
.spread.technical .tech-left-hero.ample-top {
  left: -180px;
  bottom: -420px;
  top: auto;
  transform: none;
  width: 880px;
  max-height: 1320px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.dainty-top {
  left: -180px;
  bottom: -420px;
  top: auto;
  transform: none;
  width: 880px;
  max-height: 1320px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.finesse-top {
  left: -180px;
  bottom: -260px;
  top: auto;
  transform: none;
  width: 880px;
  max-height: 1320px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.posh-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.dazzle-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.swank-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.rizz-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.plush-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.ornate-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
.spread.technical .tech-left-hero.lavish-top,
.spread.technical .tech-left-hero.glamour-top,
.spread.technical .tech-left-hero.galore-top,
.spread.technical .tech-left-hero.stellar-top {
  left: -120px;
  bottom: -160px;
  top: auto;
  transform: none;
  width: 720px;
  max-height: 1180px;
  object-fit: contain;
  object-position: bottom left;
  mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 100%);
}
/* Hero PNGs now have a genuinely transparent background (cut out from the
   white studio plate). Light mode keeps multiply so the chrome sits on the
   cream page and matches the right-page variant cards. Dark mode composites
   normally — the cutout chrome reads correctly on the dark page with no
   invert/screen hack needed. */
.spread.technical .tech-left-hero {
  mix-blend-mode: multiply;
}
[data-theme="dark"] .spread.technical .tech-left-hero {
  mix-blend-mode: normal;
  filter: none;
}
/* Re-stack text content above the hero */
.spread.technical.has-left-hero .tech-eyebrow,
.spread.technical.has-left-hero .tech-header,
.spread.technical.has-left-hero .tech-pillars,
.spread.technical.has-left-hero .finishes {
  position: relative; z-index: 1;
}
.spread.technical.has-left-hero .tech-eyebrow,
.spread.technical.has-left-hero .tech-header,
.spread.technical.has-left-hero .tech-pillars,
.spread.technical.has-left-hero .finishes {
  position: relative; z-index: 1;
}

.editorial .page-right {
  position: relative; background: #000;
  overflow: hidden;
}
.editorial .page-right img.hero {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.editorial .hero-overlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 56px 64px;
  color: #FFFFFF;
  pointer-events: none;
}
.editorial .hero-overlay .top-tag {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: rgba(255,255,255,0.86);
  display: flex; justify-content: space-between;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.editorial .hero-overlay .cap {
  font-family: var(--font-display); font-weight: 400;
  font-size: 26px; line-height: 1.1; letter-spacing: -0.015em;
  color: #FFFFFF;
  max-width: 460px;
  text-wrap: balance;
  text-shadow: 0 4px 24px rgba(0,0,0,0.5);
}
.editorial .hero-overlay .cap small {
  display: block; font-size: 15px; letter-spacing: 0.22em;
  margin-top: 14px; color: rgba(255,255,255,0.78);
  text-transform: uppercase;
}

/* hero-only spread variant (no left page) */
.spread.full-hero { grid-template-columns: 1fr; position: relative; }
.spread.full-hero img.hero {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}
.spread.full-hero .hero-meta {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 80px 96px; color: #fff; pointer-events: none;
}
.spread.full-hero .hero-meta .top {
  display: flex; justify-content: space-between; align-items: flex-start;
  font-family: var(--font-display); font-size: 16px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.86);
}
.spread.full-hero .hero-meta h2 {
  font-family: var(--font-display); font-weight: 400;
  font-size: 96px; line-height: 0.95; letter-spacing: -0.025em;
  color: #fff; margin: 0; max-width: 900px;
  text-wrap: balance;
  text-shadow: 0 4px 30px rgba(0,0,0,0.55);
}
.spread.full-hero .hero-meta h2 em {
  font-style: italic; font-weight: 300;
  color: #fff; opacity: 0.7;
}
.spread.full-hero .hero-meta {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 80px 96px; color: #fff; pointer-events: none;
}
.spread.full-hero .hero-meta .top {
  display: flex; justify-content: space-between; align-items: flex-start;
  font-family: var(--font-display); font-size: 16px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.86);
}
.spread.full-hero .hero-meta h2 {
  font-family: var(--font-display); font-weight: 400;
  font-size: 96px; line-height: 0.95; letter-spacing: -0.025em;
  color: #fff; margin: 0; max-width: 900px;
  text-wrap: balance;
  text-shadow: 0 4px 30px rgba(0,0,0,0.55);
}
.spread.full-hero .hero-meta h2 em {
  font-style: italic; font-weight: 300;
  color: #fff; opacity: 0.7;
}

/* ---- Family opener: full-bleed landscape with editorial overlay ---- */
.spread.full-hero.intro-hero { background: #0b0d10; }
.spread.full-hero.intro-hero img.hero {
  object-fit: cover; opacity: 0.92;
}
.spread.full-hero.intro-hero .intro-scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,0.45) 0%,
      rgba(0,0,0,0.10) 18%,
      rgba(0,0,0,0.00) 38%,
      rgba(0,0,0,0.00) 50%,
      rgba(0,0,0,0.55) 75%,
      rgba(0,0,0,0.88) 100%);
  pointer-events: none;
}
.spread.full-hero .hero-meta.intro-meta {
  padding: 56px 96px 88px;
  /* Drive these from --intro-* CSS vars set by the Tweaks panel so the
     editor can flip text position + alignment without touching markup. */
  justify-content: var(--intro-justify, space-between);
  align-items: var(--intro-align, stretch);
  text-align: var(--intro-text-align, left);
  display: flex;
  flex-direction: column;
}
.spread.full-hero .hero-meta.intro-meta .top {
  margin-bottom: var(--intro-top-mb, auto);
  display: flex; justify-content: space-between;
  width: 100%;
}
.spread.full-hero .hero-meta.intro-meta .family-splash {
  margin-top: var(--intro-splash-mt, auto);
}
.spread.full-hero .hero-meta.intro-meta .intro-bottom {
  align-items: var(--intro-bottom-align, flex-start);
}

/* Per-slide override: Stellar opener (slide 25) — family name floats in the
   vertical middle, the kicker / sub copy stays anchored at the bottom. */
section[data-screen-label="25 Stellar · Opener"] .hero-meta.intro-meta {
  justify-content: space-between;
}
section[data-screen-label="25 Stellar · Opener"] .hero-meta.intro-meta {
  align-items: center;
  text-align: center;
  padding-top: 0;
}
section[data-screen-label="25 Stellar · Opener"] .hero-meta.intro-meta .top {
  display: none;
}
section[data-screen-label="25 Stellar · Opener"] .hero-meta.intro-meta .family-splash {
  margin: -40px auto auto;
  align-self: center;
  text-align: center;
  width: 100%;
  line-height: 0.86;
}

/* Per-slide override: Glamour opener (slide 34) — family name perfectly
   centered both horizontally and vertically over the photo. */
section[data-screen-label="34 Glamour · Opener"] .hero-meta.intro-meta {
  align-items: center;
  text-align: center;
  justify-content: center;
  padding-bottom: 88px;
}
section[data-screen-label="34 Glamour · Opener"] img.hero,
section[data-screen-label="34 Glamour · Opener"] .hero-bg {
  object-position: center center !important;
  background-position: center center !important;
}
section[data-screen-label="34 Glamour · Opener"] .hero-meta.intro-meta {
  position: absolute !important;
  inset: 0 !important;
  z-index: 5;
}
section[data-screen-label="34 Glamour · Opener"] .hero-meta.intro-meta .top {
  display: none;
}
section[data-screen-label="34 Glamour · Opener"] .hero-meta.intro-meta .family-splash {
  margin: auto;
  align-self: center;
  text-align: center;
  width: 100%;
}
section[data-screen-label="34 Glamour · Opener"] .hero-meta.intro-meta .intro-bottom {
  margin-top: 0;
  align-self: center;
  align-items: center;
  text-align: center;
}

/* Per-slide override: Ornate opener (slide 28) — family name anchored
   top-left, the kicker / sub copy stays at the bottom. */
section[data-screen-label="28 Ornate · Opener"] .hero-meta.intro-meta {
  justify-content: space-between;
  align-items: flex-start;
  text-align: left;
}
section[data-screen-label="28 Ornate · Opener"] .hero-meta.intro-meta .family-splash {
  margin-top: 0;
  margin-bottom: auto;
  align-self: flex-start;
}

/* Per-slide override: Galore opener (slide 31) — family name anchored
   top-left, the kicker / sub copy stays at the bottom. */
section[data-screen-label="31 Galore · Opener"] .hero-meta.intro-meta {
  justify-content: space-between;
  align-items: flex-start;
  text-align: left;
}
section[data-screen-label="31 Galore · Opener"] .hero-meta.intro-meta {
  padding-left: 0;
}
section[data-screen-label="31 Galore · Opener"] .hero-meta.intro-meta .family-splash {
  margin-top: -56px;
  margin-left: -120px;
  margin-bottom: auto;
  align-self: flex-start;
}

/* Per-slide override: Plush opener (slide 19) — push splash to the far left. */
section[data-screen-label="19 Plush · Opener"] .hero-meta.intro-meta {
  padding-left: 0;
}
section[data-screen-label="19 Plush · Opener"] .hero-meta.intro-meta .family-splash {
  margin-left: -120px;
  align-self: flex-start;
}

/* Per-slide override: Ample opener (slide 7) — push splash to the far left. */
section[data-screen-label="07 Ample · Opener"] .hero-meta.intro-meta {
  padding-left: 0;
}
section[data-screen-label="07 Ample · Opener"] .hero-meta.intro-meta .family-splash {
  margin-left: -120px;
  align-self: flex-start;
}

/* Per-slide override: Swank opener (slide 38) — push splash further left
   so it doesn't overlap the photo subject. */
section[data-screen-label="38 Swank · Opener"] .hero-meta.intro-meta {
  padding-left: 0;
}
section[data-screen-label="38 Swank · Opener"] .hero-meta.intro-meta .family-splash {
  margin-left: -120px;
  align-self: flex-start;
}
.spread.full-hero .hero-meta.intro-meta .top {
  font-size: 15px; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.92);
  display: flex; justify-content: space-between; align-items: flex-start;
}
.spread.full-hero .hero-meta.intro-meta .intro-bottom {
  display: flex; flex-direction: column; gap: 28px;
  max-width: 1100px;
}
.spread.full-hero .hero-meta.intro-meta .intro-rule {
  width: 56px; height: 1px; background: rgba(255,255,255,0.7);
}
.spread.full-hero .hero-meta.intro-meta h2 {
  font-family: var(--font-display); font-weight: 300;
  font-size: 72px; line-height: 1.04; letter-spacing: -0.02em;
  color: rgba(255,255,255,0.95); margin: 0; max-width: 980px;
  text-wrap: balance;
  text-shadow: 0 3px 24px rgba(0,0,0,0.55);
}
.spread.full-hero .hero-meta.intro-meta h2 em {
  font-style: italic; font-weight: 300;
  color: #fff; opacity: 0.88;
}

/* ---- The splash: massive display caps as a chapter watermark ---- */
.spread.full-hero.intro-hero .family-splash {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 600;
  font-size: clamp(180px, 16vw, 240px);
  line-height: 0.86;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 18px -4px;
  padding: 0;
  position: relative;
  display: block;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  text-shadow: 0 6px 40px rgba(0,0,0,0.55);
}
.spread.full-hero.intro-hero .family-splash::before,
.spread.full-hero.intro-hero .family-splash::after {
  content: none;
}
.spread.full-hero .hero-meta.intro-meta .intro-rule {
  width: 96px; height: 1px; background: rgba(255,255,255,0.65);
  margin-top: 6px;
}
.spread.full-hero .hero-meta.intro-meta .intro-foot {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 16px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.82);
}
/* Default layout for every family opener: family-splash anchored top-left,
   sub-text block anchored bottom-left. Tweaks panel can override via CSS vars. */
.spread.full-hero.intro-hero .hero-meta.intro-meta {
  justify-content: var(--intro-justify, flex-start);
}
.spread.full-hero.intro-hero .hero-meta.intro-meta .top {
  margin-bottom: var(--intro-top-mb, 12px);
}
.spread.full-hero.intro-hero .hero-meta.intro-meta .family-splash {
  margin-top: var(--intro-splash-mt, 0);
  margin-bottom: auto;
  align-self: flex-start;
}
.spread.full-hero.intro-hero .hero-meta.intro-meta .intro-bottom {
  align-self: var(--intro-bottom-self, flex-start);
  align-items: var(--intro-bottom-align, flex-start);
  text-align: var(--intro-text-align, left);
  margin-top: auto;
}
/* Hide the bottom kicker line + page number across every family opener */
.spread.full-hero.intro-hero .hero-meta.intro-meta .intro-foot { display: none; }
.spread.full-hero .hero-meta.intro-meta .intro-kicker {
  letter-spacing: 0.14em; text-transform: none;
  font-style: italic; font-size: 22px;
  color: rgba(255,255,255,0.92);
}

/* ============================================================
   TECHNICAL SPREAD — product grid + finishes
   ============================================================ */
.spread.technical .page-left {
  padding: 64px 80px;
  background: var(--paper);
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 40px;
}

.tech-eyebrow {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}

.tech-header h3 {
  font-family: var(--font-display); font-weight: 600;
  font-size: 40px; line-height: 1; letter-spacing: -0.025em;
  color: var(--ink); margin: 0;
  text-transform: uppercase;
}
.tech-header .series-line {
  display: flex; align-items: baseline; gap: 16px;
  margin-top: 12px;
  font-family: var(--font-display); font-size: 16px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
}
.tech-header .series-line .big {
  font-size: 30px; color: var(--ink); font-weight: 700;
  letter-spacing: -0.01em; font-variant-numeric: tabular-nums;
}
.tech-header p.desc {
  font-family: var(--font-body); font-size: 17px; line-height: 1.55;
  color: var(--ink-soft); margin-top: 18px; max-width: 440px;
}

.tech-pillars {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px 28px;
  align-self: start;
  padding-top: 24px;
  border-top: 1px solid var(--hairline);
}
.tech-pillars .pillar .k {
  font-family: var(--font-display); font-size: 14px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 6px;
}
.tech-pillars .pillar .v {
  font-family: var(--font-display); font-size: 17px;
  color: var(--ink); letter-spacing: -0.005em;
}

/* finishes row */
.finishes {
  border-top: 1px solid var(--hairline);
  padding-top: 24px;
  display: flex; flex-direction: column; gap: 16px;
}
.finishes .label {
  font-family: var(--font-display); font-size: 14px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint);
}
/* single-finish variant — Chrome only, presented as one line */
.finishes-single .single-line {
  display: flex; align-items: center; gap: 18px;
}
.finishes-single .swatch.lg {
  width: 56px; height: 56px; border-radius: 999px;
  box-shadow: inset 0 0 0 1px var(--swatch-ring);
}
.finishes-single .meta .name {
  font-family: var(--font-display); font-weight: 600;
  font-size: 19px; letter-spacing: -0.005em; color: var(--ink);
  display: flex; align-items: baseline; gap: 12px;
}
.finishes-single .meta .name .code {
  font-family: var(--font-display); font-weight: 400;
  font-size: 15px; letter-spacing: 0.18em;
  color: var(--ink-faint); text-transform: uppercase;
}
.finishes-single .meta .sub {
  font-family: var(--font-body); font-size: 15px; line-height: 1.45;
  color: var(--ink-soft); margin-top: 2px;
}
.finishes ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: 28px; flex-wrap: wrap;
}
.finishes li {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-display); font-size: 18px;
  letter-spacing: 0.04em; color: var(--ink);
}
.finishes .swatch {
  width: 22px; height: 22px; border-radius: 50%;
  box-shadow: inset 0 0 0 1px var(--swatch-ring);
}
.swatch.s-chrome   { background: radial-gradient(circle at 30% 25%, #FAFAFA 0%, #D8DCDE 35%, #97A0A6 65%, #5E646A 100%); }
.swatch.s-gunmetal { background: radial-gradient(circle at 30% 25%, #6A6E73 0%, #3A3D40 60%, #1B1D20 100%); }
.swatch.s-black    { background: radial-gradient(circle at 30% 25%, #2A2A2A 0%, #0A0A0A 100%); }
.swatch.s-gold     { background: radial-gradient(circle at 30% 25%, #F0CE82 0%, #B58D3F 60%, #6B4A18 100%); }
.swatch.s-rose     { background: radial-gradient(circle at 30% 25%, #F2C6B0 0%, #C58266 60%, #7D4733 100%); }

/* product grid (right page) */
.spread.technical .page-right {
  padding: 56px 96px 56px 64px;
  background: var(--paper);
  display: grid; grid-template-rows: auto 1fr; gap: 32px;
}
.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 28px;
  align-content: start;
}
.product-grid.col-1 { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
.product-grid.col-3 { grid-template-columns: 1fr 1fr 1fr; gap: 18px 22px; }
.product {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 14px;
  padding: 12px 12px 18px;
  background: transparent;
}
.product .img-wrap {
  background: transparent;
  display: flex; align-items: center; justify-content: center;
  height: 320px;
  position: relative;
}
/* soft floor-puck of light, so floating products feel grounded */
.product .img-wrap::before {
  content: "";
  position: absolute; left: 12%; right: 12%; bottom: 6%;
  height: 14%;
  background: radial-gradient(ellipse at center, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0) 65%);
  filter: blur(2px);
  pointer-events: none;
}
[data-theme="dark"] .product .img-wrap::before {
  background: radial-gradient(ellipse at center, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0) 65%);
}
.product-grid.col-3 .img-wrap { height: 200px; }

/* Kitchens spread shows 5 product cards in a 3-column grid (3 + 2).
   Compress everything so all 5 fit inside the 1080px slide. */
.product-grid.col-3.kitchens-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 24px 28px;
}
.product-grid.col-3.kitchens-grid .img-wrap { height: 160px; }
.product-grid.col-3.kitchens-grid .product .specs { font-size: 11px; gap: 1px 10px; }
[data-theme="dark"] .product .img-wrap {
  background: transparent;
}
.product .img-wrap img {
  max-width: 90%; max-height: 95%;
  object-fit: contain;
  mix-blend-mode: multiply;     /* knocks the white background out */
  position: relative; z-index: 1;
}
[data-theme="dark"] .product .img-wrap img {
  /* keep the real product photo as-is — clean revert */
  mix-blend-mode: normal;
  filter: none;
}
.product .code {
  font-family: var(--font-display); font-size: 15px;
  font-weight: 600; letter-spacing: 0.04em;
  color: var(--ink); font-variant-numeric: tabular-nums;
}
.product .desc {
  font-family: var(--font-body); font-size: 13px; line-height: 1.4;
  color: var(--ink-soft); margin-top: 4px;
}
.product .specs {
  list-style: none; margin: 8px 0 0; padding: 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px 12px;
  font-family: var(--font-body); font-size: 12px; line-height: 1.4;
  color: var(--ink-faint);
}
.product .specs span.k { color: var(--ink-faint); }
.product .specs span.v { color: var(--ink-soft); }

/* product hairline divider under code */
.product .code-row {
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
}

/* ============================================================
   AMBIENCE SPREAD (4-up grid)
   ============================================================ */
.ambience {
  width: 1920px; height: 1080px;
  background: var(--paper);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  position: relative;
}
.ambience .tile {
  position: relative; overflow: hidden; background: #000;
}
.ambience .tile img {
  width: 100%; height: 100%; object-fit: cover;
}
.ambience .tile .label {
  position: absolute; left: 24px; bottom: 22px;
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: #fff; opacity: 0.86;
}
.ambience .header {
  position: absolute; left: 0; right: 0; top: 0;
  padding: 48px 96px; z-index: 3;
  display: flex; justify-content: space-between;
  color: #fff;
  font-family: var(--font-display); font-size: 16px;
  letter-spacing: 0.22em; text-transform: uppercase;
  mix-blend-mode: difference;
}

/* ============================================================
   PALETTE — single chrome finish spotlight
   ============================================================ */
.palette {
  width: 1920px; height: 1080px;
  background: var(--paper);
  padding: 100px 120px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 100px;
}
.palette .left {
  display: flex; flex-direction: column; gap: 28px;
}
.palette .left .eyebrow {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.palette .left h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: 96px; line-height: 0.92; letter-spacing: -0.025em;
  color: var(--ink); margin: 0; text-transform: uppercase;
}
.palette .left h2 em { font-style: italic; font-weight: 300; color: var(--accent-red); }
.palette .left p {
  font-family: var(--font-body); font-size: 22px; line-height: 1.55;
  color: var(--ink-soft); max-width: 600px;
}
.palette .meta-list {
  margin-top: 12px; max-width: 480px;
  border-top: 1px solid var(--hairline);
  display: flex; flex-direction: column;
}
.palette .meta-list .row {
  display: grid; grid-template-columns: 140px 1fr;
  padding: 14px 0; border-bottom: 1px solid var(--hairline);
  font-family: var(--font-display);
}
.palette .meta-list .row .k {
  font-size: 14px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-faint);
}
.palette .meta-list .row .v {
  font-size: 20px; color: var(--ink); letter-spacing: -0.005em;
}
.palette .single-swatch-wrap {
  display: flex; flex-direction: column; gap: 24px;
  align-items: center; justify-content: center;
}
.palette .single-swatch {
  width: 100%; aspect-ratio: 1 / 1.25;
  border-radius: 4px;
  background:
    radial-gradient(ellipse at 25% 20%, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0) 35%),
    radial-gradient(circle at 35% 30%, #FAFAFA 0%, #D8DCDE 28%, #9EA6AB 55%, #5E646A 80%, #2F3438 100%);
  box-shadow:
    inset 0 0 0 1px var(--swatch-ring),
    inset 0 -120px 200px -20px rgba(0,0,0,0.35);
  position: relative; overflow: hidden;
}
.palette .single-swatch::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(120deg, transparent 40%, rgba(255,255,255,0.18) 50%, transparent 60%);
}
.palette .hash {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint);
}

/* ============================================================
   CLOSING
   ============================================================ */
.closing {
  width: 1920px; height: 1080px;
  background: var(--paper);
  display: grid; grid-template-columns: 1fr 1fr;
}
.closing .ink {
  padding: 100px; display: flex; flex-direction: column; justify-content: space-between;
}
.closing .ink h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 144px; line-height: 0.86; letter-spacing: -0.04em;
  color: var(--ink); margin: 0; text-transform: uppercase;
}
.closing .ink h2 em { font-style: italic; font-weight: 300; color: var(--accent-red); }
.closing .ink .signoff {
  display: flex; flex-direction: column; gap: 12px;
  font-family: var(--font-body); font-size: 22px; line-height: 1.55;
  color: var(--ink-soft);
  max-width: 460px;
}
.closing .ink .lockup {
  width: 120px; height: 120px;
  background-image: var(--emblem-url);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left bottom;
}

.closing .img { position: relative; overflow: hidden; background: var(--paper-soft); }
.closing .img img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================
   DIVIDER / chapter spread (used for KITCHENS ambience)
   ============================================================ */
.chapter {
  width: 1920px; height: 1080px;
  background: var(--paper);
  display: grid; grid-template-columns: 1fr 1fr; position: relative;
}
.chapter .text-side {
  padding: 100px 96px; display: flex; flex-direction: column; justify-content: space-between;
  background: var(--paper-soft);
}
.chapter .text-side .eyebrow {
  font-family: var(--font-display); font-size: 15px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-soft);
  display: flex; gap: 18px; align-items: center;
}
.chapter .text-side .eyebrow::before { content: ""; display: block; width: 48px; height: 1px; background: var(--ink); }
.chapter .text-side h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 144px; line-height: 0.88; letter-spacing: -0.04em;
  color: var(--ink); margin: 0; text-transform: uppercase;
}
.chapter .text-side h2 em { font-style: italic; font-weight: 300; color: var(--accent-red); }
.chapter .text-side .body {
  font-family: var(--font-body); font-size: 22px; line-height: 1.55;
  color: var(--ink-soft); max-width: 560px;
}
.chapter .img-side { position: relative; overflow: hidden; }
.chapter .img-side img { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================
   Dark-mode photo treatment — slight desaturation for unity
   ============================================================ */
[data-theme="dark"] .editorial .page-right img.hero,
[data-theme="dark"] .spread.full-hero img.hero,
[data-theme="dark"] .closing .img img,
[data-theme="dark"] .chapter .img-side img,
[data-theme="dark"] .ambience .tile img {
  filter: brightness(0.78) contrast(1.05);
}

[data-theme="dark"] .cover .cover-img img {
  filter: brightness(0.78) contrast(1.05);
}

/* Small ritzi mark embedded in spreads */
.r-mark {
  display: inline-block;
  width: 36px; height: 36px;
  background-image: var(--emblem-url);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  vertical-align: middle;
}
.r-emblem {
  display: inline-block;
  background-image: var(--emblem-url);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.r-emblem.lg { width: 140px; height: 140px; }
.r-emblem.md { width: 56px;  height: 56px;  }
.r-emblem.sm { width: 30px;  height: 30px;  }
