/* ============================================================
   Page-specific bits — hero compositions, archive layouts,
   article body, contact page. All consume tokens + components.
   ============================================================ */

/* ─── Hero ───────────────────────────────────────────── */
.hero {
  position: relative;
  padding-block: var(--sp-6) var(--sp-7);
  overflow: hidden;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  align-items: end;
}
@media (min-width: 900px) {
  .hero__grid {
    grid-template-columns: 1.1fr 0.9fr;
    align-items: center;
    gap: var(--sp-5);
  }
}
.hero__title {
  font-size: var(--fs-4xl);
  line-height: 0.92;
  letter-spacing: -0.035em;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 800;
}
.hero__title .em {
  font-style: italic;
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 500;
  color: var(--pe-pink-dark);
}
.hero__title .stamp {
  display: inline-block;
  background: var(--pe-mustard);
  padding: 0.05em 0.25em;
  border-radius: 0.18em;
  transform: rotate(-2deg);
  border: 2px solid var(--pe-ink);
  margin-inline: 0.05em;
}
.hero__lede {
  max-width: 38ch;
  font-family: var(--ff-display);
  font-variation-settings: "SOFT" 100, "wght" 400;
  font-size: var(--fs-lg);
  line-height: 1.35;
  color: var(--fg-soft);
  margin-block: var(--sp-3) var(--sp-4);
}
.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}
.hero__art {
  position: relative;
  isolation: isolate;
}
/* off-register backdrop block */
.hero__art::before {
  content: "";
  position: absolute;
  inset: 8% -4% -4% 8%;
  background: var(--pe-mint);
  border-radius: var(--r-lg);
  z-index: -1;
  border: 2px solid var(--pe-ink);
}
.hero__art::after {
  content: "";
  position: absolute;
  inset: -3% 12% 12% -3%;
  background: var(--pe-pink-tint);
  border-radius: var(--r-lg);
  z-index: -2;
  border: 2px solid var(--pe-ink);
}
.hero__art img {
  width: 100%;
  border-radius: var(--r-lg);
  border: 2px solid var(--pe-ink);
  box-shadow: var(--shadow-deep);
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: var(--pe-paper);
}

/* the playful illustrated hero — used on the home page */
.hero__illo {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  border: 2px solid var(--pe-ink);
  background: var(--pe-mint);
  box-shadow: var(--shadow-deep);
  overflow: hidden;
}
.hero__illo svg { width: 100%; height: 100%; display: block; }
.hero__illo .hero__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  mix-blend-mode: multiply;
  opacity: 0.9;
}

.hero__ribbon {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  margin-bottom: var(--sp-3);
}

/* ─── Section heading ────────────────────────────────── */
.sec-head {
  display: grid;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
  max-width: 60ch;
}
.sec-head__title {
  font-size: var(--fs-2xl);
  letter-spacing: -0.025em;
}
.sec-head__sub {
  color: var(--fg-soft);
  font-family: var(--ff-display);
  font-variation-settings: "SOFT" 100, "wght" 400;
  font-size: var(--fs-md);
}

.sec-head--side {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

/* ─── Termine list ───────────────────────────────────── */
.termine-list {
  display: grid;
  gap: var(--sp-2);
}
@media (min-width: 700px) {
  .termine-list { gap: var(--sp-2); }
}

.tabs {
  display: inline-flex;
  padding: 4px;
  border: 2px solid var(--pe-ink);
  border-radius: var(--r-pill);
  background: var(--pe-paper);
  margin-bottom: var(--sp-3);
  box-shadow: 0 2px 0 var(--pe-ink);
}
.tabs__btn {
  padding: 0.55em 1.2em;
  border: none;
  background: transparent;
  font-family: var(--ff-body);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  color: var(--fg-soft);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-soft),
              color var(--dur-fast) var(--ease-soft);
}
.tabs__btn[aria-selected="true"] {
  background: var(--pe-ink);
  color: var(--pe-paper);
}

/* ─── Production detail ──────────────────────────────── */
.prod-detail {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .prod-detail {
    grid-template-columns: 1fr 1.4fr;
    gap: var(--sp-6);
  }
}
.prod-detail__cover {
  position: relative;
  isolation: isolate;
}
.prod-detail__cover::before {
  content: "";
  position: absolute;
  inset: 6% -8% -8% 6%;
  background: var(--pe-mustard);
  border-radius: var(--r-md);
  z-index: -1;
  border: 2px solid var(--pe-ink);
}
.prod-detail__cover img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--r-md);
  border: 2px solid var(--pe-ink);
  box-shadow: var(--shadow-deep);
  background: var(--pe-paper);
}

.prose {
  font-size: var(--fs-md);
  line-height: 1.65;
  max-width: 60ch;
}
.prose p { margin-block: 1em; }
.prose h2 { font-size: var(--fs-xl); margin-block: 1.6em 0.5em; }
.prose h3 { font-size: var(--fs-lg); margin-block: 1.4em 0.4em; }
.prose strong { color: var(--pe-pink-dark); font-weight: 700; }
.prose blockquote {
  margin: 1.6em 0;
  padding: 1em 1.2em;
  border-left: 4px solid var(--pe-mustard);
  background: var(--pe-mustard-tint);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-family: var(--ff-display);
  font-variation-settings: "SOFT" 100, "wght" 500;
  font-style: italic;
  color: var(--pe-ink);
}

/* ─── Pull-quote ─────────────────────────────────────── */
.pullquote {
  position: relative;
  padding: var(--sp-4) var(--sp-3);
  margin: var(--sp-5) auto;
  max-width: 26ch;
  text-align: center;
  font-family: var(--ff-display);
  font-variation-settings: "SOFT" 100, "wght" 600;
  font-size: var(--fs-2xl);
  line-height: 1.1;
  color: var(--pe-ink);
  letter-spacing: -0.02em;
}
.pullquote::before,
.pullquote::after {
  content: "“";
  position: absolute;
  font-family: var(--ff-display);
  font-size: 3em;
  color: var(--pe-pink-dark);
  line-height: 0.5;
}
.pullquote::before { top: 0; left: -0.2em; }
.pullquote::after  { content: "”"; bottom: 0.2em; right: -0.2em; }
.pullquote cite {
  display: block;
  margin-top: 0.6em;
  font-family: var(--ff-body);
  font-style: normal;
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pe-mustard-dark);
}

/* ─── Ensemble (about) page ──────────────────────────── */
.split {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 900px) {
  .split { grid-template-columns: 1fr 1fr; gap: var(--sp-6); }
}
.split--reverse > :first-child { order: 2; }
.split img {
  border-radius: var(--r-lg);
  border: 2px solid var(--pe-ink);
  box-shadow: var(--shadow-card);
  width: 100%;
}
@media (min-width: 900px) {
  .split--reverse > :first-child { order: 0; }
}

/* fact strip */
.facts {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
  margin-block: var(--sp-4);
}
@media (min-width: 700px)  { .facts { grid-template-columns: repeat(3, 1fr); } }
.fact {
  padding: var(--sp-3);
  border: 2px dashed var(--pe-ink);
  border-radius: var(--r-md);
  background: color-mix(in srgb, var(--pe-paper) 90%, transparent);
  text-align: center;
}
.fact__num {
  font-family: var(--ff-display);
  font-variation-settings: "SOFT" 100, "opsz" 144, "wght" 800;
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-size: var(--fs-3xl);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--pe-pink-dark);
}
.fact__label {
  font-size: var(--fs-sm);
  color: var(--fg-soft);
  margin-top: 0.3em;
}

/* ─── Contact form ───────────────────────────────────── */
.form-grid {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
}
@media (min-width: 700px) {
  .form-grid { grid-template-columns: 1fr 1fr; }
  .form-grid .full { grid-column: 1 / -1; }
}
.field {
  display: grid;
  gap: 0.4em;
}
.field label {
  font-family: var(--ff-body);
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fg-soft);
}
.field input,
.field textarea,
.field select {
  font: inherit;
  padding: 0.85em 1em;
  border: 2px solid var(--pe-ink);
  border-radius: var(--r-md);
  background: var(--pe-paper);
  color: var(--fg);
  box-shadow: 0 2px 0 var(--pe-ink);
  transition: border-color var(--dur-fast) var(--ease-soft),
              transform var(--dur-fast) var(--ease-soft);
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--pe-pink-dark);
  transform: translateY(-1px);
  box-shadow: 0 3px 0 var(--pe-pink-dark);
}
.field textarea { resize: vertical; min-height: 7em; }

/* ─── Page header (sub-page intro strip) ─────────────── */
.page-head {
  padding-block: var(--sp-6) var(--sp-5);
  display: grid;
  gap: var(--sp-3);
  position: relative;
}
.page-head__eyebrow { color: var(--pe-mustard-dark); }
.page-head__title { font-size: var(--fs-3xl); letter-spacing: -0.03em; }
.page-head__lede { max-width: 60ch; font-size: var(--fs-lg); color: var(--fg-soft); }

/* ─── A "spotlight" featured production strip ────────── */
.spotlight {
  display: grid;
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--pe-mint);
  border: 2px solid var(--pe-ink);
  border-radius: var(--r-lg);
  position: relative;
  box-shadow: var(--shadow-card);
}
@media (min-width: 900px) {
  .spotlight {
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: var(--sp-5);
  }
}
.spotlight__art {
  background: var(--pe-pink);
  border: 2px solid var(--pe-ink);
  border-radius: var(--r-md);
  aspect-ratio: 4 / 3;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.spotlight__art img { width: 100%; height: 100%; object-fit: cover; }
.spotlight__title { font-size: var(--fs-2xl); letter-spacing: -0.02em; margin-bottom: var(--sp-2); }
.spotlight__meta { font-size: var(--fs-sm); letter-spacing: 0.06em; text-transform: uppercase; color: var(--pe-ink-soft); }
