﻿/* ============================================================
   The Aeonveil Chronicles — Website shared layout
   Consumes the design system (ds/styles.css).
   ============================================================ */

html { scroll-behavior: smooth; }
body { background: var(--surface-page); color: var(--text-primary); overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.container { max-width: var(--container-max); margin: 0 auto; padding-inline: var(--gutter); width: 100%; }
.section { padding-block: var(--space-9); }

/* ---- Scroll reveal ---- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(22px); transition: opacity var(--duration-veil) var(--ease-gentle), transform var(--duration-veil) var(--ease-gentle); }
  .reveal.is-in { opacity: 1; transform: none; }
  .reveal[data-delay="1"] { transition-delay: 90ms; }
  .reveal[data-delay="2"] { transition-delay: 180ms; }
  .reveal[data-delay="3"] { transition-delay: 270ms; }
}

/* ============================================================
   Navigation
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: var(--z-sticky);
  transition: background var(--duration-base) var(--ease-gentle),
              border-color var(--duration-base) var(--ease-gentle),
              backdrop-filter var(--duration-base) var(--ease-gentle);
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled { background: rgba(13,19,38,0.88); backdrop-filter: blur(10px); border-bottom-color: var(--border-hairline); }
.nav__inner { display: flex; align-items: center; gap: var(--space-5); height: 76px; }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.brand img { height: 38px; }
.brand span { font-family: var(--font-display); font-size: 1.12rem; color: var(--text-heading); letter-spacing: 0.02em; white-space: nowrap; }
.nav__links { display: flex; gap: var(--space-5); margin-left: auto; }
.nav__links a {
  font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--text-secondary); padding-block: 4px;
  transition: color var(--duration-base) var(--ease-gentle);
}
.nav__links a:hover { color: var(--gold-300); }
.nav__links a.is-active { color: var(--gold-400); }
.nav__cta { margin-left: var(--space-3); }

/* Series dropdown */
.nav__item { position: relative; display: inline-flex; align-items: center; }
.nav__dropdown {
  position: absolute; top: 100%; left: 50%;
  margin-top: 10px; min-width: 250px; padding: var(--space-2);
  transform: translateX(-50%) translateY(-6px);
  background: rgba(13,19,38,0.97); backdrop-filter: blur(10px);
  border: 1px solid var(--border-hairline); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.18s var(--ease-gentle), transform 0.18s var(--ease-gentle), visibility 0.18s;
}
/* transparent bridge so the hover doesn't break over the gap */
.nav__dropdown::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 12px; }
.nav__item:hover .nav__dropdown,
.nav__item:focus-within .nav__dropdown {
  opacity: 1; visibility: visible; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav__dropdown a, .nav__dropdown .nav__dropdown-item {
  display: flex; align-items: baseline; gap: 0.7em;
  font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: 0.03em;
  text-transform: none; color: var(--text-secondary);
  padding: 8px 12px; border-radius: var(--radius-sm); white-space: nowrap;
  transition: color var(--duration-base) var(--ease-gentle), background var(--duration-base) var(--ease-gentle);
}
.nav__dropdown a:hover { color: var(--gold-300); background: rgba(201,162,75,0.08); }
.nav__dropdown .nav__vol { font-family: var(--font-hero); color: var(--gold-400); min-width: 1.8em; text-align: center; }
.nav__dropdown .is-tba { color: var(--text-muted); font-style: italic; }
.nav__dropdown .is-tba .nav__vol { color: var(--text-muted); }
.nav__burger { display: none; background: none; border: 0; color: var(--text-secondary); cursor: pointer; padding: 8px; margin-left: auto; }

/* ============================================================
   Page hero (full-bleed)
   ============================================================ */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; background-size: cover; background-position: 58% 22%; overflow: hidden; }
.hero__veil { position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(58% 50% at 50% 46%, rgba(8,13,28,0.55), rgba(8,13,28,0) 70%),
    linear-gradient(to bottom, rgba(8,13,28,0.5) 0%, rgba(8,13,28,0.22) 32%, rgba(8,13,28,0.55) 74%, rgba(8,13,28,0.97) 100%); }
.hero__stars { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.hero__inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-5); padding-block: var(--space-10); }
.hero__crest { height: 132px; filter: drop-shadow(0 0 30px rgba(201,162,75,0.28)); }
.hero__eyebrow { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); }
.hero__title { font-family: var(--font-hero); color: var(--text-heading); font-size: clamp(3.2rem, 8vw, 7rem); line-height: 0.98; letter-spacing: -0.01em; margin: 0; text-shadow: 0 2px 30px rgba(8,13,28,0.7), 0 1px 8px rgba(8,13,28,0.6); }
.hero__eyebrow, .hero__lead { text-shadow: 0 1px 14px rgba(8,13,28,0.75); }
.hero__lead { font-family: var(--font-body); font-style: italic; font-size: var(--text-md); line-height: 1.5; color: var(--text-secondary); max-width: 48ch; margin: 0 auto; }
.hero__cta { display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center; margin-top: var(--space-2); }
.hero__scroll { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); }
.hero__scroll-line { width: 1px; height: 38px; background: linear-gradient(var(--gold-500), transparent); }
@media (prefers-reduced-motion: no-preference) {
  .hero__scroll-line { animation: scrollpulse 2.4s var(--ease-gentle) infinite; transform-origin: top; }
  @keyframes scrollpulse { 0%,100% { opacity: 0.4; transform: scaleY(0.7); } 50% { opacity: 1; transform: scaleY(1); } }
}

/* Page sub-hero (shorter, for inner pages) */
.page-hero { position: relative; background: var(--navy-1000); padding-block: var(--space-10) var(--space-8); border-bottom: 1px solid var(--border-hairline); }
.page-hero__inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-3); padding-top: 76px; }
.page-hero__eyebrow { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); }
.page-hero__title { font-family: var(--font-hero); color: var(--text-heading); font-size: clamp(2.4rem, 5vw, 4.5rem); line-height: 1.0; margin: 0; }
.page-hero__sub { font-family: var(--font-body); font-style: italic; font-size: var(--text-md); color: var(--text-secondary); max-width: 50ch; margin: 0; }

/* ============================================================
   Section heading
   ============================================================ */
.head { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-3); margin-bottom: var(--space-7); }
.head--left { align-items: flex-start; text-align: left; }
.head__eyebrow { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); }
.head__title { font-family: var(--font-display); font-size: var(--text-2xl); line-height: var(--leading-snug); color: var(--text-heading); margin: 0; }
.head__sub { font-family: var(--font-body); font-style: italic; font-size: var(--text-md); color: var(--text-secondary); max-width: 52ch; margin: 0; }
.head__flourish { width: 182px; height: 42px; background: center/contain no-repeat url("ds/assets/ornaments/scene-splitter-gold.png"); }

/* ============================================================
   Product grid
   ============================================================ */
.grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }

/* ============================================================
   Synopsis (homepage split)
   ============================================================ */
.synopsis { background: var(--navy-1000); }
.synopsis__grid { display: grid; grid-template-columns: 0.85fr 1fr; gap: var(--space-8); align-items: center; }
.synopsis__art { position: relative; display: flex; justify-content: center; }
.synopsis__glow { position: absolute; inset: 4% 14%; border-radius: 50%; background: radial-gradient(circle, rgba(201,162,75,0.26), transparent 64%); filter: blur(26px); }
.synopsis__cover { position: relative; z-index: 1; width: min(380px, 90%); object-fit: contain; border-radius: var(--radius-sm); box-shadow: var(--shadow-xl); }
.synopsis__cover--mockup { transform: none; box-shadow: none; }
.synopsis__copy { display: flex; flex-direction: column; gap: var(--space-4); align-items: flex-start; }
.synopsis__copy .lead { font-family: var(--font-body); font-style: italic; font-size: var(--text-lg); line-height: 1.45; color: var(--text-heading); margin: 0; }
.synopsis__copy p { font-family: var(--font-body); font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; max-width: 54ch; }
.synopsis__stats { display: flex; gap: var(--space-6); margin-top: var(--space-2); }
.stat { display: flex; flex-direction: column; gap: 2px; }
.stat__n { font-family: var(--font-hero); font-size: var(--text-xl); color: var(--gold-300); }
.stat__l { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); }

/* ============================================================
   Quote band
   ============================================================ */
.quote { background: var(--navy-1000); }
.quote__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-4); }
.quote__text { font-family: var(--font-display); font-size: clamp(1.7rem, 3vw, 2.7rem); line-height: 1.3; color: var(--text-heading); max-width: 24ch; margin: 0; }
.quote__cite { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-gold); }

/* ============================================================
   Series / Cycle timeline
   ============================================================ */
.cycle { position: relative; background-size: cover; background-position: center; }
.cycle__veil { position: absolute; inset: 0; background: rgba(8,13,28,0.72); }
.cycle__inner { position: relative; z-index: 1; }
.timeline { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.tl { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; padding: var(--space-6) var(--space-4); border: 1px solid var(--border-hairline); border-radius: var(--radius-md); background: rgba(13,19,38,0.5); }
.tl__num { font-family: var(--font-hero); font-size: var(--text-2xl); color: var(--gold-400); }
.tl__title { font-family: var(--font-display); font-size: var(--text-lg); color: var(--text-heading); margin: 0; }
.tl__status { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); }

/* ============================================================
   Newsletter / Keepers
   ============================================================ */
.keepers { position: relative; background-size: cover; background-position: center; overflow: hidden; }
.keepers__veil { position: absolute; inset: 0; background: rgba(8,13,28,0.8); }
.keepers__inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-5); padding-block: var(--space-10); }
.keepers__title { font-family: var(--font-display); font-size: clamp(2rem,4vw,3.2rem); color: var(--text-heading); margin: 0; }
.keepers__sub { font-family: var(--font-body); font-style: italic; font-size: var(--text-md); color: var(--text-secondary); margin: 0; max-width: 44ch; }
.signup { display: flex; gap: var(--space-3); width: min(520px, 100%); margin-top: var(--space-2); flex-wrap: wrap; }
.signup .aev-input { flex: 1; min-width: 220px; }
.signup__note { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: 0.06em; color: var(--text-muted); }

/* ============================================================
   Footer
   ============================================================ */
.footer { border-top: 1px solid var(--border-hairline); background: var(--navy-1000); }
.footer__top { display: grid; grid-template-columns: 1.2fr 2fr; gap: var(--space-8); padding-block: var(--space-8); }
.footer__brand { display: flex; flex-direction: column; gap: var(--space-4); align-items: flex-start; }
.footer__brand p { font-family: var(--font-body); font-style: italic; color: var(--text-secondary); margin: 0; max-width: 38ch; }
.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.footer__cols h4 { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); margin: 0 0 var(--space-3); }
.footer__cols a { display: block; font-family: var(--font-body); font-size: var(--text-base); color: var(--text-secondary); padding-block: 6px; cursor: pointer; }
.footer__cols a:hover { color: var(--gold-300); }
.footer__base { display: flex; justify-content: space-between; gap: var(--space-4); padding-block: var(--space-5); border-top: 1px solid var(--divider); font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: 0.06em; color: var(--text-muted); flex-wrap: wrap; }

/* ============================================================
   Shop page
   ============================================================ */
.shop-filters { display: flex; gap: var(--space-3); justify-content: center; margin-bottom: var(--space-7); flex-wrap: wrap; }
.product-badge-strip { display: flex; gap: var(--space-3); margin-bottom: var(--space-4); }
.shipping-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-8); padding-top: var(--space-7); border-top: 1px solid var(--divider); }
.ship-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-2); }
.ship-item svg { color: var(--gold-400); }
.ship-item h4 { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-heading); margin: 0; }
.ship-item p { font-family: var(--font-body); font-size: var(--text-sm); color: var(--text-secondary); margin: 0; max-width: 24ch; }

/* ============================================================
   Book detail page
   ============================================================ */
/* Navy section with thin gold separation lines + faint gold glow top & bottom. */
.book-detail { background: var(--navy-900); border-top: 1px solid rgba(201,162,75,0.28); border-bottom: 1px solid rgba(201,162,75,0.28); }

.book-layout { display: grid; grid-template-columns: 0.85fr 1fr; gap: var(--space-9); align-items: start; padding-top: 110px; padding-bottom: var(--space-9); }
.book-art { position: relative; }
.book-art__glow { position: absolute; inset: 8% 10%; border-radius: 50%; background: radial-gradient(circle, rgba(201,162,75,0.22), transparent 60%); filter: blur(32px); }
.book-art__img { position: relative; z-index: 1; width: 100%; aspect-ratio: 3/4; object-fit: cover; border-radius: var(--radius-sm); box-shadow: var(--shadow-xl); }
.book-art__placeholder { position: relative; z-index: 1; width: 100%; aspect-ratio: 3/4; border-radius: var(--radius-sm); background: var(--navy-800); border: 1px dashed var(--border-muted); box-shadow: var(--shadow-xl); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); }
.book-art__placeholder img { height: 84px; opacity: 0.5; }
.book-art__placeholder span { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); }

/* Interactive 3D book */
.book3d { position: relative; z-index: 1; width: 100%; aspect-ratio: 3/4; }
.book3d canvas { display: block; width: 100% !important; height: 100% !important; cursor: grab; touch-action: pan-y; }
.book3d.is-dragging canvas { cursor: grabbing; }
/* once the 3D scene is live, hide the flat fallback */
.book3d.is-ready .book3d__fallback { display: none; }
.book3d__fallback { box-shadow: var(--shadow-xl); }
.book-info { display: flex; flex-direction: column; gap: var(--space-5); }
.book-info__eyebrow { font-family: var(--font-meta); font-size: var(--text-sm); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); }
.book-info__title { font-family: var(--font-hero); font-size: clamp(2.8rem, 5vw, 4.8rem); line-height: 0.98; color: var(--text-heading); margin: 0; }
.book-info__lead { font-family: var(--font-body); font-style: italic; font-size: var(--text-lg); line-height: 1.45; color: var(--text-heading); margin: 0; }
.book-info__body { font-family: var(--font-body); font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; }
.book-info__stats { display: flex; gap: var(--space-6); padding-block: var(--space-4); border-block: 1px solid var(--divider); }
.edition-tabs { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.edition-panel { display: flex; flex-direction: column; gap: var(--space-4); padding: var(--space-5); background: var(--surface-card); border: 1px solid var(--border-hairline); border-radius: var(--radius-md); box-shadow: var(--shadow-inset-gilt); }
.edition-panel__price { font-family: var(--font-body); font-size: var(--text-xl); color: var(--gold-300); }
.edition-panel__price s { color: var(--text-muted); font-size: var(--text-base); margin-right: 0.4em; }
.edition-panel__detail { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: 0.06em; color: var(--text-muted); line-height: 1.7; }
.edition-panel__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

/* Muted starfield host (e.g. characters section) */
.starfield-host { position: relative; overflow: hidden; }
.starfield-host > .container { position: relative; z-index: 1; }
.starfield { position: absolute; inset: 0; z-index: 0; pointer-events: none; }

/* Reviews */
.reviews { background: var(--navy-1000); }
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.review--centered { grid-column: 2; }
.review { padding: var(--space-5); background: var(--surface-card); border-radius: var(--radius-md); box-shadow: var(--shadow-inset-gilt), var(--shadow-md); display: flex; flex-direction: column; gap: var(--space-3); }
.review__stars { color: var(--gold-500); display: flex; gap: 3px; }
.review__text { font-family: var(--font-body); font-style: italic; font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; flex: 1; }
.review__author { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-gold); }

/* Character cards gently grow on hover for readability */
#characters .review { position: relative; transform-origin: center; transition: transform 0.3s var(--ease-gentle), box-shadow 0.3s var(--ease-gentle), z-index 0s; }
#characters .review:hover { transform: scale(1.05); z-index: 3; box-shadow: var(--shadow-inset-gilt), var(--shadow-xl); }

.char-portrait { width: 100%; aspect-ratio: 3/4; overflow: hidden; border-radius: 4px; margin-bottom: var(--space-3); border: 1px solid var(--divider); }
.char-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }

/* Astral cursor trail overlay */
.cursor-trail { position: fixed; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 9999; }

/* Excerpt */
.excerpt { background: var(--surface-page); }
.excerpt__prose { font-family: var(--font-body); font-size: var(--text-md); line-height: var(--leading-relaxed); color: var(--text-secondary); max-width: var(--container-prose); margin-inline: auto; }
.excerpt__prose p { margin: 0 0 1.4em; }
.excerpt__prose p:first-child::first-letter { font-family: var(--font-hero); font-size: 3.8em; line-height: 0.8; float: left; margin-right: 0.12em; margin-top: 0.08em; color: var(--gold-400); }

/* ============================================================
   About page
   ============================================================ */
.author-grid { display: grid; grid-template-columns: 0.8fr 1fr; gap: var(--space-8); align-items: center; }
.author-photo { position: relative; }
.author-photo__glow { position: absolute; inset: 6%; border-radius: 50%; background: radial-gradient(circle, rgba(201,162,75,0.18), transparent 60%); filter: blur(28px); }
.author-photo__img { position: relative; z-index: 1; width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-xl); }
.author-bio { display: flex; flex-direction: column; gap: var(--space-4); }
.author-bio__name { font-family: var(--font-hero); font-size: clamp(2.2rem, 4vw, 3.8rem); color: var(--text-heading); margin: 0; line-height: 1; }
.author-bio p { font-family: var(--font-body); font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; max-width: 54ch; }
.author-bio p.lead { font-style: italic; font-size: var(--text-md); color: var(--text-heading); }

.lore-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.lore-card { padding: var(--space-6); background: var(--surface-card); border: 1px solid var(--border-hairline); border-radius: var(--radius-md); box-shadow: var(--shadow-inset-gilt), var(--shadow-md); }
/* Lore cards gently grow on hover for readability */
.lore-card { position: relative; transform-origin: center; transition: transform 0.3s var(--ease-gentle), box-shadow 0.3s var(--ease-gentle), z-index 0s; }
.lore-card:hover { transform: scale(1.05); z-index: 3; box-shadow: var(--shadow-inset-gilt), var(--shadow-xl); }
.lore-card__label { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-gold); margin-bottom: var(--space-3); display: block; }
.lore-card__title { font-family: var(--font-display); font-size: var(--text-lg); color: var(--text-heading); margin: 0 0 var(--space-3); }
.lore-card p { font-family: var(--font-body); font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; }

.arc { background: var(--navy-1000); }
.arc-list { display: flex; flex-direction: column; gap: 0; max-width: 680px; margin-inline: auto; }
.arc-item { display: grid; grid-template-columns: 56px 1fr; gap: var(--space-4); align-items: start; padding-block: var(--space-5); border-bottom: 1px solid var(--divider); }
.arc-item:last-child { border-bottom: 0; }
.arc-num { font-family: var(--font-hero); font-size: var(--text-xl); color: var(--gold-400); padding-top: 2px; }
.arc-body__title { font-family: var(--font-display); font-size: var(--text-lg); color: var(--text-heading); margin: 0 0 4px; }
.arc-body__sub { font-family: var(--font-meta); font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); }

/* ============================================================
   Row dividers + navy-row edge glow
   ============================================================ */
/* simple golden hairline between consecutive rows */
.row-edge { border-top: 1px solid rgba(201,162,75,0.28); }
/* faint gold glow bleeding in from the top & bottom of plain-navy rows */
.row-glow { position: relative; }
.row-glow::before,
.row-glow::after { content: ""; position: absolute; left: 0; right: 0; height: 140px; pointer-events: none; z-index: 0; }
.row-glow::before { top: 0; background: linear-gradient(to bottom, rgba(201,162,75,0.08), transparent); }
.row-glow::after { bottom: 0; background: linear-gradient(to top, rgba(201,162,75,0.08), transparent); }
.row-glow > .container { position: relative; z-index: 1; }

/* ============================================================
   Contact section
   ============================================================ */
.contact-section { position: relative; min-height: 100vh; display: flex; align-items: center; background-size: cover; background-repeat: no-repeat; background-position: center; padding-block: var(--space-9); }
.contact-section__veil { position: absolute; inset: 0; background: rgba(8,12,28,0.35); pointer-events: none; }
/* width tracks the parchment area of the (cover) image, capped for big screens */
.contact-inner { position: relative; z-index: 1; width: min(52vw, 660px); margin-inline: auto; display: flex; flex-direction: column; align-items: center; }
.contact-header { text-align: center; margin-bottom: var(--space-5); }
.contact-title {
  display: block;
  font-family: 'Great Vibes', cursive;
  font-size: clamp(3.5rem, 7vw, 6rem);
  line-height: 1;
  color: #1a1208;
}
.contact-intro { font-family: 'Great Vibes', cursive; font-size: clamp(1.5rem, 2.8vw, 2.1rem); color: #1a1208; line-height: 1.25; margin: var(--space-2) 0 0; }

.contact-form { width: 100%; display: flex; flex-direction: column; gap: var(--space-4); }
.contact-field { display: flex; flex-direction: column; gap: 0; }
.contact-field input,
.contact-field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(26,18,8,0.28);
  border-radius: 0;
  padding: var(--space-2) 0;
  font-family: 'Cormorant Garamond', var(--font-body);
  font-style: italic;
  font-size: var(--text-md);
  color: #1a1208;
  outline: none;
  resize: none;
  width: 100%;
  transition: border-color 0.2s;
}
.contact-field input::placeholder,
.contact-field textarea::placeholder {
  font-family: 'Cormorant Garamond', var(--font-body);
  font-style: italic;
  color: #1a1208;
  opacity: 0.9;
}
.contact-field input:focus,
.contact-field textarea:focus { border-bottom-color: rgba(26,18,8,0.55); }

.contact-submit {
  align-self: flex-start;
  background: transparent;
  border: 1px solid rgba(26,18,8,0.28);
  border-radius: 0;
  padding: var(--space-2) var(--space-5);
  font-family: 'Cormorant Garamond', var(--font-body);
  font-style: italic;
  font-size: var(--text-md);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1a1208;
  cursor: pointer;
  transition: border-color 0.2s, opacity 0.2s;
  margin-top: var(--space-2);
}
.contact-submit:hover { border-color: rgba(26,18,8,0.55); opacity: 0.75; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 940px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: inline-flex; }
  .nav.is-open .nav__links {
    display: flex; position: absolute; top: 76px; left: 0; right: 0;
    flex-direction: column; gap: 0; background: rgba(13,19,38,0.97);
    border-bottom: 1px solid var(--border-hairline);
    padding: var(--space-4) var(--gutter);
  }
  /* Series dropdown shows inline/expanded on mobile (no hover) */
  .nav__item { display: flex; flex-direction: column; align-items: flex-start; width: 100%; }
  .nav__dropdown {
    position: static; transform: none; margin-top: 4px; min-width: 0;
    opacity: 1; visibility: visible; pointer-events: auto;
    background: transparent; backdrop-filter: none; border: none; box-shadow: none;
    padding: 0 0 var(--space-2) var(--space-3);
  }
  .nav__dropdown::before { display: none; }
  .synopsis__grid, .book-layout, .author-grid { grid-template-columns: 1fr; }
  .contact-section { min-height: 0; background-size: cover; }
  .book-layout { padding-top: 96px; }
  .grid, .grid--3 { grid-template-columns: repeat(2, 1fr); }
  .timeline { grid-template-columns: repeat(2, 1fr); }
  .review-grid, .lore-grid { grid-template-columns: 1fr; }
  .review--centered { grid-column: auto; }
  .footer__top { grid-template-columns: 1fr; }
  .shipping-strip { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .grid, .grid--3 { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
  .synopsis__stats, .book-info__stats { gap: var(--space-4); }
  .timeline { grid-template-columns: 1fr 1fr; }
}
