@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Dancing+Script:wght@400;600&family=Montserrat:wght@400;600&display=swap');

/* ============================================================
   Angie Hartwell — Design System Tokens
   ============================================================ */

:root {
  /* -------- base palette (locked) -------- */
  --ah-near-black: #0B0B0B;
  --ah-cream:      #F4F0E6;
  --ah-gold:       #D4AF37;
  --ah-crimson:    #8B0000;
  --ah-cinnabar:   #C21807;

  /* -------- semantic — dark mode (default) -------- */
  --bg:       var(--ah-near-black);
  --bg-soft:  #141414;
  --fg:       var(--ah-cream);
  --fg-muted: rgba(244, 240, 230, 0.62);
  --accent:   var(--ah-gold);
  --hot:      var(--ah-cinnabar);
  --reserved: var(--ah-crimson);
  --rule:     rgba(244, 240, 230, 0.12);

  /* -------- typography -------- */
  --ah-serif:  'Cinzel', 'Didot', 'Bodoni 72', serif;
  --ah-sans:   'Montserrat', system-ui, -apple-system, sans-serif;
  --ah-script: 'Dancing Script', cursive;

  --h1: 700 3.25rem/1.05 var(--ah-serif);
  --h2: 600 2.25rem/1.15 var(--ah-serif);
  --h3: 500 1.5rem/1.2 var(--ah-serif);
  --eyebrow: 600 0.8125rem/1.3 var(--ah-sans);
  --body: 400 1.0625rem/1.7 var(--ah-sans);
  --body-lg: 400 1.1875rem/1.7 var(--ah-sans);
  --small: 400 0.875rem/1.55 var(--ah-sans);
  --btn: 600 0.875rem/1 var(--ah-sans);
  --script: 400 2rem/1.3 var(--ah-script);

  --track-h1: 0.12em;
  --track-h2: 0.10em;
  --track-h3: 0.10em;
  --track-eyebrow: 0.24em;
  --track-btn: 0.14em;

  /* -------- spacing (locked) -------- */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 16px;
  --s-4: 24px;
  --s-5: 32px;
  --s-6: 48px;
  --s-7: 64px;
  --s-8: 80px;
  --s-9: 120px;
  --s-10: 160px;

  /* -------- layout -------- */
  --max-content: 1200px;
  --max-reading: 680px;
  --gutter: 32px;

  /* -------- motion -------- */
  --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
  --dur-fast: 150ms;
  --dur-slow: 300ms;

  /* -------- radii & shadow -------- */
  --radius: 0;
  --shadow-gold: 0 0 12px rgba(212, 175, 55, 0.3);
  --shadow-book: 0 30px 60px rgba(0, 0, 0, 0.5);
}

[data-mode="light"] {
  --bg:       var(--ah-cream);
  --bg-soft:  #ece7d8;
  --fg:       var(--ah-near-black);
  --fg-muted: rgba(11, 11, 11, 0.62);
  --accent:   var(--ah-crimson);
  --hot:      var(--ah-cinnabar);
  --reserved: var(--ah-gold);
  --rule:     rgba(11, 11, 11, 0.14);
}

/* ============================================================
   Base
   ============================================================ */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; padding: 0;
  background: var(--bg); color: var(--fg);
  font: var(--body);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, .ah-h1 { font: var(--h1); letter-spacing: var(--track-h1); text-transform: uppercase; margin: 0 0 var(--s-4) 0; }
h2, .ah-h2 { font: var(--h2); letter-spacing: var(--track-h2); text-transform: uppercase; margin: 0 0 var(--s-4) 0; }
h3, .ah-h3 { font: var(--h3); letter-spacing: var(--track-h3); text-transform: uppercase; margin: 0 0 var(--s-3) 0; }
p { margin: 0 0 var(--s-4) 0; }
p:last-child { margin-bottom: 0; }

.ah-eyebrow { font: var(--eyebrow); letter-spacing: var(--track-eyebrow); text-transform: uppercase; color: var(--hot); display: inline-block; margin-bottom: var(--s-4); position: relative; padding-left: 40px; font-size: 0.875rem; }
.ah-eyebrow::before { content: ""; position: absolute; left: 0; top: 50%; width: 24px; height: 1px; background: var(--hot); transform: translateY(-50%); }
/* Centered eyebrow (inside centered containers or .layout-book-feature / .layout-quote / .newsletter-block) — drop the leading hairline; it looks stranded when there's no left-anchored content. */
[style*="text-align: center"] .ah-eyebrow,
[style*="text-align:center"]  .ah-eyebrow,
.layout-book-feature .ah-eyebrow,
.layout-quote .ah-eyebrow,
.newsletter-block .ah-eyebrow {
  padding-left: 0;
}
[style*="text-align: center"] .ah-eyebrow::before,
[style*="text-align:center"]  .ah-eyebrow::before,
.layout-book-feature .ah-eyebrow::before,
.layout-quote .ah-eyebrow::before,
.newsletter-block .ah-eyebrow::before {
  display: none;
}
.ah-script  { font: var(--script); color: var(--hot); }
.ah-small   { font: var(--small); color: var(--fg-muted); }
.ah-lede    { font: var(--body-lg); margin-bottom: var(--s-5); color: var(--fg); }

a { color: var(--accent); text-decoration: none; transition: all var(--dur-fast) var(--ease); }
a:hover { text-decoration: underline; filter: brightness(1.08); }

/* Buttons */
.ah-btn-container { display: flex; gap: var(--s-3); flex-wrap: wrap; margin-top: var(--s-5); align-items: center; }
.ah-btn {
  display: inline-flex; align-items: center; justify-content: center;
  font: var(--btn); letter-spacing: var(--track-btn); text-transform: uppercase;
  padding: 16px 28px; border: none; cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  min-height: 48px; text-decoration: none;
}
.ah-btn-primary { background: var(--accent); color: var(--ah-near-black); }
[data-mode="light"] .ah-btn-primary { color: var(--ah-cream); }
.ah-btn-primary:hover { filter: brightness(1.08); box-shadow: var(--shadow-gold); text-decoration: none; }
.ah-btn-primary:active { transform: scale(0.97); }

.ah-btn-ghost { background: transparent; color: var(--fg); border: 2px solid var(--fg); }
.ah-btn-ghost:hover { background: var(--fg); color: var(--bg); text-decoration: none; }

/* Forms */
input, textarea, select {
  width: 100%; padding: 16px;
  background: var(--bg); color: var(--fg);
  border: 1px solid var(--rule); font: var(--body);
  transition: border-color var(--dur-fast);
  min-height: 52px;
  margin: 0;
}
input:focus, textarea:focus, select:focus { outline: none; border-color: var(--accent); }
textarea { resize: vertical; min-height: 160px; line-height: 1.6; }

/* ============================================================
   Layout
   ============================================================ */
.container {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.reading-width {
  max-width: var(--max-reading);
  margin: 0 auto;
}

/* Consistent vertical rhythm: each <section> owns its own padding.
   We DON'T use !important here — many pages use intentional inline overrides like
   `padding-top: 0` to flush two related sections together. Respect those.
   We only apply defaults where nothing is set. */
main > section { padding: var(--s-9) 0; }

/* When a section also has `.container`, the `.container` rule (`padding: 0 var(--gutter)`)
   overrides our vertical rule with the same specificity but comes later. Re-apply vertical
   padding at higher specificity for these compound-class cases. */
main > section.container,
main > section.layout-hero,
main > section.layout-book-feature,
main > section.newsletter-block {
  padding-top: var(--s-9);
  padding-bottom: var(--s-9);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
main > section.layout-book-feature,
main > section.newsletter-block,
main > section.layout-quote {
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 1023px) {
  main > section { padding: var(--s-8) 0; }
  main > section.container,
  main > section.layout-hero,
  main > section.layout-book-feature,
  main > section.newsletter-block {
    padding-top: var(--s-8);
    padding-bottom: var(--s-8);
  }
}
@media (max-width: 767px)  {
  main > section { padding: var(--s-7) 0; }
  main > section.container,
  main > section.layout-hero,
  main > section.layout-book-feature,
  main > section.newsletter-block {
    padding-top: var(--s-7);
    padding-bottom: var(--s-7);
  }
}

/* Reset heading top-margin so section padding owns the gap */
section h1, section h2, section h3,
section .ah-h1, section .ah-h2, section .ah-h3 { margin-top: 0; }

/* ============================================================
   Header & Nav
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 40;
  padding: var(--s-3) 0;
  background: color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}
.site-header .container { display: flex; justify-content: space-between; align-items: center; gap: var(--s-5); }
.site-logo {
  font: 700 1.125rem var(--ah-serif);
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--fg); text-decoration: none;
  white-space: nowrap;
}
.site-logo::after { content: "♠"; color: var(--hot); margin-left: 6px; letter-spacing: 0; }
.site-logo:hover { text-decoration: none; color: var(--accent); }

.site-nav ul { list-style: none; display: flex; gap: 36px; margin: 0; padding: 0; }
.site-nav a {
  color: var(--fg); font: var(--btn);
  text-transform: uppercase; letter-spacing: 0.18em;
  font-size: 0.75rem; font-weight: 600;
  padding: 6px 0; position: relative;
}
.site-nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: var(--accent); transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-fast) var(--ease);
}
.site-nav a:hover { color: var(--accent); text-decoration: none; }
.site-nav a:hover::after { transform: scaleX(1); }
.nav-toggle, .nav-toggle-label { display: none; }

@media (max-width: 767px) {
  .nav-toggle-label { display: block; cursor: pointer; width: 30px; height: 20px; position: relative; z-index: 11; }
  .nav-toggle-label span, .nav-toggle-label span::before, .nav-toggle-label span::after {
    display: block; background: var(--fg); height: 2px; position: absolute; width: 100%;
    transition: all var(--dur-fast);
  }
  .nav-toggle-label span { top: 9px; }
  .nav-toggle-label span::before { content: ''; top: -8px; }
  .nav-toggle-label span::after  { content: ''; bottom: -8px; }
  .site-nav {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--bg); border-bottom: 1px solid var(--rule);
    display: none; z-index: 10; padding: var(--s-4) 0;
  }
  .site-nav ul { flex-direction: column; align-items: center; gap: var(--s-3); }
  .nav-toggle:checked ~ .site-nav { display: block; }
  .nav-toggle:checked ~ .nav-toggle-label span { background: transparent; }
  .nav-toggle:checked ~ .nav-toggle-label span::before { transform: rotate(45deg); top: 0; }
  .nav-toggle:checked ~ .nav-toggle-label span::after  { transform: rotate(-45deg); bottom: 0; }
  .site-header { position: sticky; }
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
  padding: var(--s-8) 0 var(--s-5);
  border-top: 1px solid var(--rule);
}
.site-footer > .container {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr auto;
  gap: var(--s-7);
  align-items: start;
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--rule);
  text-align: left;
}
.site-footer > .container > div:first-child {
  margin: 0 !important;
  display: flex;
  align-items: center;
  gap: 10px;
}
.site-footer > .container > div:first-child > div:first-child {
  font: 700 1rem var(--ah-serif) !important;
  letter-spacing: 0.22em !important;
  color: var(--fg) !important;
  margin-bottom: 0 !important;
}
.site-footer > .container > div:first-child > div:last-child {
  color: var(--hot) !important;
  font-size: 18px !important;
  line-height: 1 !important;
}
.footer-nav ul {
  list-style: none; display: flex; flex-direction: column;
  gap: var(--s-2); margin: 0; padding: 0;
  justify-content: flex-start; text-align: left;
}
.footer-nav a {
  color: var(--fg); font: var(--body);
  font-size: 0.875rem; text-transform: none; letter-spacing: 0.02em;
}
.footer-nav a:hover { color: var(--accent); }
.site-footer .social-links {
  margin: 0; display: flex; gap: var(--s-3); justify-content: flex-start;
}
.site-footer .social-links a {
  color: var(--fg);
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--rule);
  transition: all var(--dur-fast) var(--ease);
}
.site-footer .social-links a:hover { border-color: var(--accent); color: var(--accent); }

/* "power looks good on you" tagline bar — normalize the inline-styled wrapper */
.site-footer > div:nth-of-type(2) {
  background: var(--bg) !important;
  padding: var(--s-6) 0 !important;
  border: 0 !important;
  border-top: 1px solid var(--rule) !important;
  margin: 0 !important;
  text-align: center;
}
.site-footer > div:nth-of-type(2) > .container {
  font: 400 1.75rem var(--ah-script) !important;
  color: var(--hot) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-align: center;
}
.site-footer > .container:last-child {
  display: block;
  border: 0;
  padding-top: var(--s-4);
  padding-bottom: 0;
  text-align: center;
}
.copyright { color: var(--fg-muted); font: var(--small); letter-spacing: 0.08em; text-transform: uppercase; font-size: 0.75rem; margin: 0; }

@media (max-width: 1023px) {
  .site-footer > .container {
    grid-template-columns: 1fr 1fr;
    gap: var(--s-6);
  }
  .site-footer > .container > div:first-child { grid-column: 1 / -1; }
  .site-footer .social-links { grid-column: 1 / -1; justify-content: flex-start; }
}
@media (max-width: 560px) {
  .site-footer > .container { grid-template-columns: 1fr; text-align: center; }
  .footer-nav ul { align-items: center; }
  .site-footer .social-links { justify-content: center; }
}

/* ============================================================
   Signature Layouts
   ============================================================ */

/* 1. Hero — asymmetric, portrait anchored */
.layout-hero {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-9);
  align-items: center;
  min-height: clamp(480px, 72vh, 720px);
}
.layout-hero-content { max-width: 560px; }
.layout-hero-content .ah-lede { max-width: 480px; }
.layout-hero-img {
  position: relative;
}
.layout-hero-img img {
  width: 100%;
  max-width: 460px;
  aspect-ratio: 4/5;
  object-fit: cover;
  object-position: 50% 25%;
  display: block;
  margin: 0 auto;
  box-shadow: var(--shadow-book);
}

/* Tablet: hero stays 2-col but tightens up so the portrait doesn't clip */
@media (max-width: 1023px) and (min-width: 769px) {
  .layout-hero {
    grid-template-columns: 1fr 1fr;
    gap: var(--s-7);
    min-height: 0;
  }
  .layout-hero-img img { max-width: 360px; }
}

@media (max-width: 768px) {
  .layout-hero {
    grid-template-columns: 1fr;
    gap: var(--s-6);
    text-align: left;
    min-height: 0;
  }
  .layout-hero-img { order: -1; }
  .layout-hero-img img { max-width: 380px; }
  .layout-hero .ah-btn-container { justify-content: flex-start; }
}
@media (max-width: 560px) {
  .layout-hero { text-align: center; }
  .layout-hero-content { margin: 0 auto; }
  .layout-hero .ah-eyebrow { display: inline-block; }
  .layout-hero .ah-btn-container { justify-content: center; }
}

/* 2. Quote Block — show-stopper with cinnabar hairlines */
.layout-quote {
  text-align: center;
  background-color: var(--ah-near-black);
  position: relative;
}
.layout-quote::before,
.layout-quote::after {
  content: "";
  position: absolute; left: 50%;
  transform: translateX(-50%);
  width: 1px; height: var(--s-7);
  background: var(--hot);
}
.layout-quote::before { top: 0; }
.layout-quote::after  { bottom: 0; }
.layout-quote > .container { max-width: 920px; }
.layout-quote blockquote {
  margin: 0;
  font: 500 clamp(1.5rem, 3.2vw, 2.5rem)/1.3 var(--ah-serif);
  letter-spacing: 0.04em;
  color: var(--fg);
  text-transform: uppercase;
}
.layout-quote blockquote::before {
  content: "♠";
  display: block;
  color: var(--hot);
  font-size: 2rem;
  margin-bottom: var(--s-5);
  letter-spacing: 0;
}
.layout-quote .attribution {
  display: block;
  font: italic 400 0.75rem/1.5 var(--ah-sans);
  color: var(--fg-muted);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-top: var(--s-5);
}

/* 3. Book Feature — centered, generous */
.layout-book-feature { text-align: center; }
.layout-book-feature > .container {
  max-width: 680px;
}
.layout-book-feature img {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 2/3;
  object-fit: cover;
  height: auto;
  box-shadow: var(--shadow-book);
  margin-bottom: var(--s-6);
}
.gold-divider {
  width: 64px; height: 1px;
  background: var(--accent);
  margin: 0 auto var(--s-5) auto;
}
.layout-book-feature h2,
.layout-book-feature h3 { margin-bottom: var(--s-4); }
.layout-book-feature .ah-lede { margin-left: auto; margin-right: auto; max-width: 560px; }
.layout-book-feature .ah-btn-container { justify-content: center; margin-top: var(--s-5); }

/* ============================================================
   Book Grid
   ============================================================ */
.book-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-7) var(--s-6);
  max-width: 1100px;
  margin: 0 auto;
}
.book-card {
  text-align: center;
  display: flex; flex-direction: column;
  align-items: center;
}
.book-card > a:first-child {
  display: block; width: 100%;
  max-width: 300px; margin: 0 auto var(--s-5);
  transition: transform var(--dur-slow) var(--ease);
}
.book-card > a:first-child:hover { transform: translateY(-6px); }
.book-card img {
  width: 100%;
  max-width: 300px;
  aspect-ratio: 2/3;
  object-fit: cover;
  height: auto;
  box-shadow: var(--shadow-book);
  margin: 0;
  display: block;
}
.book-card h3 {
  margin: 0 0 var(--s-3) 0 !important;
  font-size: 1.25rem !important;
  letter-spacing: 0.1em;
}
.book-card p {
  font-size: 1rem;
  color: var(--fg-muted);
  margin-bottom: var(--s-4);
  max-width: 300px;
  line-height: 1.65;
}
.book-card .ah-btn-container {
  margin-top: auto;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  gap: var(--s-3);
  width: 100%;
}
.book-card .ah-btn { min-width: 160px; }
@media (max-width: 1023px) { .book-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .book-grid { grid-template-columns: 1fr; gap: var(--s-8); } }

/* ============================================================
   Newsletter Block
   ============================================================ */
.newsletter-block {
  text-align: center;
  padding: var(--s-9) 0 !important;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.newsletter-block.full-bleed { background: var(--ah-near-black); }
.newsletter-block .ah-h2 { margin: 0 0 var(--s-4) 0 !important; }
.newsletter-block .ah-lede { max-width: 560px; margin: 0 auto var(--s-6) auto; }
.newsletter-form {
  max-width: 440px;
  margin: 0 auto !important;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  text-align: left;
}
.newsletter-form input { margin: 0 !important; }
.newsletter-form button { width: 100%; margin-top: var(--s-2); }
.newsletter-form .affiliate-micro { margin: var(--s-2) 0 0 !important; text-align: center; }

/* ============================================================
   Tropes / Tags
   ============================================================ */
.tropes-list { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--s-2); margin-top: var(--s-4); }
.trope-tag {
  font: 600 0.6875rem/1 var(--ah-sans);
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 10px 14px;
  border: 1px solid var(--rule);
  color: var(--fg-muted);
  transition: all var(--dur-fast) var(--ease);
}
.trope-tag:hover { border-color: var(--accent); color: var(--accent); }

/* ============================================================
   Trigger Warnings
   ============================================================ */
.trigger-warnings {
  margin-top: var(--s-5); text-align: left;
  background: var(--bg-soft); padding: var(--s-5) var(--s-6);
  border-left: 2px solid var(--hot);
}
.tw-list { list-style: none; padding: 0; margin: 0 0 var(--s-3) 0; }
.tw-list li { margin-bottom: var(--s-2); position: relative; padding-left: var(--s-4); line-height: 1.6; }
.tw-list li::before { content: '♠'; position: absolute; left: 0; color: var(--accent); }
details.tw-details summary {
  cursor: pointer;
  font: var(--eyebrow); color: var(--accent);
  margin-top: var(--s-3); outline: none;
  letter-spacing: 0.18em; text-transform: uppercase;
}
details.tw-details summary:hover { text-decoration: underline; }

/* ============================================================
   Affiliates & Microcopy
   ============================================================ */
.affiliate-micro {
  font: var(--small);
  color: var(--fg-muted);
  margin-top: var(--s-2);
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
}
.ku-badge {
  font: var(--small);
  color: var(--accent);
  margin-top: var(--s-2);
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}

/* ============================================================
   Contact form specifics
   ============================================================ */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.contact-form input,
.contact-form select,
.contact-form textarea { margin: 0 !important; }
.contact-form button { margin-top: var(--s-3); align-self: flex-start; }

/* ============================================================
   Section header pattern (centered, eyebrow above h1)
   ============================================================ */
section > .container[style*="text-align: center"] .ah-eyebrow,
section > .container[style*="text-align:center"] .ah-eyebrow {
  padding-left: 0;
}
section > .container[style*="text-align: center"] .ah-eyebrow::before,
section > .container[style*="text-align:center"] .ah-eyebrow::before {
  display: none;
}

/* ============================================================
   Typography responsive adjustments
   ============================================================ */
/* Tablet scale — prevents 3.25rem h1 from wrapping awkwardly in narrow tablet columns */
@media (max-width: 1023px) and (min-width: 768px) {
  :root {
    --h1: 700 2.625rem/1.08 var(--ah-serif);
    --h2: 600 1.875rem/1.18 var(--ah-serif);
    --h3: 500 1.375rem/1.25 var(--ah-serif);
  }
}
@media (max-width: 767px) {
  :root {
    --h1: 700 2.25rem/1.1 var(--ah-serif);
    --h2: 600 1.625rem/1.2 var(--ah-serif);
    --h3: 500 1.25rem/1.3 var(--ah-serif);
  }
  .ah-lede { font-size: 1rem; }
}
