:root {
  --ink: #21182a;
  --ink-soft: #62596a;
  --paper: #f7f1ea;
  --paper-warm: #efe4d8;
  --white: #fffdf9;
  --plum: #6c2b70;
  --plum-dark: #351638;
  --orchid: #c995c9;
  --cyan: #49bcd0;
  --gold: #c99a5a;
  --line: rgba(33, 24, 42, .14);
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
  --shadow: 0 28px 70px rgba(47, 26, 48, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: clip; }
body {
  margin: 0;
  overflow-x: clip;
  color: var(--ink);
  background: var(--paper);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button { font: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 {
  font-family: var(--serif);
  font-weight: 600;
  line-height: .98;
  letter-spacing: -.025em;
}
h1 { max-width: 860px; font-size: clamp(4rem, 8vw, 7.6rem); }
h2 { font-size: clamp(3rem, 5vw, 5.4rem); }
h3 { font-size: clamp(2rem, 3vw, 2.8rem); }
em { font-weight: 500; }

.shell { width: min(1180px, calc(100% - 48px)); margin-inline: auto; }
.section { padding: clamp(88px, 11vw, 150px) 0; }
.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: fixed; z-index: 100; left: 16px; top: 16px; padding: 10px 14px;
  color: white; background: var(--plum); transform: translateY(-150%);
}
.skip-link:focus { transform: none; }

.eyebrow {
  margin-bottom: 22px;
  color: var(--plum);
  font-size: .74rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 54px;
  padding: 13px 24px;
  border: 1px solid transparent;
  border-radius: 100px;
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: .025em;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.button:hover { transform: translateY(-2px); }
.button-primary { color: white; background: var(--plum); box-shadow: 0 12px 30px rgba(108, 43, 112, .25); }
.button-primary:hover { background: var(--plum-dark); }
.button-dark { color: white; background: var(--ink); }
.button-light { color: var(--plum-dark); background: var(--white); }
.text-link {
  display: inline-flex; gap: 9px; align-items: center; padding-bottom: 3px;
  border-bottom: 1px solid currentColor; color: var(--plum); font-weight: 600; text-decoration: none;
}
.text-link span { transition: transform .2s ease; }
.text-link:hover span { transform: translateX(4px); }

.site-header {
  position: fixed;
  z-index: 20;
  inset: 0 0 auto;
  border-bottom: 1px solid transparent;
  transition: background .25s ease, border-color .25s ease, backdrop-filter .25s ease;
}
.site-header.scrolled {
  border-color: var(--line);
  background: rgba(247, 241, 234, .9);
  backdrop-filter: blur(14px);
}
.nav-wrap { display: flex; min-height: 88px; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; }
.brand-mark {
  display: grid; width: 40px; aspect-ratio: 1; place-items: center;
  border: 1px solid rgba(108, 43, 112, .35); border-radius: 50%;
  color: var(--plum); font-family: var(--serif); font-size: 1.6rem; font-style: italic;
}
.brand strong, .brand small { display: block; line-height: 1.15; }
.brand strong { font-family: var(--serif); font-size: 1.25rem; }
.brand small { margin-top: 4px; color: var(--ink-soft); font-size: .61rem; letter-spacing: .13em; text-transform: uppercase; }
.site-nav { display: flex; align-items: center; gap: 34px; }
.site-nav a { font-size: .8rem; font-weight: 600; text-decoration: none; }
.site-nav a:not(.nav-cta):hover { color: var(--plum); }
.site-nav .nav-cta { padding: 9px 18px; border: 1px solid rgba(108, 43, 112, .4); border-radius: 100px; color: var(--plum); }
.menu-toggle { display: none; padding: 8px; border: 0; background: transparent; }
.menu-toggle > span:not(.sr-only) { display: block; width: 25px; height: 2px; margin: 5px; background: var(--ink); }

.hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  padding: 150px 0 80px;
  background:
    radial-gradient(circle at 85% 20%, rgba(201, 149, 201, .38), transparent 28%),
    radial-gradient(circle at 6% 82%, rgba(73, 188, 208, .14), transparent 25%),
    var(--paper);
}
.hero-grid { display: grid; min-height: calc(100svh - 230px); grid-template-columns: 1.3fr .7fr; gap: 70px; align-items: center; }
.hero-copy { position: relative; z-index: 2; }
.hero h1 { margin-bottom: 30px; }
.hero h1 em { color: var(--plum); }
.hero-lede { max-width: 630px; margin-bottom: 34px; color: var(--ink-soft); font-size: clamp(1.05rem, 1.5vw, 1.25rem); }
.hero-actions { display: flex; align-items: center; gap: 28px; }
.hero-art { position: relative; z-index: 2; justify-self: end; width: min(100%, 390px); }
.portrait-frame { position: relative; padding: 15px; background: rgba(255,255,255,.4); box-shadow: var(--shadow); transform: rotate(2deg); }
.portrait-frame img { width: 100%; aspect-ratio: .78; object-fit: cover; object-position: 50% 30%; filter: saturate(.72) sepia(.06); }
.portrait-frame::before {
  content: ""; position: absolute; inset: -12px 25px auto -24px; height: 66%;
  border: 1px solid rgba(108,43,112,.38); z-index: -1;
}
.portrait-note {
  position: absolute; right: -35px; bottom: 40px; padding: 12px 16px;
  color: white; background: var(--plum); font-family: var(--serif); font-size: 1rem; transform: rotate(-2deg);
}
.floating-quote { max-width: 310px; margin: 34px auto 0; font-family: var(--serif); font-size: 1.35rem; font-style: italic; line-height: 1.3; text-align: center; }
.hero-orbit { position: absolute; border: 1px solid rgba(108, 43, 112, .12); border-radius: 50%; }
.orbit-one { right: -15vw; top: -22vw; width: 65vw; height: 65vw; }
.orbit-two { right: -5vw; top: -11vw; width: 45vw; height: 45vw; }
.scroll-cue {
  position: absolute; bottom: 30px; left: 50%; display: flex; gap: 12px; align-items: center;
  color: var(--ink-soft); font-size: .69rem; letter-spacing: .13em; text-decoration: none; text-transform: uppercase; transform: translateX(-50%);
}

.welcome { background: var(--white); }
.welcome-grid { display: grid; grid-template-columns: 50px 1.1fr .9fr; gap: 55px; }
.section-number { color: var(--orchid); font-family: var(--serif); font-size: 1.2rem; }
.welcome h2 { max-width: 560px; }
.welcome h2 em { color: var(--plum); }
.welcome-copy { padding-top: 44px; color: var(--ink-soft); }
.welcome-copy .drop-cap::first-letter {
  float: left; margin: 11px 9px 0 0; color: var(--plum); font-family: var(--serif); font-size: 4.5rem; line-height: .6;
}
.signature { margin-top: 30px; color: var(--ink); font-family: var(--serif); font-size: 1.35rem; font-style: italic; }
.signature span { color: var(--plum); font-size: 2rem; }

.books { background: var(--paper-warm); }
.section-heading { display: flex; justify-content: space-between; gap: 40px; align-items: end; margin-bottom: 70px; }
.section-heading h2 { margin-bottom: 0; }
.section-heading > p { max-width: 390px; margin-bottom: 7px; color: var(--ink-soft); }
.book-feature {
  display: grid; grid-template-columns: .75fr 1.25fr; min-height: 570px;
  margin-bottom: 28px; overflow: hidden; background: var(--white); box-shadow: var(--shadow);
}
.book-cover {
  display: flex; position: relative; min-height: 570px; flex-direction: column; justify-content: center;
  overflow: hidden; padding: 60px; color: white; background: var(--plum-dark);
}
.book-cover::before {
  content: ""; position: absolute; width: 420px; aspect-ratio: 1; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; top: -110px; right: -200px;
  box-shadow: 0 0 0 70px rgba(255,255,255,.025), 0 0 0 140px rgba(255,255,255,.02);
}
.book-cover strong { position: relative; font-family: var(--serif); font-size: clamp(4rem, 7vw, 6.2rem); line-height: .75; letter-spacing: -.06em; }
.cover-kicker { position: absolute; top: 50px; left: 60px; font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; }
.cover-mark { position: absolute; right: 45px; bottom: 25px; color: var(--cyan); font-family: var(--serif); font-size: 6rem; }
.book-details { display: flex; flex-direction: column; justify-content: center; padding: clamp(45px, 7vw, 95px); }
.book-details h3 { margin-bottom: 22px; font-size: clamp(3.4rem, 5vw, 5.2rem); }
.book-type, .journal-date { color: var(--plum); font-size: .67rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; }
.book-hook { color: var(--ink); font-family: var(--serif); font-size: 1.55rem; font-style: italic; line-height: 1.3; }
.book-details > p:not(.book-type, .book-hook) { color: var(--ink-soft); }
.book-details .button { align-self: flex-start; margin-top: 15px; }
.book-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.book-card { overflow: hidden; background: rgba(255,255,255,.7); }
.book-card > div:last-child { padding: 30px; }
.book-card h3 { margin-bottom: 15px; font-size: 2.2rem; line-height: 1; }
.book-card p:not(.book-type) { color: var(--ink-soft); font-size: .91rem; }
.mini-cover {
  position: relative; display: flex; min-height: 320px; flex-direction: column; justify-content: center; padding: 38px; color: white;
}
.mini-cover span { position: absolute; top: 30px; font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; }
.mini-cover strong { font-family: var(--serif); font-size: 3.5rem; line-height: .75; letter-spacing: -.04em; }
.mini-cover i { position: absolute; right: 28px; bottom: 16px; font-family: var(--serif); font-size: 4rem; font-style: normal; opacity: .75; }
.cover-dreaming { background: linear-gradient(150deg, #172940, #6f628b); }
.cover-bridges { background: linear-gradient(150deg, #513143, #b97775); }
.cover-time { background: linear-gradient(150deg, #18393e, #4b8790); }
.status-pill { display: inline-block; padding: 5px 11px; border: 1px solid var(--line); border-radius: 100px; color: var(--ink-soft); font-size: .68rem; text-transform: uppercase; }

.about { background: var(--white); }
.about-grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(50px, 9vw, 120px); align-items: center; }
.about-image { position: relative; }
.about-image::before { content: ""; position: absolute; inset: 30px -25px -25px 35px; border: 1px solid rgba(108,43,112,.26); }
.about-image img { position: relative; width: 100%; max-height: 710px; object-fit: cover; object-position: 50% 24%; filter: saturate(.75); }
.image-caption {
  position: absolute; z-index: 2; bottom: 25px; left: -26px; padding: 12px 18px;
  color: white; background: var(--plum); font-family: var(--serif); font-style: italic;
}
.about-copy h2 { margin-bottom: 30px; }
.about-copy p { color: var(--ink-soft); }
.about-copy .large-copy { color: var(--ink); font-family: var(--serif); font-size: 1.65rem; line-height: 1.4; }
details { margin-top: 34px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
summary { padding: 18px 0; color: var(--plum); cursor: pointer; font-weight: 600; list-style: none; }
summary::after { content: "+"; float: right; font-size: 1.4rem; font-weight: 400; }
details[open] summary::after { content: "−"; }
.details-copy { padding-bottom: 10px; }

.meaning { color: white; background: var(--plum-dark); text-align: center; }
.meaning-inner { max-width: 850px; }
.meaning img { width: 34px; margin: 0 auto 20px; image-rendering: auto; }
.meaning .eyebrow { color: var(--orchid); }
.meaning h2 { margin-bottom: 25px; font-size: clamp(3.2rem, 7vw, 6.8rem); letter-spacing: .01em; }
.meaning h2 span { color: var(--cyan); font-style: italic; }
.meaning p:last-child { max-width: 650px; margin: auto; color: rgba(255,255,255,.72); font-size: 1.05rem; }

.journal { background: var(--paper); }
.journal-grid { display: grid; grid-template-columns: 1.25fr .75fr; gap: 28px; }
.journal-card { min-height: 330px; padding: clamp(34px, 5vw, 60px); background: var(--white); }
.journal-card h3 { margin-bottom: 25px; }
.journal-card p:last-child { color: var(--ink-soft); }
.journal-feature { grid-row: span 2; color: white; background: var(--plum); }
.journal-feature .journal-date { color: var(--orchid); }
.journal-feature h3 { font-size: clamp(3.5rem, 5vw, 5.5rem); }
.journal-feature blockquote { margin: 40px 0; font-family: var(--serif); font-size: 1.5rem; font-style: italic; line-height: 1.4; }
.journal-feature p:last-child { color: rgba(255,255,255,.75); }

.connect { background: var(--cyan); }
.connect-card { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: end; padding: clamp(45px, 7vw, 80px); color: white; background: var(--plum-dark); box-shadow: var(--shadow); }
.connect .eyebrow { color: var(--orchid); }
.connect h2 { margin-bottom: 0; }
.connect-card > div:last-child p { color: rgba(255,255,255,.72); }
.site-footer { padding: 45px 0; background: var(--paper); }
.footer-grid { display: grid; grid-template-columns: 1fr auto auto; gap: 35px; align-items: center; }
.footer-grid > p { margin: 0; color: var(--ink-soft); font-size: .72rem; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal[data-delay="1"] { transition-delay: .12s; }
.reveal[data-delay="2"] { transition-delay: .24s; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 920px) {
  .hero-grid { grid-template-columns: 1fr; padding-top: 50px; }
  .hero-art { justify-self: center; margin-top: 35px; }
  .hero { padding-bottom: 130px; }
  .welcome-grid { grid-template-columns: 30px 1fr; }
  .welcome-copy { grid-column: 2; padding-top: 0; }
  .book-feature { grid-template-columns: 1fr; }
  .book-cover { min-height: 480px; }
  .book-grid { grid-template-columns: 1fr 1fr; }
  .book-card:last-child { grid-column: 1 / -1; }
  .about-grid { grid-template-columns: 1fr; }
  .about-image { max-width: 570px; }
  .journal-grid { grid-template-columns: 1fr 1fr; }
  .journal-feature { grid-column: 1 / -1; grid-row: auto; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > p:first-of-type { display: none; }
}

@media (max-width: 700px) {
  .shell { width: min(100% - 30px, 1180px); }
  .nav-wrap { min-height: 72px; }
  .menu-toggle { display: block; position: relative; z-index: 22; }
  .site-nav {
    position: fixed; z-index: 21; inset: 0; display: flex; flex-direction: column; justify-content: center;
    opacity: 0; visibility: hidden; background: var(--paper); transition: opacity .2s ease, visibility .2s ease;
  }
  .site-nav.open { opacity: 1; visibility: visible; }
  .site-nav a { font-family: var(--serif); font-size: 2.5rem; }
  .site-nav .nav-cta { padding: 0; border: 0; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] > span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .menu-toggle > span:not(.sr-only) { transition: transform .2s ease, opacity .2s ease; }
  .hero { padding-top: 120px; }
  .hero-grid { gap: 20px; }
  .hero h1 { font-size: clamp(3.7rem, 17vw, 5rem); }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .portrait-note { right: -8px; }
  .scroll-cue { display: none; }
  .welcome-grid { display: block; }
  .section-number { display: none; }
  .welcome-copy { padding-top: 15px; }
  .section-heading { display: block; }
  .section-heading > p { margin-top: 24px; }
  .book-cover { min-height: 430px; padding: 40px; }
  .cover-kicker { left: 40px; }
  .book-grid { grid-template-columns: 1fr; }
  .book-card:last-child { grid-column: auto; }
  .mini-cover { min-height: 390px; }
  .image-caption { left: 12px; }
  .journal-grid { grid-template-columns: 1fr; }
  .journal-feature { grid-column: auto; }
  .connect-card { grid-template-columns: 1fr; gap: 25px; }
  .footer-grid { grid-template-columns: 1fr; text-align: center; }
  .footer-brand { justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
