/* ───────────────────────────────────────────────────────────
   Dictionary of African Philosophy — project page styles.
   Builds on the global tokens in style.css.
─────────────────────────────────────────────────────────── */

/* ── Shared utilities ── */
.crumb { padding-top: clamp(1.8rem,3vw,2.6rem); padding-bottom: clamp(1.8rem,3vw,2.6rem); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-muted); }
.crumb a { color: var(--ink-muted); border-bottom: 1px solid transparent; transition: color var(--fast), border-color var(--fast); }
.crumb a:hover { color: var(--ink); border-color: var(--ink); }
.crumb span { color: var(--ink); }

/* ════════ COVER HERO (book object on a dark stage — no purchase info) ════════ */
.cv-hero { background: var(--ink); color: var(--bg); padding-top: clamp(2.5rem,5vw,4.2rem); padding-bottom: clamp(3rem,6vw,5rem); overflow: hidden; }
.cv-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2.5rem,6vw,5.5rem); align-items: center; }
.cv-hero .pill { display: inline-flex; align-items: center; gap: .6rem; font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); background: var(--accent); padding: .5rem 1rem; border-radius: 100px; margin-bottom: 1.6rem; }
/* ghost pill: subtle outline, no golden fill — the section's accent lives in the headline */
.cv-hero .pill.ghost { background: transparent; color: rgba(245,243,239,.7); border: 1px solid rgba(245,243,239,.28); }
.cv-hero h1 { font-family: var(--font-display); font-weight: 400; font-size: clamp(2.8rem,6vw,5.6rem); line-height: .96; letter-spacing: -.03em; color: var(--bg); }
.cv-hero h1 em { font-style: italic; color: var(--accent); }
.cv-hero .sub { font-size: 1.08rem; line-height: 1.75; color: rgba(245,243,239,.66); max-width: 48ch; margin-top: 1.4rem; }
.cv-hero .sub b { color: var(--bg); font-weight: 500; }
/* informative meta strip in place of the old purchase actions */
.cv-hero-meta { display: flex; flex-wrap: wrap; gap: clamp(1.4rem,4vw,3rem); margin-top: 2.2rem; padding-top: 1.7rem; border-top: 1px solid rgba(245,243,239,.18); }
.cv-hero-meta .m .k { font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(245,243,239,.5); margin-bottom: .4rem; }
.cv-hero-meta .m .v { font-family: var(--font-display); font-size: clamp(1.15rem,1.7vw,1.45rem); color: var(--bg); line-height: 1.12; }
.cv-cover-stage { position: relative; display: flex; justify-content: center; }
.cv-cover-stage .book { width: min(72%, 360px); aspect-ratio: 2/3; border-radius: 3px 6px 6px 3px; overflow: hidden; box-shadow: 0 50px 110px rgba(0,0,0,.6), -10px 0 0 rgba(255,255,255,.04); transform: rotateY(-10deg) rotateX(2deg); transform-origin: left center; }
.cv-cover-stage .book img, .cv-cover-stage .book .ph { width: 100%; height: 100%; object-fit: cover; }
.cv-cover-stage .glow { position: absolute; inset: -20% -10% -30% -10%; background: radial-gradient(60% 55% at 50% 45%, rgba(176,143,98,.22), transparent 70%); z-index: 0; }
.cv-cover-stage .book { position: relative; z-index: 1; }
@media (max-width: 820px) { .cv-hero-grid { grid-template-columns: 1fr; gap: 2.6rem; } .cv-cover-stage { order: -1; } .cv-cover-stage .book { transform: none; width: min(58%, 300px); } }

/* ════════ STAT BAND ════════ */
.cv-stats { border-bottom: 1px solid var(--rule); }
.cv-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.cv-stats .c { padding: clamp(1.6rem,3vw,2.4rem) clamp(1rem,2vw,1.6rem); border-right: 1px solid var(--rule); }
.cv-stats .c:last-child { border-right: none; }
.cv-stats .cv { font-family: var(--font-display); font-size: clamp(2.2rem,4vw,3.4rem); line-height: 1; color: var(--ink); }
.cv-stats .cl { font-size: .66rem; letter-spacing: .13em; text-transform: uppercase; color: var(--ink-muted); margin-top: .6rem; line-height: 1.45; }
@media (max-width: 640px) { .cv-stats-grid { grid-template-columns: 1fr 1fr; } .cv-stats .c:nth-child(2) { border-right: none; } .cv-stats .c:nth-child(-n+2) { border-bottom: 1px solid var(--rule); } }

/* ════════ LEDE / THE STORY ════════ */
.cv-lede { padding: clamp(3.5rem,7vw,6rem) 0; }
.cv-lede-grid { display: grid; grid-template-columns: .42fr 1.58fr; gap: clamp(2rem,5vw,5rem); }
.cv-lede .side { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.cv-lede .body p { font-size: 1.34rem; line-height: 1.6; font-family: var(--font-display); color: var(--ink); }
.cv-lede .body p + p { font-family: var(--font-body); font-size: 1.05rem; line-height: 1.85; color: var(--ink-mid); margin-top: 1.5rem; }
@media (max-width: 760px) { .cv-lede-grid { grid-template-columns: 1fr; gap: 1.25rem; } }

/* ════════ A–Z STRIP (dark) ════════ */
.lx-az { background: var(--ink); color: var(--bg); padding: clamp(2.2rem,4vw,3.2rem) 0; }
.lx-az .container { display: flex; align-items: center; gap: clamp(1.5rem,4vw,3rem); flex-wrap: wrap; }
.lx-az .lead { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(245,243,239,.55); flex: 0 0 auto; max-width: 12ch; line-height: 1.6; }
.lx-az .letters { display: flex; flex-wrap: wrap; gap: .25rem .55rem; flex: 1 1 auto; }
.lx-az .letters span { font-family: var(--font-display); font-size: clamp(1.1rem,2vw,1.7rem); color: rgba(245,243,239,.32); transition: color .3s var(--ease); line-height: 1; }
.lx-az .letters span.lit { color: var(--accent); }
.lx-az .count { flex: 0 0 auto; text-align: right; }
.lx-az .count .cv { font-family: var(--font-display); font-size: clamp(2.4rem,4vw,3.4rem); line-height: 1; color: var(--bg); }
.lx-az .count .cl { font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(245,243,239,.55); margin-top: .4rem; }
@media (max-width: 720px) { .lx-az .count { width: 100%; text-align: left; } }

/* ════════ ENTRY SPECIMENS ════════ */
.lx-spec { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.lx-spec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem 2rem; flex-wrap: wrap; margin-bottom: clamp(1.5rem,3vw,2.4rem); }
.lx-spec-head .label { color: var(--accent); }
.lx-spec-head .note { font-family: var(--font-display); font-style: italic; font-size: 1.15rem; color: var(--ink-muted); }
.lx-cols { columns: 2; column-gap: clamp(2.5rem, 5vw, 4.5rem); column-rule: 1px solid var(--rule); }
.lx-art { break-inside: avoid; padding-bottom: clamp(1.3rem,2.2vw,1.7rem); margin-bottom: clamp(1.3rem,2.2vw,1.7rem); border-bottom: 1px solid var(--rule); }
.lx-art .hw { display: flex; align-items: baseline; gap: .7rem; flex-wrap: wrap; }
.lx-art .hw h3 { font-family: var(--font-display); font-size: 1.7rem; line-height: 1; letter-spacing: -.01em; }
.lx-art .hw .pos { font-family: var(--font-display); font-style: italic; font-size: 1rem; color: var(--ink-muted); }
.lx-art .hw .pg { margin-left: auto; font-family: ui-monospace, Menlo, monospace; font-size: .68rem; color: var(--accent); letter-spacing: .04em; }
.lx-art .gloss { font-size: .98rem; line-height: 1.7; color: var(--ink-mid); margin-top: .6rem; }
.lx-art .gloss b { color: var(--ink); font-weight: 500; }
.lx-art .xref { font-size: .76rem; letter-spacing: .04em; color: var(--ink-muted); margin-top: .7rem; font-style: italic; font-family: var(--font-display); }
.lx-art .xref em { color: var(--accent); font-style: italic; }
@media (max-width: 720px) { .lx-cols { columns: 1; } }

/* ════════ THESIS QUOTE ════════ */
.lx-thesis { padding: clamp(4rem, 8vw, 7rem) 0; }
.lx-thesis blockquote { font-family: var(--font-display); font-style: italic; font-weight: 300; font-size: clamp(1.9rem, 4vw, 3.2rem); line-height: 1.28; max-width: 28ch; margin: 0; color: var(--ink); }
.lx-thesis blockquote em { color: var(--accent); font-style: italic; }
.lx-thesis .src { margin-top: 1.75rem; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-muted); }

/* ════════ THE BOOK (colophon) ════════ */
.da-book { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.da-book-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2.5rem, 6vw, 5.5rem); align-items: center; }
.da-book-cover { position: relative; }
.da-book-cover .frame { aspect-ratio: 2/3; overflow: hidden; border-radius: 3px; background: #e7ded1; box-shadow: 0 40px 90px rgba(20,18,14,.28); }
.da-book-cover .frame img, .da-book-cover .frame .ph { width: 100%; height: 100%; object-fit: cover; }
.da-book .lbl { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.1rem; }
.da-book h2 { font-size: clamp(2rem, 3.6vw, 3.2rem); line-height: 1.05; margin-bottom: 1.1rem; }
.da-book h2 em { font-style: italic; color: var(--ink-mid); }
.da-book .intro { color: var(--ink-mid); font-size: 1.05rem; line-height: 1.8; max-width: 50ch; margin-bottom: 2rem; }
.da-spec { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--rule); }
.da-spec .s { padding: 1rem 1.2rem 1rem 0; border-bottom: 1px solid var(--rule); }
.da-spec .s:nth-child(odd) { border-right: 1px solid var(--rule); }
.da-spec .s:nth-child(even) { padding-left: 1.2rem; }
.da-spec .sk { font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: .35rem; }
.da-spec .sv { font-family: var(--font-display); font-size: 1.18rem; color: var(--ink); line-height: 1.25; }
.da-book .buy { display: inline-flex; align-items: center; gap: .6rem; margin-top: 2rem; }
@media (max-width: 760px) { .da-book-grid { grid-template-columns: 1fr; gap: 2.4rem; } .da-book-cover .frame { max-width: 320px; } }

/* ── THE VOLUME: head + image brick + full colophon ── */
.da-book .vol-head { max-width: 56ch; margin-bottom: clamp(2rem,4vw,3rem); }
.da-book .vol-head .lbl { font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.1rem; }
.da-book .vol-head h2 { font-size: clamp(2rem,3.6vw,3.2rem); line-height: 1.05; margin-bottom: 1.1rem; }
.da-book .vol-head h2 em { font-style: italic; color: var(--ink-mid); }
.da-book .vol-head .intro { color: var(--ink-mid); font-size: 1.05rem; line-height: 1.8; }
.da-book-gallery { display: grid; grid-template-columns: repeat(12,1fr); gap: clamp(.7rem,1.4vw,1.1rem); margin-bottom: clamp(2.4rem,4.5vw,3.6rem); }
.da-book-gallery figure { margin: 0; }
.da-book-gallery .frame { overflow: hidden; border-radius: 3px; background: #e7ded1; border: 1px solid var(--rule); }
.da-book-gallery .frame img, .da-book-gallery .frame .ph { width: 100%; height: 100%; object-fit: cover; display: block; cursor: zoom-in; transition: transform 1s var(--ease); }
.da-book-gallery figure:hover .frame img { transform: scale(1.04); }
.da-book-gallery figcaption { font-size: .72rem; color: var(--ink-muted); line-height: 1.5; margin-top: .6rem; }
.da-book-gallery .b1 { grid-column: span 5; } .da-book-gallery .b1 .frame { height: clamp(280px,34vw,440px); }
.da-book-gallery .b2 { grid-column: span 7; } .da-book-gallery .b2 .frame { height: clamp(280px,34vw,440px); }
.da-book-gallery .b3, .da-book-gallery .b4, .da-book-gallery .b5 { grid-column: span 4; }
.da-book-gallery .b3 .frame, .da-book-gallery .b4 .frame, .da-book-gallery .b5 .frame { height: clamp(190px,22vw,280px); }
.da-book-gallery .b6 { grid-column: span 12; } .da-book-gallery .b6 .frame { height: clamp(230px,28vw,360px); }
.vol-credits { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); border-top: 1px solid var(--rule); padding-top: clamp(1.8rem,3vw,2.4rem); }
.vol-credits .cred-group { margin-bottom: 1.8rem; }
.vol-credits .cred-group.last { margin-bottom: 0; }
.vol-credits .gk { font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: .6rem; }
.vol-credits .row { display: flex; align-items: baseline; justify-content: space-between; gap: 1.2rem; padding: .6rem 0; border-bottom: 1px solid var(--rule); }
.vol-credits .row .role { font-size: .76rem; letter-spacing: .03em; color: var(--ink-muted); flex: 0 0 auto; }
.vol-credits .row .name { font-family: var(--font-display); font-size: 1.1rem; color: var(--ink); line-height: 1.2; text-align: right; }
.vol-credits .isbn-list .ib { display: flex; align-items: baseline; justify-content: space-between; gap: 1.2rem; padding: .55rem 0; border-bottom: 1px solid var(--rule); }
.vol-credits .isbn-list .ib .fmt { font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-muted); }
.vol-credits .isbn-list .ib .num { font-family: ui-monospace, Menlo, monospace; font-size: .82rem; letter-spacing: .01em; color: var(--ink); }
.vol-credits .buy { display: inline-flex; align-items: center; gap: .6rem; margin-top: 1.6rem; }
@media (max-width: 820px) {
  .da-book-gallery .b1, .da-book-gallery .b2 { grid-column: span 12; }
  .da-book-gallery .b3, .da-book-gallery .b4, .da-book-gallery .b5 { grid-column: span 6; }
  .da-book-gallery .b5 { grid-column: span 12; }
  .vol-credits { grid-template-columns: 1fr; gap: 0; }
  .vol-credits .vc-col + .vc-col { margin-top: 1.8rem; }
}

/* ════════ ORIGINS / TIMELINE (dark band — corrected: project begins 2021) ════════ */
.da-line { background: var(--ink); color: var(--bg); padding: clamp(3.8rem, 7vw, 6.5rem) 0; }
.da-line .label { color: var(--accent); margin-bottom: 1.5rem; }
.da-line h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(2rem, 4vw, 3.4rem); line-height: 1.08; max-width: 24ch; color: var(--bg); }
.da-line h2 em { font-style: italic; color: var(--accent); }
.da-arc { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: clamp(2.8rem, 5vw, 4rem); padding-top: clamp(2rem, 3vw, 2.6rem); border-top: 1px solid rgba(245,243,239,.16); }
.da-arc .node { padding: 0 1.2rem; border-left: 1px solid rgba(245,243,239,.12); }
.da-arc .node:first-child { border-left: none; padding-left: 0; }
.da-arc .node .yr { font-family: var(--font-display); font-size: 1.7rem; line-height: 1; color: var(--accent); font-variant-numeric: tabular-nums; }
.da-arc .node .nm { font-family: var(--font-display); font-size: 1.25rem; line-height: 1.1; color: var(--bg); margin-top: .55rem; }
.da-arc .node .gl { font-size: .76rem; line-height: 1.55; color: rgba(245,243,239,.55); margin-top: .55rem; }
@media (max-width: 880px) { .da-arc { grid-template-columns: 1fr 1fr; gap: 1.8rem 0; } .da-arc .node:nth-child(2n+1) { border-left: none; padding-left: 0; } }
@media (max-width: 460px) { .da-arc { grid-template-columns: 1fr; } .da-arc .node { border-left: none; padding-left: 0; } }

/* ════════ QUOTE BAND ════════ */
.da-quote { background: var(--bg-white); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: clamp(4rem, 8vw, 7rem) 0; }
.da-quote blockquote { font-family: var(--font-display); font-style: italic; font-weight: 300; font-size: clamp(1.9rem, 4vw, 3.2rem); line-height: 1.28; max-width: 26ch; margin: 0; color: var(--ink); }
.da-quote blockquote em { color: var(--accent); font-style: italic; }
.da-quote .src { margin-top: 1.75rem; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-muted); }

/* ════════ BROLLY — THE COVER STORY ════════ */
.cv-brolly { background: var(--bg-white); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: clamp(3.5rem,7vw,6rem) 0; }
.cv-brolly-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2.5rem,6vw,5rem); align-items: center; }
.cv-brolly-img .frame { aspect-ratio: 3/4; overflow: hidden; border-radius: 3px; background: #e7ded1; border: 1px solid var(--rule); box-shadow: 0 30px 70px rgba(20,18,14,.2); }
.cv-brolly-img .frame img, .cv-brolly-img .frame .ph { width: 100%; height: 100%; object-fit: cover; cursor: zoom-in; }
.cv-brolly-img figcaption { font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-muted); margin-top: .8rem; }
.cv-brolly .label { color: var(--accent); margin-bottom: 1rem; }
.cv-brolly h2 { font-size: clamp(2rem,3.6vw,3.1rem); line-height: 1.05; margin-bottom: 1.2rem; }
.cv-brolly h2 em { font-style: italic; color: var(--ink-mid); }
.cv-brolly p { color: var(--ink-mid); font-size: 1.05rem; line-height: 1.85; max-width: 52ch; margin-bottom: 1.2rem; }
.cv-brolly p strong { color: var(--ink); font-weight: 500; }
.cv-brolly .essays { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-top: 1.8rem; padding-top: 1.4rem; border-top: 1px solid var(--rule); }
.cv-brolly .essays a { font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 3px; transition: color var(--fast), border-color var(--fast); }
.cv-brolly .essays a:hover { color: var(--accent); border-color: var(--accent); }
/* facts strip (replaces the duplicate essay links — those live in da-fa below) */
.cv-brolly .facts { display: flex; gap: clamp(1.4rem,4vw,2.8rem); flex-wrap: wrap; margin-top: 1.8rem; padding-top: 1.4rem; border-top: 1px solid var(--rule); }
.cv-brolly .facts .f { display: flex; flex-direction: column; gap: .35rem; }
.cv-brolly .facts .fk { font-size: .6rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-muted); }
.cv-brolly .facts .fv { font-family: var(--font-display); font-size: 1.08rem; color: var(--ink); line-height: 1.15; margin: 0; }
@media (max-width: 760px) { .cv-brolly-grid { grid-template-columns: 1fr; gap: 2.2rem; } .cv-brolly-img .frame { max-width: 300px; aspect-ratio: 3/4; } }

/* ════════ FOREWORD / AFTERWORD ════════ */
.da-fa { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.da-fa .label { color: var(--accent); margin-bottom: 2.4rem; display: block; }
.da-fa-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 3vw, 2.5rem); }
.da-fa-c { display: flex; flex-direction: column; padding: clamp(1.8rem,3vw,2.4rem); border: 1px solid var(--rule); border-radius: 4px; background: var(--bg-white); transition: border-color var(--slow) var(--ease), transform var(--slow) var(--ease); }
.da-fa-c:hover { border-color: var(--accent); transform: translateY(-4px); }
.da-fa-c .k { font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 1rem; }
.da-fa-c h3 { font-size: clamp(1.6rem,2.4vw,2rem); line-height: 1.12; margin-bottom: .5rem; }
.da-fa-c .by { font-family: var(--font-display); font-style: italic; font-size: 1.12rem; color: var(--ink-mid); margin-bottom: 1.1rem; }
.da-fa-c p { font-size: .96rem; color: var(--ink-mid); line-height: 1.75; margin-bottom: 1.4rem; }
.da-fa-c .links { margin-top: auto; display: flex; gap: 1.5rem; flex-wrap: wrap; padding-top: 1.2rem; border-top: 1px solid var(--rule); }
.da-fa-c a { font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 3px; transition: color var(--fast), border-color var(--fast); }
.da-fa-c a:hover { color: var(--accent); border-color: var(--accent); }
@media (max-width: 720px) { .da-fa-grid { grid-template-columns: 1fr; } }

/* ════════ THE GENERAL EDITOR (+ origin block; harmonised colours) ════════ */
.da-ed { padding: clamp(3.5rem, 7vw, 6rem) 0; border-top: 1px solid var(--rule); background: var(--bg-white); }
.da-ed-grid { display: grid; grid-template-columns: .7fr 1.3fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
/* picture + background share one tone: portrait frame matches the section's bg-white */
.da-ed-photo .frame { aspect-ratio: 4/5; overflow: hidden; border-radius: 3px; background: var(--bg-white); border: 1px solid var(--rule); }
.da-ed-photo .frame img { width: 100%; height: 100%; object-fit: cover; }
/* two-up portrait diptych of the General Editor */
.da-ed-photo .pair { display: grid; grid-template-columns: 1fr 1fr; gap: .55rem; }
.da-ed-photo .pair .frame { aspect-ratio: 4/5; overflow: hidden; border-radius: 3px; background: var(--bg-white); border: 1px solid var(--rule); }
.da-ed-photo .frame .ph { width: 100%; height: 100%; background-color: var(--bg-white); background-image: repeating-linear-gradient(135deg, rgba(0,0,0,.035) 0 12px, transparent 12px 24px); }
.da-ed-photo figcaption { font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-muted); margin-top: .8rem; }
.da-ed-photo .origin { margin-top: 1.6rem; padding-top: 1.4rem; border-top: 1px solid var(--rule); }
.da-ed-photo .origin .ok { font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: .5rem; }
.da-ed-photo .origin p { font-size: .92rem; color: var(--ink-mid); line-height: 1.7; }
.da-ed-photo .origin p strong { color: var(--ink); font-weight: 500; }
.da-ed .side { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.2rem; display: block; }
.da-ed h2 { font-size: clamp(2rem, 3.6vw, 3.1rem); line-height: 1.06; max-width: 18ch; margin-bottom: 1.5rem; }
.da-ed h2 em { font-style: italic; color: var(--ink-mid); }
.da-ed .col p { color: var(--ink-mid); margin-bottom: 1.2rem; line-height: 1.85; }
.da-ed .col p strong { color: var(--ink); font-weight: 500; }
@media (max-width: 760px) { .da-ed-grid { grid-template-columns: 1fr; gap: 1.8rem; } .da-ed-photo .frame { aspect-ratio: 16/11; max-width: 360px; } }

/* ════════ ESSENCE LIBRARY callout (with logo lockup) ════════ */
.da-essence { padding: clamp(3rem,5vw,4.5rem) 0; }
.da-essence-inner { display: grid; grid-template-columns: minmax(180px, .42fr) 1fr; gap: clamp(1.8rem,4vw,3rem); align-items: center; padding: clamp(1.8rem,3.4vw,2.8rem); border: 1px solid var(--rule); border-left: 3px solid var(--accent); border-radius: 4px; background: var(--bg-white); }
.da-essence .logo-tile { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .9rem; text-align: center; padding: 1.4rem 1.2rem; background: var(--bg); border: 1px solid var(--rule); border-radius: 4px; min-height: 150px; }
.da-essence .logo-tile img { max-width: 100%; max-height: 96px; width: auto; height: auto; object-fit: contain; }
/* typographic fallback wordmark (shown if the live logo cannot load) */
.da-essence .wordmark { display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.da-essence .wordmark .em { font-family: var(--font-display); font-size: clamp(1.7rem,2.6vw,2.2rem); line-height: .95; letter-spacing: .01em; color: var(--ink); }
.da-essence .wordmark .em b { display: block; font-weight: 500; color: var(--accent); }
.da-essence .wordmark .tl { font-family: var(--font-body); font-size: .56rem; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-muted); max-width: 22ch; line-height: 1.6; }
.da-essence .kicker { font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; color: var(--accent); margin-bottom: .7rem; }
.da-essence h3 { font-size: clamp(1.4rem,2.2vw,1.9rem); line-height: 1.15; margin-bottom: .6rem; }
.da-essence p { font-size: .98rem; color: var(--ink-mid); line-height: 1.75; max-width: 64ch; }
.da-essence .visit { display: inline-flex; align-items: center; gap: .45rem; margin-top: 1.1rem; font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 3px; transition: color var(--fast), border-color var(--fast); }
.da-essence .visit:hover { color: var(--accent); border-color: var(--accent); }
@media (max-width: 620px) { .da-essence-inner { grid-template-columns: 1fr; gap: 1.4rem; } }

/* ════════ STORY GALLERY (creative asymmetric brick mosaic, dark) ════════ */
.cv-gal { background: var(--ink); color: var(--bg); padding: clamp(3.5rem,7vw,6rem) 0; }
.cv-gal-head { max-width: 60ch; margin-bottom: clamp(2rem,4vw,3rem); }
.cv-gal-head .label { color: var(--accent); }
.cv-gal-head h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(2rem,3.6vw,3.1rem); line-height: 1.05; color: var(--bg); margin: .7rem 0 .8rem; }
.cv-gal-head h2 em { font-style: italic; color: var(--accent); }
.cv-gal-head p { color: rgba(245,243,239,.6); font-size: 1rem; line-height: 1.8; }
/* 12-col brick: equal-height rows, alternating widths for an asymmetric rhythm */
.cv-gal-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(.7rem,1.4vw,1.1rem); }
.cv-gal figure { margin: 0; position: relative; }
.cv-gal figure.g-a { grid-column: span 7; }
.cv-gal figure.g-b { grid-column: span 5; }
.cv-gal figure.g-c { grid-column: span 5; }
.cv-gal figure.g-d { grid-column: span 7; }
.cv-gal .frame { overflow: hidden; border-radius: 3px; background: #2a2926; border: 1px solid rgba(245,243,239,.1); height: clamp(200px, 25vw, 360px); }
.cv-gal .frame img, .cv-gal .frame .ph { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease); cursor: zoom-in; }
.cv-gal .frame .ph { background-color: #2a2926; }
.cv-gal .frame .ph code { background: rgba(255,255,255,.06); color: rgba(245,243,239,.55); }
.cv-gal figure:hover .frame img { transform: scale(1.05); }
.cv-gal figcaption { font-size: .74rem; color: rgba(245,243,239,.5); line-height: 1.5; margin-top: .65rem; }
@media (max-width: 760px) {
  .cv-gal figure.g-a, .cv-gal figure.g-d { grid-column: span 12; }
  .cv-gal figure.g-b, .cv-gal figure.g-c { grid-column: span 6; }
}
@media (max-width: 460px) { .cv-gal figure { grid-column: span 12 !important; } .cv-gal .frame { height: clamp(200px, 56vw, 300px); } }

/* ════════ BUY CTA (dark) ════════ */
.da-cta { background: var(--ink); color: var(--bg); padding: clamp(3.5rem, 6vw, 5.5rem) 0; }
.da-cta .label { color: var(--accent); margin-bottom: 1.6rem; }
.da-cta h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(2.4rem, 5vw, 4.4rem); line-height: 1; letter-spacing: -.02em; color: var(--bg); max-width: 16ch; }
.da-cta h2 em { font-style: italic; color: var(--accent); }
.da-cta-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 2.5rem; flex-wrap: wrap; margin-top: clamp(2.2rem, 4vw, 3rem); padding-top: clamp(1.8rem, 3vw, 2.4rem); border-top: 1px solid rgba(245,243,239,.14); }
.da-cta-row .lead { max-width: 44ch; color: rgba(245,243,239,.58); font-size: 1rem; line-height: 1.7; margin: 0; }
.da-cta .price { font-family: var(--font-display); font-size: 1.6rem; color: var(--bg); margin-bottom: .2rem; }
.da-cta .price span { display: block; font-size: .64rem; font-family: var(--font-body); letter-spacing: .12em; text-transform: uppercase; color: rgba(245,243,239,.5); margin-top: .25rem; }
.da-cta-buy { display: flex; flex-direction: column; align-items: flex-start; gap: 1.1rem; }
.da-cta .btn-light { flex: 0 0 auto; display: inline-flex; align-items: center; gap: .55rem; font-family: var(--font-body); font-size: .82rem; letter-spacing: .11em; text-transform: uppercase; padding: 1.05rem 2.4rem; background: var(--bg); color: var(--ink); border: 1px solid var(--bg); border-radius: 2px; transition: background var(--fast) var(--ease), color var(--fast) var(--ease), border-color var(--fast) var(--ease); }
.da-cta .btn-light:hover { background: transparent; color: var(--bg); border-color: rgba(245,243,239,.5); }
@media (max-width: 640px) { .da-cta .btn-light { width: 100%; justify-content: center; } .da-cta-buy { width: 100%; } }
/* dual CTA links */
.da-cta .da-cta-links { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.da-cta .btn-ghost { display: inline-flex; align-items: center; gap: .55rem; font-family: var(--font-body); font-size: .82rem; letter-spacing: .11em; text-transform: uppercase; padding: 1.05rem 2rem; background: transparent; color: var(--bg); border: 1px solid rgba(245,243,239,.4); border-radius: 2px; transition: background var(--fast) var(--ease), color var(--fast) var(--ease), border-color var(--fast) var(--ease); }
.da-cta .btn-ghost:hover { border-color: var(--bg); background: rgba(245,243,239,.06); }
@media (max-width: 640px) { .da-cta .da-cta-links { width: 100%; flex-direction: column; align-items: stretch; } .da-cta .btn-ghost { width: 100%; justify-content: center; } }

/* ════════ LIGHTBOX ════════ */
.da-lb { position: fixed; inset: 0; z-index: 300; background: rgba(20,18,14,.93); display: flex; align-items: center; justify-content: center; padding: clamp(1.5rem,5vw,4rem); opacity: 0; pointer-events: none; transition: opacity .3s var(--ease); cursor: zoom-out; }
.da-lb.open { opacity: 1; pointer-events: auto; }
.da-lb figure { margin: 0; max-width: 1100px; max-height: 100%; display: flex; flex-direction: column; align-items: center; }
.da-lb img { max-width: 100%; max-height: 80vh; object-fit: contain; border-radius: 3px; box-shadow: 0 30px 90px rgba(0,0,0,.5); }
.da-lb figcaption { color: rgba(245,243,239,.82); font-family: var(--font-display); font-style: italic; font-size: 1.05rem; text-align: center; margin-top: 1.1rem; max-width: 60ch; }
.da-lb .lb-close { position: absolute; top: clamp(1rem,3vw,1.8rem); right: clamp(1rem,3vw,1.8rem); width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(245,243,239,.4); background: transparent; color: var(--bg); font-size: 1rem; cursor: pointer; display: grid; place-items: center; transition: background .2s, color .2s; }
.da-lb .lb-close:hover { background: var(--bg); color: var(--ink); }

/* ════════ SUB-350px DISPLAY TYPE ════════
   On very narrow phones the big display headings keep scaling down with the
   viewport (vw-driven), so the heaviest type shrinks the most while light
   running text stays put. Legible rem floors prevent collapse. */
@media (max-width: 350px) {
  .cv-hero h1 { font-size: clamp(1.7rem, 8.5vw, 2.3rem); }
  .cv-hero .sub { font-size: .98rem; }
  .cv-stats .cv { font-size: clamp(1.6rem, 7.5vw, 2.2rem); }
  .lx-az .count .cv { font-size: clamp(1.6rem, 7.5vw, 2.2rem); }
  .lx-az .letters span { font-size: clamp(1rem, 4.5vw, 1.5rem); }
  .lx-thesis blockquote,
  .da-quote blockquote { font-size: clamp(1.4rem, 6.5vw, 1.9rem); }
  .da-book h2,
  .da-book .vol-head h2,
  .cv-brolly h2,
  .da-line h2,
  .da-ed h2,
  .cv-gal-head h2,
  .da-essence .je-head h2 { font-size: clamp(1.45rem, 7vw, 2rem); }
  .da-fa-c h3 { font-size: clamp(1.3rem, 5.5vw, 1.6rem); }
  .da-essence h3,
  .da-partners .partner h3 { font-size: clamp(1.25rem, 5.5vw, 1.55rem); }
  .da-cta h2 { font-size: clamp(1.7rem, 8vw, 2.4rem); }
}
