/* ============================================================
   Banjara Art Showcase — Shared Stylesheet
   Aesthetic: Indian textile editorial magazine
   Palette: warm indigo base + terracotta / saffron / emerald / mirror
   Type: Fraunces (display) · Cormorant Garamond (body) · Tiro Devanagari Hindi (accent)
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT@0,9..144,300..900,0..100;1,9..144,400..900,0..100&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Tiro+Devanagari+Hindi:ital@0;1&display=swap");

/* ---------- 1. Design tokens ---------- */
:root {
  /* Palette */
  --ink-indigo: #1e2d4a;
  --ink-indigo-deep: #131c30;
  --ink-brown: #3a1f1a;
  --paper: #f4ead5;
  --paper-warm: #efe1c2;
  --paper-faded: #d9cca9;
  --terracotta: #c84b31;
  --terracotta-deep: #9e3521;
  --saffron: #e8a33d;
  --saffron-soft: #f4c573;
  --emerald: #1f6e5d;
  --emerald-soft: #3a8d7b;
  --ochre: #8b5a2b;
  --mirror: #fff8e7;
  --mirror-shine: #ffffff;

  /* Text */
  --ink-on-dark: #f4ead5;
  --ink-on-dark-muted: #c8b88f;
  --ink-on-light: #1e2d4a;
  --ink-on-light-muted: #5b6278;

  /* Rhythm */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4.5rem;
  --space-9: 6.5rem;
  --space-10: 9rem;

  /* Radii + shadows */
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 22px;
  --shadow-paper: 0 1px 0 rgba(30, 45, 74, 0.08), 0 24px 48px -28px rgba(19, 28, 48, 0.55);
  --shadow-lift: 0 12px 28px -16px rgba(19, 28, 48, 0.8), 0 2px 0 rgba(232, 163, 61, 0.25);

  /* Type scale — editorial, generous */
  --fs-mono: 0.78rem;
  --fs-small: 0.92rem;
  --fs-body: 1.08rem;
  --fs-lead: 1.25rem;
  --fs-h5: 1.15rem;
  --fs-h4: 1.5rem;
  --fs-h3: 2rem;
  --fs-h2: clamp(2.4rem, 4.6vw, 4rem);
  --fs-h1: clamp(3.4rem, 9vw, 8rem);

  /* Motion */
  --ease-out: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

  --nav-h: 72px;
}

/* ---------- 2. Reset + base ---------- */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-h) + 16px);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  margin: 0;
  font-family: "Cormorant Garamond", "Iowan Old Style", Georgia, serif;
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink-on-dark);
  background: var(--ink-indigo-deep);
  overflow-x: hidden;
  position: relative;
}

/* Textured paper backdrop using layered gradients + noise via SVG data-uri */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(200, 75, 49, 0.09), transparent 55%),
    radial-gradient(ellipse at 85% 15%, rgba(232, 163, 61, 0.07), transparent 50%),
    radial-gradient(ellipse at 50% 90%, rgba(31, 110, 93, 0.08), transparent 55%),
    linear-gradient(180deg, #141f37 0%, #1e2d4a 30%, #1e2d4a 70%, #182545 100%);
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  opacity: 0.55;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='260' height='260'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.25  0 0 0 0 0.2  0 0 0 0 0.15  0 0 0 0.35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
}

img, svg { display: block; max-width: 100%; height: auto; }

a {
  color: inherit;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: rgba(232, 163, 61, 0.35);
  transition: color 220ms var(--ease-out), text-decoration-color 220ms var(--ease-out);
}
a:hover { color: var(--saffron); text-decoration-color: var(--saffron); }

button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }

:focus-visible {
  outline: 2px solid var(--saffron);
  outline-offset: 3px;
  border-radius: 2px;
}

::selection { background: var(--saffron); color: var(--ink-indigo); }

/* ---------- 3. Type utilities ---------- */
.display {
  font-family: "Fraunces", "Playfair Display", Georgia, serif;
  font-optical-sizing: auto;
  font-variation-settings: "SOFT" 60, "opsz" 144;
  line-height: 1.02;
  letter-spacing: -0.01em;
  font-weight: 700;
}
.display--italic { font-style: italic; font-variation-settings: "SOFT" 100, "opsz" 144; }

.hindi {
  font-family: "Tiro Devanagari Hindi", "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 400;
}

.kicker {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: var(--fs-mono);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--saffron);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.kicker::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 1px;
  background: currentColor;
  opacity: 0.7;
}

.lead {
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--ink-on-dark);
  font-weight: 400;
  font-style: italic;
}

h1, h2, h3, h4, h5 {
  font-family: "Fraunces", serif;
  font-optical-sizing: auto;
  font-variation-settings: "SOFT" 60, "opsz" 144;
  font-weight: 700;
  line-height: 1.08;
  margin: 0 0 0.5em;
  letter-spacing: -0.015em;
  color: var(--mirror);
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); font-weight: 600; letter-spacing: 0; }
h5 { font-size: var(--fs-h5); font-weight: 600; font-style: italic; color: var(--saffron); }

p { margin: 0 0 1em; }
p + p { text-indent: 0; }

/* Drop cap for first paragraph of prose */
.prose > p:first-of-type::first-letter {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 900;
  font-size: 4.6em;
  float: left;
  line-height: 0.88;
  padding: 0.06em 0.12em 0 0;
  color: var(--terracotta);
}

blockquote {
  margin: var(--space-6) 0;
  padding: var(--space-4) var(--space-6);
  border-left: 2px solid var(--saffron);
  font-family: "Fraunces", serif;
  font-style: italic;
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: var(--fs-lead);
  color: var(--mirror);
}

/* ---------- 4. Layout primitives ---------- */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}
.container--narrow { max-width: 860px; }
.container--wide { max-width: 1380px; }

.section {
  padding: var(--space-9) 0;
  position: relative;
}
.section--lg { padding: var(--space-10) 0; }
.section--sm { padding: var(--space-8) 0; }

.grid {
  display: grid;
  gap: var(--space-6);
}
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* ---------- 5. Navigation ---------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 80;
  display: flex;
  align-items: center;
  background: #131c30;
  border-bottom: 1px solid rgba(232, 163, 61, 0.18);
  transition: border-color 260ms var(--ease-out), box-shadow 260ms var(--ease-out);
}
.nav.is-scrolled {
  border-bottom-color: rgba(232, 163, 61, 0.32);
  box-shadow: 0 6px 18px -10px rgba(0, 0, 0, 0.6);
}
.nav__brand, .nav__list { white-space: nowrap; }

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  width: 100%;
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: var(--mirror);
  font-size: 1.35rem;
  line-height: 1;
}
.nav__brand-name { line-height: 1; }
.nav__brand-sub { line-height: 1; align-self: center; }
.nav__brand-name {
  font-family: "Fraunces", "Playfair Display", Georgia, serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 800;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.nav__brand-sub {
  font-family: "Cormorant Garamond", "Iowan Old Style", Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: 0.78em;
  opacity: 0.6;
  letter-spacing: 0.01em;
  margin-left: 0.25em;
}
@media (max-width: 640px) {
  :root { --nav-h: 60px; }
  .nav__brand-sub { display: none; }
  .nav__brand { font-size: 1.1rem; gap: var(--space-2); }
  .nav__brand-mark { width: 24px; height: 24px; }
  .nav__list { gap: var(--space-2); }
  .nav__link { padding: var(--space-2); font-size: 0.9rem; }
}
.nav__brand-mark {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--mirror-shine) 0%, var(--saffron) 45%, var(--terracotta) 80%);
  box-shadow:
    inset 0 0 0 2px rgba(255, 248, 231, 0.3),
    inset 0 0 0 5px rgba(19, 28, 48, 0.4),
    0 0 0 1px rgba(232, 163, 61, 0.5),
    0 4px 10px -4px rgba(0, 0, 0, 0.5);
  position: relative;
}
.nav__brand-mark::after {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--mirror-shine), transparent 70%);
}

.nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--space-4);
  align-items: center;
}
.nav__link {
  position: relative;
  padding: var(--space-2) var(--space-3);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 30, "opsz" 20, "wght" 500;
  font-size: 0.98rem;
  color: var(--ink-on-dark-muted);
  text-decoration: none;
  transition: color 220ms var(--ease-out);
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 12px; right: 12px; bottom: 3px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 260ms var(--ease-out);
}
.nav__link:hover, .nav__link.is-active { color: var(--mirror); }
.nav__link:hover::after, .nav__link.is-active::after { transform: scaleX(1); }
.nav__link.is-active {
  color: var(--saffron);
}

/* Hamburger (hidden — nav is simple with 2 links) */
.nav__toggle { display: none !important; }

@media (max-width: 520px) {
  .nav__link { padding: var(--space-2); font-size: 0.92rem; }
  .nav__brand { font-size: 1.15rem; }
}

/* ---------- 6. Ornaments ---------- */

/* Running-stitch divider */
.stitch-divider {
  display: block;
  height: 22px;
  width: 100%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' height='22' width='100'><g fill='none' stroke='%23e8a33d' stroke-width='1.2' stroke-dasharray='6 5' stroke-linecap='round'><path d='M0 11 H 100'/></g><g fill='%23c84b31'><circle cx='12' cy='11' r='1.6'/><circle cx='50' cy='11' r='1.6'/><circle cx='88' cy='11' r='1.6'/></g></svg>");
  background-repeat: repeat-x;
  background-size: 100px 22px;
  opacity: 0.75;
  margin: var(--space-6) 0;
}

/* Shisha (mirror) decorative dingbat, use as block with ::before or standalone */
.shisha {
  --size: 44px;
  width: var(--size);
  height: var(--size);
  display: inline-block;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 30%, var(--mirror-shine) 0%, var(--saffron-soft) 35%, var(--terracotta) 78%, var(--terracotta-deep) 100%);
  box-shadow:
    inset 0 0 0 2px rgba(255, 248, 231, 0.35),
    inset 0 0 0 5px rgba(30, 45, 74, 0.55),
    inset 0 0 0 6px rgba(232, 163, 61, 0.6),
    0 0 0 1px rgba(232, 163, 61, 0.4),
    0 6px 14px -6px rgba(0, 0, 0, 0.55);
  position: relative;
  flex: none;
}
.shisha::after {
  content: "";
  position: absolute;
  inset: 28%;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 35%, var(--mirror-shine), transparent 65%);
  opacity: 0.9;
}

/* Nakra diamond */
.nakra {
  --size: 14px;
  width: var(--size);
  height: var(--size);
  background: var(--saffron);
  transform: rotate(45deg);
  box-shadow: 0 0 0 2px var(--ink-indigo-deep), 0 0 0 3px var(--saffron);
  display: inline-block;
}

/* Section header block */
.section-head {
  display: grid;
  gap: var(--space-4);
  max-width: 760px;
  margin-bottom: var(--space-7);
}
.section-head__row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}
.section-head__row .shisha { --size: 28px; }

/* ---------- 7. Hero ---------- */
.hero {
  min-height: 100vh;
  min-height: 100svh;
  padding: calc(var(--nav-h) + var(--space-7)) 0 var(--space-8);
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
}
.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
  width: 100%;
  max-width: 1320px;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}
.hero__content { width: 100%; }
.hero__tagline { max-width: none; }
.hero__content { position: relative; z-index: 2; }
.hero__eyebrow {
  font-family: "Tiro Devanagari Hindi", "Cormorant Garamond", serif;
  font-style: italic;
  color: var(--saffron);
  font-size: 1.05rem;
  margin-bottom: var(--space-4);
  letter-spacing: 0.03em;
}
.hero__title {
  font-size: var(--fs-h1);
  font-weight: 800;
  line-height: 0.95;
  margin: 0 0 var(--space-5);
  letter-spacing: -0.02em;
  color: var(--mirror);
}
.hero__title em {
  font-style: italic;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 700;
  color: var(--saffron);
  position: relative;
  display: inline-block;
}
.hero__title em::after {
  content: "";
  position: absolute;
  left: 0; right: -4px; bottom: 0.08em;
  height: 6px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' height='6' width='60'><path d='M1 3 Q 15 0 30 3 T 59 3' stroke='%23c84b31' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat: repeat-x;
  background-size: 60px 6px;
  opacity: 0.9;
}
.hero__tagline {
  font-size: var(--fs-lead);
  color: var(--ink-on-dark-muted);
  max-width: 48ch;
  font-style: italic;
  margin-bottom: var(--space-6);
}
.hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  font-size: 0.92rem;
  color: var(--ink-on-dark-muted);
  font-variant: small-caps;
  letter-spacing: 0.08em;
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
}
.hero__meta-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.hero__meta-item::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--terracotta);
  transform: rotate(45deg);
  display: inline-block;
}

.hero__visual {
  position: relative;
  aspect-ratio: 1 / 1.08;
  width: 100%;
  max-width: 520px;
  justify-self: end;
}
.hero__visual svg {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 30px 45px rgba(0, 0, 0, 0.55));
  animation: floatIn 1.4s var(--ease-out) 0.2s both;
}
@keyframes floatIn {
  from { opacity: 0; transform: translateY(22px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.hero__scroll-cue {
  position: absolute;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--fs-mono);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--ink-on-dark-muted);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
}
.hero__scroll-cue::after {
  content: "";
  width: 1px;
  height: 48px;
  background: linear-gradient(var(--saffron), transparent);
  animation: scrollPulse 2s var(--ease-in-out) infinite;
}
@keyframes scrollPulse {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  51% { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; gap: var(--space-6); }
  .hero__visual { max-width: 360px; justify-self: center; order: -1; }
}

/* ---------- 8. Intro / prose section ---------- */
.intro {
  position: relative;
}
.intro__grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-7);
  align-items: start;
}
.intro__sidebar {
  position: sticky;
  top: calc(var(--nav-h) + var(--space-5));
  padding: var(--space-5);
  border: 1px solid rgba(232, 163, 61, 0.25);
  border-radius: var(--radius-md);
  background: rgba(19, 28, 48, 0.65);
  backdrop-filter: blur(6px);
  display: grid;
  gap: var(--space-4);
}
.intro__sidebar-row {
  display: flex; gap: var(--space-3);
  align-items: baseline;
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed rgba(244, 234, 213, 0.15);
}
.intro__sidebar-row:last-child { border-bottom: 0; padding-bottom: 0; }
.intro__sidebar-label {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--saffron);
  flex: none; width: 80px;
}
.intro__sidebar-value {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.05rem;
  color: var(--mirror);
  font-style: italic;
}

@media (max-width: 900px) {
  .intro__grid { grid-template-columns: 1fr; }
  .intro__sidebar { position: static; }
}

/* ---------- 9. Gallery ---------- */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 260px;
  gap: var(--space-4);
}
.gallery__tile {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--ink-indigo);
  border: 1px solid rgba(232, 163, 61, 0.2);
  isolation: isolate;
  transition: transform 360ms var(--ease-out), box-shadow 360ms var(--ease-out), border-color 360ms;
}
.gallery__tile:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lift);
  border-color: rgba(232, 163, 61, 0.5);
}
.gallery__tile--tall { grid-row: span 2; }
.gallery__tile--wide { grid-column: span 2; }

.gallery__tile svg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
}
.gallery__caption {
  position: absolute;
  left: var(--space-4); bottom: var(--space-4); right: var(--space-4);
  display: flex; justify-content: space-between; align-items: end;
  color: var(--mirror);
  z-index: 2;
  pointer-events: none;
}
.gallery__caption-title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-style: italic;
  font-size: 1.3rem;
  line-height: 1.05;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.6);
}
.gallery__caption-num {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.78rem;
  letter-spacing: 0.28em;
  color: var(--saffron);
}
.gallery__tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(19, 28, 48, 0.85) 100%);
  z-index: 1;
}

@media (max-width: 1024px) {
  .gallery { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
  .gallery__tile--wide { grid-column: span 2; }
  .gallery__tile--tall { grid-row: span 1; }
}

/* ---------- 10. Article cards ---------- */
.articles {
  display: grid;
  gap: var(--space-6);
}
.article-card {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: var(--space-6);
  align-items: center;
  padding: var(--space-5) 0;
  border-top: 1px solid rgba(232, 163, 61, 0.25);
  text-decoration: none;
  color: inherit;
  transition: background 240ms var(--ease-out), padding 240ms;
  position: relative;
}
.article-card:last-child { border-bottom: 1px solid rgba(232, 163, 61, 0.25); }
.article-card:hover {
  background: linear-gradient(90deg, rgba(232, 163, 61, 0.06), transparent 70%);
  padding-left: var(--space-4);
}
.article-card__thumb {
  width: 200px; height: 140px;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: 1px solid rgba(232, 163, 61, 0.3);
  background: var(--ink-indigo);
}
.article-card__thumb svg { width: 100%; height: 100%; }
.article-card__meta {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: var(--fs-mono);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: var(--space-3);
  display: flex; gap: var(--space-4);
}
.article-card__title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-size: 1.75rem;
  line-height: 1.1;
  margin: 0 0 var(--space-3);
  color: var(--mirror);
  max-width: 26ch;
}
.article-card__excerpt {
  color: var(--ink-on-dark-muted);
  font-size: 1.02rem;
  max-width: 54ch;
  margin: 0;
}
.article-card__cta {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--saffron);
  white-space: nowrap;
  transition: transform 260ms var(--ease-out);
}
.article-card:hover .article-card__cta { transform: translateX(6px); color: var(--mirror); }

@media (max-width: 820px) {
  .article-card { grid-template-columns: 1fr; grid-template-rows: auto auto auto; }
  .article-card__thumb { width: 100%; height: 180px; }
  .article-card__cta { justify-self: start; }
}

/* ---------- 11. Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.96rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 999px;
  transition: transform 260ms var(--ease-out), background 260ms, color 260ms, box-shadow 260ms;
  position: relative;
  overflow: hidden;
}
.btn--primary {
  background: var(--saffron);
  color: var(--ink-indigo);
  box-shadow: 0 12px 24px -12px rgba(232, 163, 61, 0.6), inset 0 0 0 1px rgba(19, 28, 48, 0.15);
}
.btn--primary:hover {
  background: var(--mirror);
  transform: translateY(-2px);
  box-shadow: 0 18px 28px -14px rgba(244, 234, 213, 0.6);
}
.btn--ghost {
  color: var(--mirror);
  border: 1px solid rgba(232, 163, 61, 0.6);
  background: transparent;
}
.btn--ghost:hover {
  background: rgba(232, 163, 61, 0.15);
  border-color: var(--saffron);
  transform: translateY(-2px);
}
.btn__arrow { transition: transform 260ms var(--ease-out); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ---------- 12. Artisans teaser banner ---------- */
.teaser {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-6);
  align-items: center;
  padding: var(--space-7);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 85% 30%, rgba(232, 163, 61, 0.18), transparent 55%),
    linear-gradient(135deg, #2a1a18 0%, #3a1f1a 100%);
  border: 1px solid rgba(232, 163, 61, 0.28);
  position: relative;
  overflow: hidden;
}
.teaser::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: calc(var(--radius-lg) - 6px);
  border: 1px dashed rgba(232, 163, 61, 0.35);
  pointer-events: none;
}
.teaser__title {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  margin: 0 0 var(--space-3);
  color: var(--mirror);
  max-width: 22ch;
}
.teaser__text {
  color: var(--ink-on-dark-muted);
  margin: 0;
  max-width: 48ch;
  font-style: italic;
  font-size: 1.08rem;
}
@media (max-width: 720px) {
  .teaser { grid-template-columns: 1fr; }
}

/* ---------- 13. Footer ---------- */
.footer {
  padding: var(--space-8) 0 var(--space-7);
  border-top: 1px solid rgba(232, 163, 61, 0.18);
  margin-top: var(--space-7);
  color: var(--ink-on-dark-muted);
  font-size: 0.94rem;
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
.footer__title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.78rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--saffron);
  margin: 0 0 var(--space-3);
}
.footer__list {
  list-style: none;
  padding: 0; margin: 0;
  display: grid;
  gap: var(--space-2);
}
.footer__list a { text-decoration: none; }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding-top: var(--space-5);
  border-top: 1px dashed rgba(244, 234, 213, 0.14);
  font-size: 0.84rem;
  color: var(--ink-on-dark-muted);
}
.footer__bottom em { color: var(--saffron); font-style: italic; }
@media (max-width: 720px) {
  .footer__grid { grid-template-columns: 1fr; }
}

/* ---------- 14. Article page layout ---------- */
.page-hero {
  padding: calc(var(--nav-h) + var(--space-8)) 0 var(--space-7);
  text-align: left;
  border-bottom: 1px solid rgba(232, 163, 61, 0.25);
  position: relative;
  overflow: hidden;
}
.page-hero__bg {
  position: absolute;
  inset: 0;
  opacity: 0.12;
  pointer-events: none;
  z-index: 0;
}
.page-hero__inner { position: relative; z-index: 1; }
.page-hero__title {
  font-size: var(--fs-h1);
  max-width: 16ch;
  margin: 0 0 var(--space-4);
  font-weight: 800;
}
.page-hero__title em {
  font-style: italic;
  color: var(--saffron);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 700;
}
.page-hero__lead {
  font-size: var(--fs-lead);
  max-width: 60ch;
  color: var(--ink-on-dark-muted);
  font-style: italic;
}

.toc {
  display: flex; flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  margin-top: var(--space-6);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.86rem;
  color: var(--ink-on-dark-muted);
}
.toc a {
  text-decoration: none;
  padding: 4px 12px;
  border: 1px solid rgba(232, 163, 61, 0.3);
  border-radius: 999px;
  transition: background 240ms, color 240ms, border-color 240ms;
}
.toc a:hover { background: var(--saffron); color: var(--ink-indigo); border-color: var(--saffron); }

.prose-section {
  padding: var(--space-9) 0;
  border-bottom: 1px solid rgba(244, 234, 213, 0.1);
}
.prose-section:last-of-type { border-bottom: 0; }
.prose-section__inner {
  display: grid;
  grid-template-columns: minmax(140px, 220px) minmax(0, 1fr);
  gap: var(--space-7);
  align-items: start;
}
.prose-section__marker {
  display: grid;
  gap: var(--space-3);
  padding-right: var(--space-5);
  position: sticky;
  top: calc(var(--nav-h) + var(--space-4));
}
.prose-section__num {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 900;
  font-style: italic;
  font-size: 3.2rem;
  line-height: 0.9;
  color: var(--terracotta);
}
.prose-section__kicker {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.78rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--saffron);
}
.prose-section__body h2 {
  font-size: var(--fs-h2);
  max-width: 20ch;
  margin-top: 0;
}
.prose-section__body p {
  max-width: 60ch;
  color: var(--ink-on-dark);
  font-size: 1.1rem;
}
.prose-section__body p + p { margin-top: var(--space-3); }
@media (max-width: 820px) {
  .prose-section__inner { grid-template-columns: 1fr; }
  .prose-section__marker { position: static; flex-direction: row; display: flex; align-items: baseline; gap: var(--space-4); }
}

/* 14 stitches grid */
.stitches {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: var(--space-4);
}
.stitch {
  padding: var(--space-5) var(--space-4);
  border: 1px solid rgba(232, 163, 61, 0.25);
  border-radius: var(--radius-md);
  background: linear-gradient(160deg, rgba(232, 163, 61, 0.04), rgba(244, 234, 213, 0.02));
  display: grid;
  gap: var(--space-3);
  position: relative;
  overflow: hidden;
  transition: transform 260ms var(--ease-out), border-color 260ms, background 260ms;
}
.stitch:hover {
  transform: translateY(-4px);
  border-color: var(--saffron);
  background: linear-gradient(160deg, rgba(232, 163, 61, 0.14), rgba(200, 75, 49, 0.08));
}
.stitch__num {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 800;
  font-size: 0.92rem;
  letter-spacing: 0.14em;
  color: var(--saffron);
  font-style: italic;
}
.stitch__name {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-size: 1.4rem;
  color: var(--mirror);
  line-height: 1.1;
}
.stitch__desc {
  color: var(--ink-on-dark-muted);
  font-size: 0.98rem;
  line-height: 1.5;
  margin: 0;
}

/* Color swatches */
.swatches {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.swatch {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid rgba(244, 234, 213, 0.14);
  display: grid;
  gap: var(--space-3);
}
.swatch__chip {
  aspect-ratio: 1.5 / 1;
  border-radius: var(--radius-sm);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.swatch__name {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mirror);
}
.swatch__hex {
  color: var(--ink-on-dark-muted);
  font-size: 0.8rem;
  letter-spacing: 0.1em;
}

/* ---------- 15. Artisans cards ---------- */
.disclosure {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  background: linear-gradient(90deg, rgba(200, 75, 49, 0.18), rgba(232, 163, 61, 0.12));
  border: 1px dashed rgba(232, 163, 61, 0.5);
  color: var(--mirror);
  font-size: 0.98rem;
  font-style: italic;
  margin-bottom: var(--space-7);
  display: flex;
  gap: var(--space-4);
  align-items: center;
}
.disclosure__badge {
  flex: none;
  padding: 4px 10px;
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 700;
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  background: var(--saffron);
  color: var(--ink-indigo);
  border-radius: 999px;
  font-style: normal;
}

.artisans {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.artisan {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  background: rgba(19, 28, 48, 0.65);
  border: 1px solid rgba(232, 163, 61, 0.22);
  position: relative;
  overflow: hidden;
  transition: transform 320ms var(--ease-out), border-color 320ms;
}
.artisan:hover { transform: translateY(-6px); border-color: var(--saffron); }
.artisan__portrait {
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  border: 2px solid rgba(232, 163, 61, 0.35);
  overflow: hidden;
  width: 100%;
  max-width: 150px;
  margin-inline: auto;
  box-shadow: 0 10px 24px -12px rgba(0, 0, 0, 0.6), inset 0 0 0 6px rgba(19, 28, 48, 0.7);
}
.artisan__portrait svg { width: 100%; height: 100%; }
.artisan__name {
  text-align: center;
  font-size: 1.55rem;
  margin: 0;
}
.artisan__meta {
  text-align: center;
  color: var(--saffron);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.artisan__bio {
  color: var(--ink-on-dark-muted);
  font-size: 1rem;
  text-align: center;
  max-width: 38ch;
  margin-inline: auto;
  font-style: italic;
}
.artisan__cta {
  justify-self: center;
  padding: var(--space-3) var(--space-5);
  font-size: 0.8rem;
  letter-spacing: 0.2em;
}
@media (max-width: 900px) { .artisans { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .artisans { grid-template-columns: 1fr; } }

/* ---------- 16. Coming soon panel ---------- */
.soon {
  min-height: calc(100vh - var(--nav-h));
  display: grid;
  place-items: center;
  padding: calc(var(--nav-h) + var(--space-7)) 0 var(--space-8);
}
.soon__panel {
  max-width: 720px;
  padding: var(--space-8) var(--space-7);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 25% 20%, rgba(232, 163, 61, 0.14), transparent 55%),
    linear-gradient(150deg, #2a1a18 0%, #1a2440 100%);
  border: 1px solid rgba(232, 163, 61, 0.35);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.soon__panel::before, .soon__panel::after {
  content: "";
  position: absolute;
  border: 1px dashed rgba(232, 163, 61, 0.28);
  border-radius: calc(var(--radius-lg) - 6px);
  pointer-events: none;
}
.soon__panel::before { inset: 10px; }
.soon__panel::after { inset: 22px; border-style: dotted; border-color: rgba(244, 234, 213, 0.1); }
.soon__title {
  font-size: clamp(2.5rem, 6vw, 4rem);
  margin: var(--space-3) 0 var(--space-4);
}
.soon__title em { font-style: italic; color: var(--saffron); }
.soon__text {
  color: var(--ink-on-dark-muted);
  max-width: 48ch;
  margin-inline: auto;
  font-size: 1.08rem;
  font-style: italic;
}
.soon__list {
  list-style: none;
  padding: 0;
  margin: var(--space-6) 0;
  display: grid;
  gap: var(--space-3);
  text-align: left;
}
.soon__list li {
  padding: var(--space-3) var(--space-4);
  border-left: 2px solid var(--saffron);
  background: rgba(244, 234, 213, 0.04);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: baseline;
}
.soon__list-name {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-size: 1.1rem;
  color: var(--mirror);
  white-space: nowrap;
}
.soon__list-text { color: var(--ink-on-dark-muted); font-size: 0.98rem; }
.soon__back { margin-top: var(--space-5); }

/* ---------- 17. Reveal-on-scroll ---------- */
.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
}
.reveal.is-visible { opacity: 1; transform: none; }
.reveal[data-reveal-delay="1"] { transition-delay: 60ms; }
.reveal[data-reveal-delay="2"] { transition-delay: 140ms; }
.reveal[data-reveal-delay="3"] { transition-delay: 220ms; }
.reveal[data-reveal-delay="4"] { transition-delay: 300ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero__visual svg { animation: none; }
  html { scroll-behavior: auto; }
}

/* ---------- 18. Utilities ---------- */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute;
  top: -50px; left: 8px;
  padding: 10px 14px;
  background: var(--saffron);
  color: var(--ink-indigo);
  text-decoration: none;
  border-radius: 6px;
  z-index: 100;
  transition: top 200ms var(--ease-out);
}
.skip-link:focus { top: 8px; }

/* Mono-like inline tag */
.tag {
  display: inline-block;
  padding: 2px 8px;
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--saffron);
  border: 1px solid rgba(232, 163, 61, 0.4);
  border-radius: 999px;
  margin-right: 4px;
  white-space: nowrap;
}

/* References list */
.references {
  list-style: none;
  padding: 0; margin: 0;
  display: grid;
  gap: var(--space-3);
  counter-reset: ref;
}
.references li {
  padding: var(--space-4) var(--space-5);
  background: rgba(244, 234, 213, 0.04);
  border-left: 2px solid var(--terracotta);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: baseline;
  counter-increment: ref;
}
.references li::before {
  content: counter(ref, decimal-leading-zero);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 700;
  font-size: 1.3rem;
  color: var(--saffron);
  font-style: italic;
}
.references a {
  color: var(--mirror);
  word-break: break-word;
  text-decoration-color: rgba(232, 163, 61, 0.4);
}

/* Article page footer CTA strip */
.continue {
  margin-top: var(--space-7);
  padding: var(--space-6);
  border: 1px dashed rgba(232, 163, 61, 0.35);
  border-radius: var(--radius-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  background: rgba(232, 163, 61, 0.04);
}
.continue__text {
  font-style: italic;
  color: var(--mirror);
  max-width: 42ch;
  margin: 0;
}

/* ---------- 19. Editorial patterns (v2) ---------- */

/* --- 19.1 Lead paragraph with dramatic drop cap --- */
.lead-intro {
  max-width: 56ch;
  margin-inline: auto;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
  line-height: 1.55;
  color: var(--ink-on-dark);
  padding: var(--space-6) 0;
  position: relative;
}
.lead-intro::first-letter {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 900;
  font-style: italic;
  font-size: 6.5em;
  float: left;
  line-height: 0.82;
  padding: 0.04em 0.14em 0 0;
  color: var(--terracotta);
  text-shadow: 2px 2px 0 rgba(232, 163, 61, 0.25);
}
.lead-intro em {
  font-style: italic;
  color: var(--saffron);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 600;
}
.lead-intro strong {
  font-weight: 600;
  color: var(--mirror);
  font-style: normal;
  background: linear-gradient(transparent 78%, rgba(232, 163, 61, 0.3) 78%);
}

/* --- 19.2 Asymmetric mosaic (1 large + 3 small) --- */
.mosaic {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  grid-template-rows: repeat(3, 1fr);
  gap: var(--space-4);
  aspect-ratio: 8 / 5;
  max-width: 1100px;
  margin-inline: auto;
}
.mosaic__tile {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid rgba(232, 163, 61, 0.25);
  background: var(--ink-indigo);
  transition: transform 420ms var(--ease-out), border-color 420ms;
  text-decoration: none;
  display: block;
}
.mosaic__tile:hover {
  transform: translateY(-4px);
  border-color: var(--saffron);
}
.mosaic__tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.mosaic__tile--main { grid-row: span 3; }
.mosaic__tile::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(19,28,48,0.88) 100%);
  z-index: 1;
}
.mosaic__caption {
  position: absolute;
  left: var(--space-5); bottom: var(--space-5); right: var(--space-5);
  z-index: 2;
  color: var(--mirror);
  pointer-events: none;
}
.mosaic__caption-num {
  display: inline-block;
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.74rem;
  letter-spacing: 0.32em;
  color: var(--saffron);
  margin-bottom: var(--space-2);
}
.mosaic__caption-title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-style: italic;
  font-size: clamp(1.2rem, 2.2vw, 1.7rem);
  line-height: 1.04;
  margin: 0;
  text-shadow: 0 2px 8px rgba(0,0,0,0.65);
}
.mosaic__tile--main .mosaic__caption-title { font-size: clamp(1.6rem, 3vw, 2.4rem); }
.mosaic__corner {
  position: absolute;
  top: 14px; right: 14px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--mirror-shine), var(--saffron) 50%, var(--terracotta) 100%);
  box-shadow: inset 0 0 0 2px rgba(30,45,74,.6), 0 0 0 1px rgba(232,163,61,.4);
  z-index: 2;
}
@media (max-width: 780px) {
  .mosaic {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    aspect-ratio: auto;
  }
  .mosaic__tile { aspect-ratio: 4 / 3; }
  .mosaic__tile--main { grid-column: span 2; grid-row: span 1; aspect-ratio: 16 / 9; }
}

/* --- 19.3 Feature pull-quote --- */
.feature-quote {
  max-width: 900px;
  margin: var(--space-9) auto var(--space-8);
  text-align: center;
  padding: var(--space-8) var(--space-6) var(--space-7);
  position: relative;
}
.feature-quote::before {
  content: "\201C";
  position: absolute;
  top: -32px; left: 50%;
  transform: translateX(-50%);
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 900;
  font-style: italic;
  font-size: clamp(7rem, 14vw, 11rem);
  line-height: 1;
  color: var(--saffron);
  opacity: 0.38;
}
.feature-quote__text {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 500;
  font-style: italic;
  font-size: clamp(1.5rem, 3.2vw, 2.4rem);
  line-height: 1.28;
  color: var(--mirror);
  margin: 0 0 var(--space-5);
  letter-spacing: -0.005em;
}
.feature-quote__text em {
  color: var(--saffron);
  font-style: italic;
}
.feature-quote__cite {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.8rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--saffron);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.feature-quote__cite::before,
.feature-quote__cite::after {
  content: "";
  width: 28px; height: 1px;
  background: currentColor;
  opacity: 0.6;
}

/* --- 19.4 Watermark numeral behind a section --- */
.prose-section { position: relative; }
.watermark-num {
  position: absolute;
  top: 10px;
  right: 4%;
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 900;
  font-style: italic;
  font-size: clamp(10rem, 22vw, 22rem);
  line-height: 0.8;
  color: var(--terracotta);
  opacity: 0.065;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.prose-section__inner { position: relative; z-index: 1; }

/* --- 19.5 CTA band (simplified teaser) --- */
.cta-band {
  margin-top: var(--space-9);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  border-top: 1px solid rgba(232,163,61,0.3);
  border-bottom: 1px solid rgba(232,163,61,0.3);
  background:
    radial-gradient(circle at 50% 30%, rgba(232,163,61,0.1), transparent 55%),
    linear-gradient(180deg, transparent, rgba(200,75,49,0.04));
  position: relative;
}
.cta-band__title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  line-height: 1.05;
  color: var(--mirror);
  max-width: 20ch;
  margin: var(--space-3) auto var(--space-4);
}
.cta-band__title em {
  font-style: italic;
  color: var(--saffron);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 700;
}
.cta-band__text {
  color: var(--ink-on-dark-muted);
  font-size: 1.08rem;
  font-style: italic;
  max-width: 46ch;
  margin: 0 auto var(--space-6);
}

/* --- 19.6 Refined hero tweaks --- */
.hero__title {
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 800;
}
.hero__visual svg { overflow: visible; }
/* Subtle continuous "breath" on the dancer */
@keyframes heroBreath {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-4px) scale(1.005); }
}
.hero__visual > img,
.hero__visual > svg {
  animation: floatIn 1.4s var(--ease-out) 0.2s both, heroBreath 8s var(--ease-in-out) 2s infinite;
}

/* --- 19.7 Polished section head --- */
.section-head .display {
  font-size: var(--fs-h2);
}

/* --- 19.8 Page hero bg diamond pattern: softer --- */
.page-hero { padding-bottom: var(--space-8); }
.page-hero__bg { opacity: 0.08; }
.page-hero__title {
  letter-spacing: -0.025em;
}

/* --- 19.9 Prose section tighter & more editorial --- */
.prose-section {
  padding: clamp(var(--space-8), 12vw, var(--space-10)) 0;
}
.prose-section__body h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.02em;
}
.prose-section__body p {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  max-width: 62ch;
}

/* --- 19.10 Card corner mirror dot --- */
.stitch, .article-card {
  position: relative;
}
.stitch::before {
  content: "";
  position: absolute;
  top: 10px; right: 10px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--mirror-shine), var(--saffron) 70%);
  opacity: 0.8;
}

/* --- 19.11 Stitch divider draws wider on landing --- */
.stitch-divider--wide { margin: var(--space-8) auto; max-width: 560px; }

/* --- 19.12 Inline CTA after lead paragraph --- */
.lead-cta {
  text-align: center;
  margin-top: var(--space-7);
  margin-bottom: var(--space-5);
}

/* --- 19.13 Makers' Shelf (product cards) --- */
.section-head__sub {
  color: var(--ink-on-dark-muted);
  font-style: italic;
  font-size: 1.05rem;
  max-width: 52ch;
  margin: var(--space-3) auto 0;
  line-height: 1.55;
}
.shelf {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-7);
}
.shelf__item {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(232, 163, 61, 0.24);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: linear-gradient(180deg, rgba(244, 234, 213, 0.03), rgba(232, 163, 61, 0.015));
  transition: transform 320ms var(--ease-out), border-color 320ms, box-shadow 320ms;
  position: relative;
}
.shelf__item:hover {
  transform: translateY(-4px);
  border-color: var(--saffron);
  box-shadow: 0 18px 30px -18px rgba(0, 0, 0, 0.6);
}
.shelf__media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--ink-indigo);
  overflow: hidden;
  border-bottom: 1px solid rgba(232, 163, 61, 0.18);
}
.shelf__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-out);
}
.shelf__item:hover .shelf__media img { transform: scale(1.05); }
.shelf__mirror {
  position: absolute;
  top: 10px; left: 10px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--mirror-shine), var(--saffron) 55%, var(--terracotta) 100%);
  box-shadow: inset 0 0 0 2px rgba(30,45,74,.55), 0 0 0 1px rgba(232,163,61,.5);
  z-index: 2;
}
.shelf__body {
  padding: var(--space-5) var(--space-5) var(--space-4);
  display: grid;
  gap: var(--space-2);
}
.shelf__tag {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 500;
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--saffron);
}
.shelf__title {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 700;
  font-style: italic;
  font-size: 1.45rem;
  line-height: 1.08;
  color: var(--mirror);
  margin: 0;
}
.shelf__desc {
  color: var(--ink-on-dark-muted);
  font-size: 0.96rem;
  line-height: 1.5;
  margin: 0;
}
.shelf__foot {
  margin-top: auto;
  padding: 0 var(--space-5) var(--space-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}
.shelf__price {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 60, "opsz" 144, "wght" 600;
  font-size: 1.05rem;
  color: var(--mirror);
}
.shelf__price em {
  color: var(--ink-on-dark-muted);
  font-style: italic;
  font-size: 0.78rem;
  font-weight: 400;
  margin-left: 2px;
}
.shelf__cta {
  font-family: "Fraunces", serif;
  font-variation-settings: "SOFT" 20, "opsz" 20, "wght" 600;
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--saffron);
  text-decoration: none;
  padding: 6px 14px;
  border: 1px solid rgba(232, 163, 61, 0.45);
  border-radius: 999px;
  transition: background 220ms var(--ease-out), color 220ms, border-color 220ms, transform 220ms;
  white-space: nowrap;
}
.shelf__cta:hover {
  background: var(--saffron);
  color: var(--ink-indigo);
  border-color: var(--saffron);
  transform: translateX(3px);
}

@media (max-width: 1024px) {
  .shelf { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .shelf { grid-template-columns: 1fr; gap: var(--space-4); }
  .shelf__title { font-size: 1.3rem; }
}

/* --- 19.14 Disclosure note under shelf --- */
.shelf-note {
  text-align: center;
  max-width: 56ch;
  margin: var(--space-6) auto 0;
  font-size: 0.92rem;
  color: var(--ink-on-dark-muted);
  font-style: italic;
  padding-top: var(--space-4);
  border-top: 1px dashed rgba(232, 163, 61, 0.25);
}
.shelf-note strong { color: var(--saffron); font-weight: 500; font-style: normal; letter-spacing: 0.08em; text-transform: uppercase; font-size: 0.76rem; margin-right: 6px;}
