/* ════════════════════════════════════════════════════════════════
   WHEREVER YOUR LAUGHTER LIVES — site styles
   Three switchable directions via html[data-theme]:
   golden · twilight · page
   ════════════════════════════════════════════════════════════════ */

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

:root{
  --serif-display:"Cormorant Garamond", Georgia, serif;
  --serif-body:"Newsreader", Georgia, serif;
  --sans:"Manrope", system-ui, -apple-system, sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(0.22,1,0.36,1);
}

/* ── THEME: GOLDEN HOUR (default) ── */
html[data-theme="golden"]{
  --bg:#F2E9D8; --bg-2:#E9DCC5; --surface:#FBF6EC; --surface-2:#F4EAD7;
  --ink:#2B2017; --ink-soft:#5C4F40; --muted:#8C7C66;
  --accent:#B14E2A; --accent-2:#C5882F;
  --line:rgba(43,32,23,0.14); --line-soft:rgba(43,32,23,0.07);
  --shadow:0 30px 80px -40px rgba(43,32,23,0.55);
  --grain-op:0.05;
}
/* ── THEME: TWILIGHT ── */
html[data-theme="twilight"]{
  --bg:#0E1117; --bg-2:#11151D; --surface:#171E28; --surface-2:#1C2530;
  --ink:#F3EBDC; --ink-soft:#C9BDA9; --muted:#8A8270;
  --accent:#E2A64E; --accent-2:#D9743F;
  --line:rgba(243,235,220,0.14); --line-soft:rgba(243,235,220,0.06);
  --shadow:0 36px 90px -40px rgba(0,0,0,0.8);
  --grain-op:0.06;
}
/* ── THEME: THE PRINTED PAGE ── */
html[data-theme="page"]{
  --bg:#F6F2E9; --bg-2:#EDE7D8; --surface:#FCFAF3; --surface-2:#F2ECDD;
  --ink:#27313A; --ink-soft:#4E5963; --muted:#7C8893;
  --accent:#B23A2E; --accent-2:#5E7A86;
  --line:rgba(39,49,58,0.14); --line-soft:rgba(39,49,58,0.07);
  --shadow:0 30px 80px -44px rgba(39,49,58,0.5);
  --grain-op:0.04;
}

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg); color:var(--ink);
  font-family:var(--serif-body); font-size:18px; line-height:1.7;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  transition:background .6s var(--ease), color .6s var(--ease);
}
/* film-grain texture over everything */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:var(--grain-op);
  background-image:url("data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjIwIDIyMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZmlsdGVyIGlkPSJuIj48ZmVUdXJidWxlbmNlIHR5cGU9ImZyYWN0YWxOb2lzZSIgYmFzZUZyZXF1ZW5jeT0iMC44NSIgbnVtT2N0YXZlcz0iMyIgc3RpdGNoVGlsZXM9InN0aXRjaCIvPjwvZmlsdGVyPjxyZWN0IHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbHRlcj0idXJsKCNuKSIvPjwvc3ZnPg==");
  mix-blend-mode:overlay;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--accent); color:var(--surface); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 40px; }

/* ── type helpers ── */
.kicker{
  font-family:var(--sans); font-size:12px; font-weight:700; letter-spacing:0.32em;
  text-transform:uppercase; color:var(--accent);
  display:inline-flex; align-items:center; gap:14px;
}
.kicker::before{ content:""; width:30px; height:1px; background:var(--accent); display:inline-block; }
.kicker.center{ justify-content:center; }
.kicker.bare::before{ display:none; }

h1,h2,h3{ font-family:var(--serif-display); font-weight:500; line-height:1.02; letter-spacing:0.005em; }
.serif-it{ font-style:italic; }
.lead{ font-family:var(--serif-body); font-size:22px; line-height:1.6; color:var(--ink-soft); }

/* ════════ NAV ════════ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px; transition:all .4s var(--ease);
}
.nav.scrolled{
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:blur(14px) saturate(1.2); -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft); padding:13px 40px;
}
.nav .brand{ display:flex; flex-direction:column; line-height:1.05; }
.nav .brand .bt{ font-family:var(--serif-display); font-style:italic; font-size:23px; color:var(--ink); white-space:nowrap; }
.nav .brand .bs{ font-family:var(--sans); font-size:9.5px; font-weight:600; letter-spacing:0.28em; text-transform:uppercase; color:var(--muted); margin-top:2px; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ font-family:var(--sans); font-size:13px; font-weight:600; letter-spacing:0.04em; color:var(--ink-soft); transition:color .25s; position:relative; }
.nav-links a::after{ content:""; position:absolute; left:0; right:0; bottom:-5px; height:1.5px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ transform:scaleX(1); }

/* over the hero (before scroll) nav goes light for legibility */
.nav:not(.scrolled) .brand .bt{ color:#F6EEE1; }
.nav:not(.scrolled) .brand .bs{ color:rgba(246,238,225,0.62); }
.nav:not(.scrolled) .nav-links > a{ color:rgba(246,238,225,0.88); }
.nav:not(.scrolled) .nav-links > a:hover{ color:#fff; }
.nav:not(.scrolled) .menu-btn{ color:#F6EEE1; border-color:rgba(246,238,225,0.4); }
.nav:not(.scrolled) .theme-switch{ border-left-color:rgba(246,238,225,0.3); }
.nav:not(.scrolled) .brand .bt,
.nav:not(.scrolled) .brand .bs,
.nav:not(.scrolled) .nav-links > a{ text-shadow:0 1px 14px rgba(0,0,0,0.45); }

/* theme switcher */
.theme-switch{ display:flex; align-items:center; gap:9px; padding-left:22px; border-left:1px solid var(--line); }
.theme-switch .sw{
  width:24px; height:24px; border-radius:50%; cursor:pointer; padding:0; border:1.5px solid var(--line);
  position:relative; transition:transform .25s var(--ease), box-shadow .25s; outline:none;
}
.theme-switch .sw:hover{ transform:scale(1.12); }
.theme-switch .sw[aria-pressed="true"]{ box-shadow:0 0 0 2px var(--bg), 0 0 0 3.5px var(--accent); }
.sw.sw-golden{ background:linear-gradient(135deg,#E9DCC5,#B14E2A); }
.sw.sw-twilight{ background:linear-gradient(135deg,#1C2530,#E2A64E); }
.sw.sw-page{ background:linear-gradient(135deg,#5E7A86,#B23A2E); }

.menu-btn{ display:none; }

/* ════════ HERO ════════ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero-img{ position:absolute; inset:0; z-index:1; }
.hero-img img{ width:100%; height:100%; object-fit:cover; object-position:center 28%; }
.hero-img::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,6,4,0.50) 0%, rgba(8,6,4,0.12) 22%, rgba(8,6,4,0.10) 40%, rgba(8,6,4,0.52) 72%, rgba(8,6,4,0.86) 92%, var(--bg) 100%),
    linear-gradient(95deg, rgba(8,6,4,0.74) 0%, rgba(8,6,4,0.30) 46%, transparent 74%);
}
.hero-inner{ position:relative; z-index:3; width:100%; padding-bottom:9vh; }
.hero .kicker{ margin-bottom:26px; color:var(--accent-2); }
.hero .kicker::before{ background:var(--accent-2); }
.hero h1{
  font-size:clamp(44px, 6.6vw, 94px); line-height:0.98; letter-spacing:-0.012em; color:#F6EEE1;
  text-wrap:balance; max-width:15ch; text-shadow:0 2px 40px rgba(0,0,0,0.35);
}
.hero h1 .it{ font-style:italic; color:var(--accent-2); }
.hero .byline{ font-family:var(--sans); font-size:15px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:rgba(246,238,225,0.82); margin-top:30px; }
.hero .byline strong{ color:#fff; font-weight:700; }
.hero .sub{ margin-top:24px; max-width:46ch; font-size:21px; line-height:1.62; color:rgba(246,238,225,0.92); font-style:italic; }
.hero .btn-ghost{ color:#F6EEE1; border-color:rgba(246,238,225,0.45); }
.hero .btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,0.1); }
.hero-cta{ display:flex; gap:16px; margin-top:40px; flex-wrap:wrap; }

.btn{
  font-family:var(--sans); font-size:13.5px; font-weight:700; letter-spacing:0.08em;
  padding:15px 28px; border-radius:2px; cursor:pointer; border:1px solid transparent;
  transition:all .3s var(--ease); display:inline-flex; align-items:center; gap:11px; white-space:nowrap;
}
.btn-primary{ background:var(--accent); color:var(--surface); }
.btn-primary:hover{ background:var(--ink); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); background:color-mix(in srgb,var(--ink) 5%,transparent); transform:translateY(-2px); }
.btn .arr{ transition:transform .3s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }

.scroll-hint{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:4;
  font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:0.26em; text-transform:uppercase; color:var(--muted);
  display:flex; flex-direction:column; align-items:center; gap:10px; }
.scroll-hint .ln{ width:1px; height:38px; background:linear-gradient(var(--muted),transparent); animation:scrollPulse 2.4s ease-in-out infinite; }
@keyframes scrollPulse{ 0%,100%{ opacity:.3; transform:scaleY(.7); } 50%{ opacity:1; transform:scaleY(1); } }

/* ════════ SECTION SCAFFOLD ════════ */
.section{ position:relative; padding:130px 0; }
.section.alt{ background:var(--bg-2); }
.section-head{ max-width:760px; margin-bottom:70px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size:clamp(38px,5.2vw,68px); margin-top:22px; color:var(--ink); text-wrap:balance; }
.section-head h2 .it{ font-style:italic; color:var(--accent); }
.section-head .lead{ margin-top:24px; }

/* ════════ INVITATION ════════ */
.invite{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:80px; align-items:center; }
.invite .prose p{ margin-bottom:22px; color:var(--ink-soft); }
.invite .prose p .em{ font-style:italic; color:var(--ink); }
.invite .prose .drop::first-letter{
  font-family:var(--serif-display); font-style:italic; float:left; font-size:84px; line-height:0.66;
  padding:10px 14px 0 0; color:var(--accent);
}
.invite-figure{ position:relative; }
.invite-figure .frame{ position:relative; box-shadow:var(--shadow); }
.invite-figure img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.invite-figure .cap{ font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-top:16px; display:flex; align-items:center; gap:12px; }
.invite-figure .cap::before{ content:""; width:22px; height:1px; background:var(--accent); }
.invite .stats{ display:flex; gap:42px; margin-top:42px; padding-top:34px; border-top:1px solid var(--line); }
.invite .stat .n{ font-family:var(--serif-display); font-style:italic; font-size:50px; line-height:1; color:var(--accent); }
.invite .stat .l{ font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* ════════ MOVEMENTS ════════ */
.movements{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); }
.mv{ position:relative; padding:38px 30px 36px; border-right:1px solid var(--line); transition:background .4s; overflow:hidden; }
.mv:last-child{ border-right:none; }
.mv:hover{ background:var(--surface); }
.mv .mv-img{ aspect-ratio:4/3; overflow:hidden; margin-bottom:26px; position:relative; }
.mv .mv-img img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); filter:saturate(1.02); }
.mv:hover .mv-img img{ transform:scale(1.06); }
.mv .mv-n{ font-family:var(--serif-display); font-style:italic; font-size:24px; color:var(--accent); }
.mv .mv-phase{ font-family:var(--sans); font-size:10.5px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin:14px 0 6px; }
.mv h3{ font-size:31px; color:var(--ink); margin-bottom:14px; }
.mv p{ font-size:15.5px; line-height:1.55; color:var(--ink-soft); }

/* ════════ READER / LIBRARY ════════ */
.lib-part{ margin-bottom:64px; }
.lib-part:last-child{ margin-bottom:0; }
.lib-part-head{ display:flex; align-items:baseline; gap:20px; margin-bottom:14px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.lib-part-head .pn{ font-family:var(--serif-display); font-style:italic; font-size:28px; color:var(--accent); white-space:nowrap; }
.lib-part-head .pt{ font-family:var(--serif-display); font-size:34px; color:var(--ink); }
.lib-part-head .pp{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-left:auto; }

.poem-row{
  display:grid; grid-template-columns:64px 1fr auto; gap:26px; align-items:center;
  padding:22px 18px; border-bottom:1px solid var(--line-soft); cursor:pointer;
  transition:background .3s, padding .3s var(--ease); position:relative;
}
.poem-row::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--accent); transform:scaleY(0); transform-origin:center; transition:transform .35s var(--ease); }
.poem-row:hover{ background:var(--surface); padding-left:30px; }
.poem-row:hover::before{ transform:scaleY(1); }
.poem-row .rn{ font-family:var(--serif-display); font-style:italic; font-size:30px; color:var(--muted); transition:color .3s; }
.poem-row:hover .rn{ color:var(--accent); }
.poem-row .rt{ }
.poem-row .rt h4{ font-family:var(--serif-display); font-size:30px; font-weight:500; color:var(--ink); line-height:1.05; }
.poem-row .rt .rsub{ font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--muted); margin-top:5px; }
.poem-row .rt .rteaser{ font-family:var(--serif-body); font-style:italic; font-size:17px; color:var(--ink-soft); margin-top:7px; max-width:54ch; }
.poem-row .rthumb{ width:74px; height:74px; overflow:hidden; flex-shrink:0; }
.poem-row .rthumb img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.poem-row:hover .rthumb img{ transform:scale(1.08); }
.poem-row .rgo{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent); display:flex; align-items:center; gap:8px; opacity:0; transform:translateX(-8px); transition:all .35s var(--ease); }
.poem-row:hover .rgo{ opacity:1; transform:none; }

/* ════════ READER OVERLAY ════════ */
.reader{
  position:fixed; inset:0; z-index:500; display:grid; grid-template-columns:42% 58%;
  background:var(--bg); opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s;
}
.reader.open{ opacity:1; visibility:visible; }
.reader-img{ position:relative; overflow:hidden; background:var(--bg-2); }
.reader-img img{ width:100%; height:100%; object-fit:cover; object-position:center; }
.reader-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg, transparent 60%, color-mix(in srgb,var(--bg) 70%,transparent)); }
.reader-scroll{ overflow-y:auto; height:100vh; position:relative; }
.reader-pad{ max-width:660px; margin:0 auto; padding:120px 64px 130px; }
.reader .r-kicker{ margin-bottom:20px; }
.reader h2{ font-size:clamp(42px,5vw,64px); color:var(--ink); line-height:0.98; margin-bottom:8px; text-wrap:balance; }
.reader .r-sub{ font-family:var(--serif-body); font-style:italic; font-size:18px; color:var(--ink-soft); margin-bottom:40px; }
.reader-divide{ width:54px; height:2px; background:var(--accent); margin:34px 0 38px; }

/* poem audio player */
.poem-audio{ display:flex; align-items:center; gap:18px; margin-top:34px; padding:14px 20px 14px 14px;
  background:var(--surface); border:1px solid var(--line); border-radius:3px; }
.pa-btn{ flex:none; width:46px; height:46px; border-radius:50%; border:none; cursor:pointer;
  background:var(--accent); color:var(--surface); display:flex; align-items:center; justify-content:center;
  transition:transform .25s var(--ease), background .25s; }
.pa-btn svg{ margin-left:1px; }
.pa-btn.playing svg{ margin-left:0; }
.pa-btn:hover{ transform:scale(1.07); background:var(--ink); }
.pa-body{ flex:1; min-width:0; }
.pa-top{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:10px; }
.pa-label{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); }
.pa-time{ font-family:var(--sans); font-size:11.5px; font-weight:600; letter-spacing:0.04em; color:var(--muted); font-variant-numeric:tabular-nums; }
.pa-track{ position:relative; height:4px; border-radius:3px; background:var(--line); cursor:pointer; }
.pa-fill{ position:absolute; left:0; top:0; bottom:0; width:0; border-radius:3px; background:var(--accent); transition:width .12s linear; }
.pa-track::after{ content:""; position:absolute; inset:-9px 0; }

/* inline page players (intro, author's note, nonprofits) */
.inline-audio{ margin-top:0; }
.invite-text .inline-audio{ margin:34px 0 4px; max-width:460px; }
.about-text .inline-audio{ margin:30px 0 4px; max-width:460px; }
.give-col{ display:flex; flex-direction:column; gap:16px; }
.give-col .give-card{ flex:1; height:auto; }
.give-col .inline-audio{ margin:0; }

.poem-body{ font-family:var(--serif-body); font-size:20px; line-height:1.62; color:var(--ink); }
.poem-body .stanza{ margin-bottom:1.55em; white-space:pre-line; text-wrap:pretty; }
.poem-body .p-rule{ width:0; height:0; border:none; margin:2.2em auto; position:relative; }
.poem-body .p-rule::after{ content:"\2766"; display:block; text-align:center; color:var(--accent); font-size:20px; opacity:.8; }

.poem-extra{ margin-top:48px; padding-top:32px; border-top:1px solid var(--line); }
.poem-memorial{ font-family:var(--sans); font-size:12px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); margin-bottom:24px; }
.poem-epigraph{ font-family:var(--serif-body); font-style:italic; font-size:18.5px; line-height:1.55; color:var(--ink-soft); padding-left:22px; border-left:2px solid var(--line); }
.poem-epigraph .by{ display:block; font-style:normal; font-family:var(--sans); font-size:11.5px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-top:14px; }

.reader-close{ position:fixed; top:26px; right:30px; z-index:520; width:48px; height:48px; border-radius:50%;
  background:var(--surface); border:1px solid var(--line); color:var(--ink); cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all .3s var(--ease); }
.reader-close:hover{ background:var(--accent); color:var(--surface); transform:rotate(90deg); }
.reader-nav{ position:fixed; bottom:30px; right:30px; z-index:520; display:flex; gap:10px; }
.reader-nav button{ font-family:var(--sans); font-size:12px; font-weight:700; letter-spacing:0.08em; padding:12px 20px;
  background:var(--surface); border:1px solid var(--line); color:var(--ink); cursor:pointer; transition:all .3s var(--ease);
  display:flex; align-items:center; gap:9px; }
.reader-nav button:hover{ background:var(--ink); color:var(--surface); }
.reader-nav button:disabled{ opacity:.35; pointer-events:none; }
.reader-progress{ position:fixed; top:0; left:0; height:3px; background:var(--accent); z-index:530; width:0; transition:width .1s linear; }

/* ════════ FLIP-BOOK OVERLAY ════════ */
.readmodes{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; margin-top:30px; }
.readmodes-or{ font-family:var(--serif-body); font-style:italic; font-size:16px; color:var(--muted); }
.flipbook{ position:fixed; inset:0; z-index:600; display:flex; flex-direction:column;
  background:#171210; opacity:0; visibility:hidden; transition:opacity .45s var(--ease), visibility .45s; }
.flipbook.open{ opacity:1; visibility:visible; }
.flipbook-bar{ flex:none; display:flex; align-items:center; gap:16px; padding:15px 22px;
  background:rgba(0,0,0,0.32); border-bottom:1px solid rgba(255,255,255,0.08); }
.flipbook-eyebrow{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--accent-2); white-space:nowrap; }
.flipbook-title{ font-family:var(--serif-display); font-style:italic; font-size:20px; color:#F6EEE1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.flipbook-actions{ margin-left:auto; display:flex; align-items:center; gap:12px; flex:none; }
.flipbook-ext{ font-family:var(--sans); font-size:12px; font-weight:700; letter-spacing:0.06em; color:rgba(246,238,225,0.85);
  display:inline-flex; align-items:center; gap:7px; padding:9px 16px; border:1px solid rgba(255,255,255,0.22); border-radius:2px; transition:background .25s var(--ease), color .25s, border-color .25s; }
.flipbook-ext:hover{ background:rgba(255,255,255,0.1); color:#fff; border-color:rgba(255,255,255,0.4); }
.flipbook-close{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,0.22);
  background:transparent; color:#F6EEE1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .3s var(--ease); }
.flipbook-close:hover{ background:var(--accent); border-color:var(--accent); color:#fff; transform:rotate(90deg); }
.flipbook-stage{ flex:1; position:relative; background:#171210; }
.flipbook-stage iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.flipbook-loading{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--serif-body); font-style:italic; font-size:18px; color:rgba(246,238,225,0.55); }
@media (max-width:680px){
  .flipbook-title{ display:none; }
  .flipbook-ext{ padding:9px 12px; }
}

/* ════════ ABOUT ADAM ════════ */
.about{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:80px; align-items:start; }
.about-portrait{ position:relative; }
.about-portrait .frame{ box-shadow:var(--shadow); position:relative; }
.about-portrait img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.about-portrait .ph{ display:flex; align-items:center; justify-content:center; aspect-ratio:3/4; background:var(--surface-2);
  border:1px dashed var(--line); text-align:center; padding:40px; }
.about-portrait .ph span{ font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); line-height:1.8; }
.about-portrait .cap{ font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-top:16px; }
.about .prose p{ margin-bottom:22px; color:var(--ink-soft); font-size:19px; }
.about .prose p .em{ font-style:italic; color:var(--ink); }
.about .prose p:first-of-type{ font-size:24px; line-height:1.55; color:var(--ink); font-family:var(--serif-display); }
.about-roles{ display:flex; flex-wrap:wrap; gap:10px; margin-top:34px; }
.about-roles span{ font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:0.08em; padding:8px 16px; border:1px solid var(--line); color:var(--ink-soft); }

/* ════════ GIVING BACK ════════ */
.giving{ }
.give-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px; margin-top:10px; }
.give-card{ background:var(--surface); border:1px solid var(--line); padding:48px 46px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s; }
.give-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.give-card .gc-tag{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--accent); margin-bottom:20px; }
.give-card h3{ font-size:40px; color:var(--ink); line-height:1; margin-bottom:8px; }
.give-card .gc-full{ font-family:var(--sans); font-size:12.5px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:24px; }
.give-card p{ font-size:17px; color:var(--ink-soft); margin-bottom:18px; }
.give-card .gc-link{ margin-top:auto; font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:0.06em; color:var(--accent); display:inline-flex; align-items:center; gap:10px; padding-top:10px; }
.give-card .gc-link .arr{ transition:transform .3s var(--ease); }
.give-card:hover .gc-link .arr{ transform:translateX(5px); }
.giving-note{ margin-top:40px; font-family:var(--serif-body); font-style:italic; font-size:21px; line-height:1.55; color:var(--ink-soft); max-width:760px; text-align:center; margin-inline:auto; }
.giving-note .em{ color:var(--accent); font-style:italic; }

/* pull-quote band */
.quoteband{ padding:120px 0; background:var(--bg-2); position:relative; overflow:hidden; }
.quoteband .q{ font-family:var(--serif-display); font-style:italic; font-size:clamp(30px,4.4vw,58px); line-height:1.18; color:var(--ink); text-align:center; max-width:18ch; margin:0 auto; text-wrap:balance; }
.quoteband .q .em{ color:var(--accent); }
.quoteband .qby{ text-align:center; margin-top:34px; font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }

/* ════════ FOOTER ════════ */
.footer{ background:var(--ink); color:var(--bg); padding:96px 0 44px; position:relative; }
html[data-theme="twilight"] .footer{ background:#080A0E; }
.footer .ded{ font-family:var(--serif-display); font-style:italic; font-size:clamp(26px,3.4vw,40px); line-height:1.3; color:var(--bg); max-width:20ch; margin-bottom:60px; text-wrap:balance; }
.footer .ded .em{ color:var(--accent-2); }
.footer-grid{ display:flex; justify-content:space-between; align-items:flex-end; gap:50px; flex-wrap:wrap; padding-top:42px; border-top:1px solid rgba(255,255,255,0.16); }
.footer .fbrand{ flex-shrink:0; }
.footer .fbrand .ft{ font-family:var(--serif-display); font-style:italic; font-size:26px; color:var(--bg); white-space:nowrap; }
.footer .fbrand .fa{ font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-top:6px; }
.footer .fmeta{ font-family:var(--sans); font-size:12px; line-height:1.9; color:rgba(255,255,255,0.6); text-align:right; }
.footer .fmeta a{ color:var(--accent-2); }
.footer .fcopy{ margin-top:40px; font-family:var(--sans); font-size:11px; letter-spacing:0.04em; color:rgba(255,255,255,0.4); }

/* ════════ reveal-on-scroll ════════ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } *{ scroll-behavior:auto !important; } }

/* ════════ RESPONSIVE ════════ */
@media (max-width:1080px){
  .invite,.about{ grid-template-columns:1fr; gap:50px; }
  .invite-figure{ max-width:460px; }
  .about-portrait{ max-width:380px; }
  .movements{ grid-template-columns:1fr 1fr; }
  .mv{ border-bottom:1px solid var(--line); }
  .mv:nth-child(2){ border-right:none; }
  .reader{ grid-template-columns:1fr; }
  .reader-img{ height:42vh; }
  .reader-scroll{ height:auto; }
}
@media (max-width:760px){
  body{ font-size:17px; }
  .wrap{ padding:0 22px; }
  .nav{ padding:14px 22px; }
  .nav.scrolled{ padding:11px 22px; }
  .nav-links{ display:none; }
  .nav-links.mobile-open{ display:flex; position:fixed; inset:0; background:var(--bg); flex-direction:column; justify-content:center; align-items:center; gap:30px; z-index:190; }
  .nav-links.mobile-open a{ font-size:22px; font-family:var(--serif-display); }
  .nav-links.mobile-open .theme-switch{ border-left:none; border-top:1px solid var(--line); padding:24px 0 0; }
  .menu-btn{ display:flex; align-items:center; justify-content:center; width:42px; height:42px; background:none; border:1px solid var(--line); color:var(--ink); cursor:pointer; z-index:210; position:relative; }
  .nav .theme-switch{ display:none; }
  .nav-links.mobile-open .theme-switch{ display:flex; }
  .section{ padding:80px 0; }
  .section-head{ margin-bottom:44px; }
  .movements{ grid-template-columns:1fr; }
  .mv{ border-right:none; }
  .give-grid{ grid-template-columns:1fr; }
  .poem-row{ grid-template-columns:44px 1fr; gap:16px; padding:18px 8px; }
  .poem-row .rthumb,.poem-row .rgo{ display:none; }
  .poem-row:hover{ padding-left:14px; }
  .reader-pad{ padding:80px 28px 110px; }
  .poem-body{ font-size:18px; }
  .invite .stats{ flex-wrap:wrap; gap:26px; }
  .hero .sub{ font-size:18px; }
  .reader-nav{ bottom:18px; right:18px; }
  .reader-close{ top:16px; right:18px; }
}