/* memoir.html + memoir-lesen.html — Iskandar's memoirs.
 * Layered on top of styles.css + qisas.css (+ lesen.css for reader sub-page).
 * Inherits design tokens — see design.md for canon. */

.memoir-body {
  background: var(--c-cream);
}

/* ---------------- HERO ---------------- */
.memoir-cover-fig {
  aspect-ratio: 3/4;
  max-width: 22rem;
  margin: 0;
}
.memoir-cover-fig .qisas-cover-img {
  object-fit: cover;
  filter: sepia(.06) contrast(1.04) brightness(.97);
}

.memoir-body .qisas-hero-title {
  font-family: var(--serif-de);
  font-weight: 300;
  font-size: clamp(2rem, 1.4rem + 3.4vw, 3.4rem);
  line-height: 1.18;
  margin: 0 0 1.2rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  align-items: center;
  text-align: center;
}
.memoir-body .qisas-hero-title .t-de em {
  color: var(--c-clay);
  font-style: italic;
  font-weight: 400;
}
.memoir-body .qisas-hero-title .t-ar {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: clamp(1.9rem, 1.4rem + 3vw, 3.2rem);
  line-height: 1.4;
  color: var(--c-clay);
}
html[data-mode="ar"] .memoir-body .qisas-hero-title .t-ar {
  color: var(--c-ink);
}

.memoir-body .qisas-hero-eyebrow {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  align-items: center;
  font-family: var(--sans-ui);
  font-size: .82rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--c-eyebrow);
  margin-bottom: 1rem;
}
.memoir-body .qisas-hero-eyebrow .t-ar {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--c-clay);
}

.memoir-body .qisas-hero-sub {
  font-family: var(--serif-de);
  font-style: italic;
  font-size: clamp(1rem, .9rem + .5vw, 1.25rem);
  color: var(--c-ink-2);
  margin: 0 0 .5rem;
  line-height: 1.7;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  align-items: center;
  text-align: center;
}
.memoir-body .qisas-hero-sub .t-ar {
  font-family: var(--serif-ar);
  font-style: normal;
  font-weight: 400;
}

.memoir-body .qisas-hero-meta {
  font-family: var(--sans-ui);
  font-size: .76rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin: 0 0 1.4rem;
  text-align: center;
}

.memoir-body .qisas-hero-note {
  font-size: clamp(.95rem, .9rem + .25vw, 1.05rem);
  line-height: 1.85;
  color: var(--c-ink-2);
  max-width: 38rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: .8rem;
  text-align: center;
}
.memoir-body .qisas-hero-note .t-de {
  font-family: var(--serif-de);
  font-weight: 300;
}
.memoir-body .qisas-hero-note .t-ar {
  font-family: var(--serif-ar);
}

.memoir-body .qisas-hero-text {
  text-align: center;
}

/* ---------------- ABOUT ---------------- */
.memoir-body .qisas-about .about-portrait img {
  filter: sepia(.04) contrast(1.04);
}

/* ---------------- PREFACE ---------------- */
.memoir-body .qisas-preface {
  padding: clamp(3rem, 6vw, 5rem) var(--gutter);
  background: linear-gradient(180deg, var(--c-cream) 0%, var(--c-paper) 100%);
}
:root[data-theme="dark"] .memoir-body .qisas-preface {
  background: linear-gradient(180deg, var(--c-cream) 0%, #15110B 100%);
}
.memoir-body .qisas-preface-inner {
  max-width: 56rem;
  margin: 0 auto;
}
.memoir-preface-body {
  margin-top: 2rem;
  font-size: clamp(1.05rem, .98rem + .25vw, 1.18rem);
  line-height: 1.85;
  color: var(--c-ink);
}
.memoir-preface-body .preface-de {
  font-family: var(--serif-de);
  font-weight: 300;
}
.memoir-preface-body .preface-ar {
  font-family: var(--serif-ar);
  line-height: 2.05;
  direction: rtl;
}
.memoir-preface-body p {
  margin: 0 0 1.2rem;
}
.memoir-preface-body .preface-de p,
.memoir-preface-body .preface-en p {
  text-align: left;
  hyphens: auto;
}
.memoir-preface-body .preface-ar p {
  text-align: justify;
  text-justify: inter-word;
}
.memoir-preface-body .preface-de p:first-of-type::first-letter {
  font-size: 2.4em;
  float: left;
  line-height: 1;
  margin: .1em .25em 0 0;
  color: var(--c-clay);
  font-weight: 700;
}
html[data-mode="both"] .memoir-preface-body {
  display: grid;
  gap: 2.5rem;
}
html[data-mode="both"] .memoir-preface-body .preface-de {
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(139, 90, 43, .15);
}

/* ---------------- TOC (chapter list w/ synopses) ---------------- */
.memoir-toc {
  padding: clamp(3rem, 5vw, 4rem) var(--gutter);
}
.memoir-toc-list {
  max-width: 56rem;
  margin: 0 auto;
  list-style: none;
  padding: 0;
  display: grid;
  gap: 1rem;
}
.memoir-toc-list li {
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--rad);
  transition: border-color .18s var(--ease-premium),
              box-shadow .18s var(--ease-premium),
              transform .18s var(--ease-premium);
  overflow: hidden;
}
.memoir-toc-list li:hover {
  border-color: var(--c-clay);
  box-shadow: 0 12px 26px -16px rgba(60, 40, 15, .25);
  transform: translateY(-2px);
}

.memoir-toc-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.4rem;
  padding: 1.6rem 1.8rem;
}
.memoir-toc-card.has-cover {
  grid-template-columns: 9rem auto 1fr;
  gap: 1.6rem;
}
.memoir-toc-cover {
  margin: 0;
  width: 9rem;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 4px;
  box-shadow: 0 8px 18px -10px rgba(60, 40, 15, .35);
  background: var(--c-paper);
}
.memoir-toc-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: sepia(.08) contrast(1.04) brightness(.96);
  transition: filter .5s var(--ease-premium, ease), transform .6s var(--ease-premium, ease);
}
.memoir-toc-card:hover .memoir-toc-cover img {
  filter: sepia(0) contrast(1.05) brightness(1.0);
  transform: scale(1.04);
}
@media (max-width: 760px) {
  .memoir-toc-card { grid-template-columns: 1fr; gap: .8rem; padding: 1.3rem 1.3rem; }
  .memoir-toc-card.has-cover { grid-template-columns: 1fr; }
  .memoir-toc-cover { width: 100%; aspect-ratio: 16 / 7; }
}

.memoir-toc-num {
  font-family: var(--serif-de);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(2.6rem, 2rem + 2vw, 3.4rem);
  color: var(--c-clay);
  opacity: .75;
  line-height: 1;
  align-self: start;
}

.memoir-toc-titles {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  margin-bottom: .8rem;
}
.memoir-toc-title-de {
  font-family: var(--serif-de);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.25rem, 1.1rem + .5vw, 1.5rem);
  color: var(--c-ink);
  line-height: 1.3;
}
.memoir-toc-title-ar {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1.5;
  color: var(--c-clay);
  direction: rtl;
}
html[data-mode="ar"] .memoir-toc-title-ar {
  color: var(--c-ink);
  font-size: 1.4rem;
}

.memoir-toc-synopsis {
  font-size: clamp(.95rem, .9rem + .15vw, 1.05rem);
  line-height: 1.65;
  color: var(--c-ink-2);
  margin: .4rem 0 1rem;
}
.memoir-toc-synopsis-de {
  font-family: var(--serif-de);
  font-weight: 300;
}
.memoir-toc-synopsis-ar {
  font-family: var(--serif-ar);
  line-height: 1.95;
  direction: rtl;
  text-align: right;
}
html[data-mode="both"] .memoir-toc-synopsis-de {
  margin-bottom: .8rem;
  padding-bottom: .8rem;
  border-bottom: 1px dashed rgba(139, 90, 43, .2);
}

.memoir-toc-cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--sans-ui);
  font-size: .82rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--c-clay);
  text-decoration: none;
  padding: .6rem 1.2rem;
  border: 1px solid rgba(139, 90, 43, .35);
  border-radius: 999px;
  transition: background .18s var(--ease-premium),
              color .18s var(--ease-premium),
              border-color .18s var(--ease-premium);
  align-self: flex-start;
  margin-top: .4rem;
}
.memoir-toc-cta:hover,
.memoir-toc-cta:focus-visible {
  background: var(--c-clay);
  color: var(--c-cream);
  border-color: var(--c-clay);
}
.memoir-toc-cta-arrow {
  transition: transform .18s var(--ease-premium);
}
.memoir-toc-cta:hover .memoir-toc-cta-arrow {
  transform: translateX(3px);
}
html[data-mode="ar"] .memoir-toc-cta-arrow {
  transform: scaleX(-1);
}
html[data-mode="ar"] .memoir-toc-cta:hover .memoir-toc-cta-arrow {
  transform: scaleX(-1) translateX(3px);
}

/* ---------------- HERO — instant render (no entrance cascade) ---------------- */

@media (prefers-reduced-motion: reduce) {
  .memoir-body .memoir-cover-fig,
  .memoir-body .qisas-hero-eyebrow,
  .memoir-body .qisas-hero-title,
  .memoir-body .qisas-hero-sub,
  .memoir-body .qisas-hero-meta,
  .memoir-body .qisas-hero-note {
    opacity: 1;
    animation: none;
  }
}

/* ---------------- LANG-MODE VISIBILITY ---------------- */
html[data-mode="de"] .memoir-body .t-ar { display: none !important; }
html[data-mode="ar"] .memoir-body .t-de { display: none !important; }

/* ---------------- BIDI RESET + LEFT-ALIGN FOR DE/EN ----------------
   body.dir="rtl" leaks from AR mode (script.js doesn't reset on switch).
   Without this, Versalien (uppercase tagline) end up on the wrong side
   and the hero appears mirrored. AR mode keeps natural RTL. */
html[data-mode="de"] .memoir-body,
html[data-mode="en"] .memoir-body,
html[data-mode="de"] .memoir-body .qisas-hero,
html[data-mode="en"] .memoir-body .qisas-hero,
html[data-mode="de"] .memoir-body .qisas-hero-inner,
html[data-mode="en"] .memoir-body .qisas-hero-inner,
html[data-mode="de"] .memoir-body .qisas-hero-text,
html[data-mode="en"] .memoir-body .qisas-hero-text { direction: ltr; }

/* Switch hero from centered to left-aligned in DE/EN (per Ray's request).
   Title flex column starts at left edge; meta/sub/note follow suit. */
html[data-mode="de"] .memoir-body .qisas-hero-text,
html[data-mode="en"] .memoir-body .qisas-hero-text { text-align: left; }
html[data-mode="de"] .memoir-body .qisas-hero-eyebrow,
html[data-mode="en"] .memoir-body .qisas-hero-eyebrow,
html[data-mode="de"] .memoir-body .qisas-hero-title,
html[data-mode="en"] .memoir-body .qisas-hero-title,
html[data-mode="de"] .memoir-body .qisas-hero-sub,
html[data-mode="en"] .memoir-body .qisas-hero-sub {
  align-items: flex-start;
  text-align: left;
}
html[data-mode="de"] .memoir-body .qisas-hero-meta,
html[data-mode="en"] .memoir-body .qisas-hero-meta,
html[data-mode="de"] .memoir-body .qisas-hero-note,
html[data-mode="en"] .memoir-body .qisas-hero-note { text-align: left; }
html[data-mode="de"] .memoir-body .qisas-hero-note,
html[data-mode="en"] .memoir-body .qisas-hero-note { margin: 0 auto 0 0; }

/* Pending DE notice (when translation not yet available) */
.memoir-de-pending {
  max-width: 36rem;
  margin: 1.5rem auto 2.5rem;
  padding: 1rem 1.4rem;
  background: rgba(201, 166, 107, .12);
  border: 1px dashed rgba(139, 90, 43, .35);
  border-radius: var(--rad);
  color: var(--c-ink-2);
  font-family: var(--serif-de);
  font-size: 1rem;
  line-height: 1.6;
  text-align: center;
}

/* Both-mode reader: stack DE on top, AR below, with separator */
html[data-mode="both"] .memoir-lesen-body .lesen-body--de {
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  border-bottom: 1px dashed rgba(139, 90, 43, .25);
}
html[data-mode="both"] .memoir-lesen-body .lesen-body--de:empty,
html[data-mode="both"] .memoir-lesen-body .lesen-body--de:not(:has(p)):not(:has(h3)):not(:has(h4)) {
  display: none;
}

/* DE body styling */
.lesen-body--de {
  font-family: var(--serif-de);
  font-weight: 300;
  line-height: 1.75;
  font-size: clamp(1.08rem, 1rem + .3vw, 1.22rem);
  color: var(--c-ink);
  direction: ltr;
}
.lesen-body--de p,
.lesen-body--en p {
  margin: 0 0 1.2rem;
  text-align: left;
  hyphens: auto;
}
.lesen-body--de h3 {
  font-family: var(--serif-de);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.3rem, 1.1rem + .6vw, 1.55rem);
  color: var(--c-clay);
  margin: 2.2rem 0 1rem;
  text-align: left;
}
.lesen-body--de h4 {
  font-family: var(--serif-de);
  font-weight: 600;
  font-size: 1.15rem;
  color: var(--c-ink);
  margin: 1.8rem 0 .8rem;
}
.lesen-body--de p:first-of-type::first-letter {
  font-size: 3em;
  float: left;
  line-height: .9;
  margin: .12em .3em .05em 0;
  color: var(--c-clay);
  font-weight: 700;
}

/* Lang toggle stays right in every mode (user requirement) */

/* ---------------- READER SUB-PAGE (memoir-lesen.html) ---------------- */
.memoir-lesen-body {
  background: var(--c-cream);
}

/* The chapter article — direction follows the active language mode.
   Previous rule forced RTL globally → German text rendered spiegelverkehrt. */
.memoir-lesen-body .lesen-article { direction: ltr; }
html[data-mode="ar"] .memoir-lesen-body .lesen-article { direction: rtl; }
/* AR-specific children always render RTL regardless of mode (titles, AR body) */
.memoir-lesen-body .lesen-article .t-ar,
.memoir-lesen-body .lesen-title-ar,
.memoir-lesen-body .lesen-body--ar { direction: rtl; }
.memoir-lesen-body .lesen-title-ar {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: clamp(2rem, 1.5rem + 2vw, 2.8rem);
  line-height: 1.4;
  margin: 0 0 .5rem;
  color: var(--c-ink);
  text-align: center;
}
/* Hero-Plate-Override: warm-gold instead of dark ink so the title reads
   against the dark photo + dark plate. Needs higher specificity than the
   plain .memoir-lesen-body .lesen-title-ar rule above. */
.memoir-lesen-body .lesen-head--on-hero .lesen-title-ar {
  color: #F5D896;
  font-weight: 700;
  text-shadow: 0 1px 2px rgba(0,0,0,.55);
}
.memoir-lesen-body .lesen-head--on-hero .lesen-title-de {
  color: #FFF4DE;
  font-style: italic;
  text-shadow: 0 1px 2px rgba(0,0,0,.55);
}
.memoir-lesen-body .lesen-title-de {
  font-family: var(--serif-de);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.2rem, 1rem + .8vw, 1.55rem);
  color: var(--c-ink-2);
  text-align: center;
  margin: 0 0 .4rem;
}
.memoir-lesen-body .lesen-meta {
  text-align: center;
  margin: 1.2rem 0 0;
  font-family: var(--sans-ui);
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-muted);
}
.memoir-lesen-body .lesen-eyebrow {
  font-family: var(--sans-ui);
  font-size: .76rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin: 0 0 1.5rem;
  text-align: center;
}
.memoir-lesen-body .lesen-eyebrow a {
  color: var(--c-clay);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .2s;
}
.memoir-lesen-body .lesen-eyebrow a:hover {
  border-bottom-color: var(--c-clay);
}

.memoir-lesen-body .lesen-body {
  margin-top: 2.5rem;
  font-size: clamp(1.08rem, 1rem + .3vw, 1.22rem);
  line-height: 2.05;
  color: var(--c-ink);
}
/* DE/EN body — Cormorant LTR, left-aligned (no justify rivers) */
.memoir-lesen-body .lesen-body--de,
.memoir-lesen-body .lesen-body--en {
  font-family: var(--serif-de);
  direction: ltr;
  text-align: left;
}
.memoir-lesen-body .lesen-body--de p,
.memoir-lesen-body .lesen-body--en p {
  margin: 0 0 1.2rem;
  text-align: left;
  hyphens: auto;
}
/* AR body — Amiri RTL, justified inter-word (Arabic justify is well-behaved).
   Stronger weight + full ink color for readability on both light and dark mode
   (Amiri at default 400 can read too thin/shadowy on cream backgrounds). */
.memoir-lesen-body .lesen-body--ar {
  font-family: var(--serif-ar);
  font-weight: 500;
  color: var(--c-ink);
  direction: rtl;
  text-align: right;
}
.memoir-lesen-body .lesen-body--ar p {
  margin: 0 0 1.2rem;
  text-align: justify;
  text-justify: inter-word;
  color: var(--c-ink);
}
/* Dark mode: ensure full luminance — explicit override for AR body */
:root[data-theme="dark"] .memoir-lesen-body .lesen-body--ar,
:root[data-theme="dark"] .memoir-lesen-body .lesen-body--ar p {
  color: #F5ECD8;
}
.memoir-lesen-body .lesen-body h3 {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: clamp(1.3rem, 1.1rem + .6vw, 1.55rem);
  color: var(--c-clay);
  margin: 2.2rem 0 1rem;
  text-align: right;
}
.memoir-lesen-body .lesen-body h4 {
  font-family: var(--serif-ar);
  font-weight: 700;
  font-size: 1.18rem;
  color: var(--c-ink);
  margin: 1.8rem 0 .9rem;
}
/* Drop-cap — only the AR body gets the right-floated Amiri cap.
   DE/EN bodies use a left-floated Cormorant cap (lesen.css owns the rule).
   Previously this rule applied to ALL .lesen-body paragraphs, leaving the
   AR drop-cap floated right inside German text → "I" stranded on the right. */
.memoir-lesen-body .lesen-body--ar p:first-of-type::first-letter {
  font-family: var(--serif-ar);
  font-size: 3em;
  float: right;
  line-height: .9;
  margin: .12em 0 .05em .3em;
  color: var(--c-clay);
  font-weight: 700;
}
.memoir-lesen-body .lesen-body--de p:first-of-type::first-letter,
.memoir-lesen-body .lesen-body--en p:first-of-type::first-letter {
  font-family: var(--serif-de);
  font-size: 3em;
  float: left;
  line-height: .9;
  margin: .08em .22em -.05em 0;
  color: var(--c-clay);
  font-weight: 700;
}

/* RTL bottom navigation (back arrow flipped, prev/next swapped visually via flex) */
.memoir-lesen-body .lesen-nav-prev .lesen-nav-arrow,
.memoir-lesen-body .lesen-nav-next .lesen-nav-arrow {
  display: inline-block;
}
.memoir-lesen-body .lesen-nav-arrow {
  transform: scaleX(-1);
}

/* RTL fixes for back button (skip link uses clip-path globally — kein Override noetig).
   Frueheres .skip { right: -100vw } verursachte horizontalen Overflow auf DE-Mode. */
.memoir-lesen-body .back-to-library {
  left: auto;
  right: clamp(1rem, 3vw, 2rem);
}
.memoir-lesen-body .back-arrow {
  display: inline-block;
  transform: scaleX(-1);
}
