/* ==========================================================================
   citation-proverbe.com — Design system "Parchemin & calligraphie"
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Italianno&display=swap');

/* ---------- Tokens ---------- */
:root {
  /* Couleurs */
  --bg: #F5EFE0;           /* parchemin */
  --bg-alt: #FFFCF5;       /* parchemin clair (cards) */
  --bg-warm: #EDE3D0;      /* parchemin tirant vers le sepia (sections) */
  --ink: #3B2A1E;          /* encre brune, texte primaire */
  --ink-soft: #5A4636;     /* encre brune adoucie */
  --ink-deep: #2E1F15;     /* encre noire (footer) */
  --gold: #C9A84C;         /* or vieilli, accent */
  --gold-soft: #D9BC6E;    /* or clair */
  --sepia: #8B5A3C;        /* brun sepia, tags */
  --error: #A0291C;        /* rouge oxblood, 404 */
  --rule: rgba(201, 168, 76, 0.4);   /* filets dores */
  --shadow: 0 8px 24px -12px rgba(59, 42, 30, 0.18);
  --shadow-deep: 0 18px 48px -16px rgba(59, 42, 30, 0.28);

  /* Polices */
  --ff-display: 'EB Garamond', Georgia, 'Times New Roman', serif;
  --ff-body: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --ff-script: 'Italianno', 'Snell Roundhand', cursive;

  /* Mesures */
  --measure-article: 720px;
  --measure-wide: 1200px;
  --measure-hero: 1440px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);

  /* Transitions */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast: 280ms;
  --dur: 480ms;
  --dur-slow: 720ms;
}

/* ---------- Reset minimal ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--ff-body);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--ink);
  background: var(--bg);
  background-image:
    radial-gradient(at 20% 10%, rgba(201, 168, 76, 0.06) 0%, transparent 50%),
    radial-gradient(at 80% 90%, rgba(139, 90, 60, 0.05) 0%, transparent 55%);
  background-attachment: fixed;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ink); text-decoration-color: var(--gold); text-underline-offset: 3px; text-decoration-thickness: 1px; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--sepia); }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }

/* ---------- Typo titres ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--ff-display);
  color: var(--ink);
  letter-spacing: -0.005em;
}
h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); font-weight: 500; line-height: 1.15; font-style: italic; }
h2 { font-size: clamp(1.9rem, 3.4vw, 2.6rem); font-weight: 500; line-height: 1.25; margin-top: 2.5em; margin-bottom: 0.8em; position: relative; padding-bottom: 0.5em; }
h2::after { content: ''; position: absolute; left: 0; bottom: 0; width: 60px; height: 1px; background: var(--gold); }
h3 { font-size: clamp(1.45rem, 2.4vw, 1.75rem); font-weight: 600; line-height: 1.35; margin-top: 2em; margin-bottom: 0.7em; color: var(--ink-soft); }
h4 { font-size: 1.25rem; font-weight: 600; margin-top: 1.5em; margin-bottom: 0.5em; }

/* ---------- Body article ---------- */
p { margin-bottom: 1.2em; }
p + p { margin-top: -0.2em; }
strong { color: var(--ink-deep); font-weight: 600; }
em { font-style: italic; color: var(--ink-soft); }
ul, ol { padding-left: 1.5em; margin-bottom: 1.4em; }
li { margin-bottom: 0.5em; }
li::marker { color: var(--gold); }

blockquote {
  margin: 2.5em 0;
  padding: 1.5em 2em 1.5em 3.2em;
  font-family: var(--ff-display);
  font-size: 1.4em;
  font-style: italic;
  color: var(--ink-soft);
  background: var(--bg-alt);
  border-left: 3px solid var(--gold);
  position: relative;
  box-shadow: var(--shadow);
}
blockquote::before {
  content: '\00AB';
  position: absolute;
  left: 0.4em; top: 0.05em;
  font-family: var(--ff-display);
  font-size: 3.5em;
  font-style: normal;
  color: var(--gold);
  line-height: 1;
  opacity: 0.6;
}
blockquote p:last-child { margin-bottom: 0; }
blockquote cite {
  display: block;
  margin-top: 0.8em;
  font-family: var(--ff-body);
  font-size: 0.85em;
  font-style: normal;
  color: var(--sepia);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

hr {
  border: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold) 50%, transparent);
  margin: 3em auto;
  width: 60%;
}

code { font-family: 'SF Mono', Menlo, monospace; font-size: 0.9em; padding: 0.15em 0.4em; background: var(--bg-warm); border-radius: 3px; color: var(--sepia); }

/* ---------- Layouts ---------- */
.container { max-width: var(--measure-wide); margin: 0 auto; padding: 0 var(--gutter); }
.container-article { max-width: var(--measure-article); margin: 0 auto; padding: 0 var(--gutter); }
.container-hero { max-width: var(--measure-hero); margin: 0 auto; padding: 0 var(--gutter); }

.section { padding: clamp(3rem, 7vw, 5.5rem) 0; }
.section-warm { background: var(--bg-warm); }

/* ---------- Header ---------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 1.2rem 0;
  background: transparent;
  backdrop-filter: blur(0);
  transition: background var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), padding var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.site-header.scrolled {
  background: rgba(245, 239, 224, 0.92);
  backdrop-filter: blur(14px) saturate(120%);
  padding: 0.7rem 0;
  box-shadow: 0 1px 0 var(--rule), 0 6px 20px -12px rgba(59, 42, 30, 0.18);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { font-family: var(--ff-display); font-weight: 600; font-size: 1.4rem; letter-spacing: 0.01em; font-style: italic; color: var(--ink-deep); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
.brand-sub { display: block; font-family: var(--ff-body); font-style: normal; font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sepia); margin-top: -2px; font-weight: 500; transition: color var(--dur-fast) var(--ease); }

.nav { display: flex; gap: 2rem; align-items: center; }
.nav a { font-family: var(--ff-body); font-size: 0.95rem; font-weight: 500; letter-spacing: 0.04em; text-decoration: none; padding: 0.4em 0; border-bottom: 1px solid transparent; transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease); }
.nav a:hover, .nav a.active { border-color: var(--gold); }

.nav-toggle { display: none; padding: 0.4rem 0.6rem; }
.nav-toggle span { display: block; width: 24px; height: 1.5px; background: var(--ink); transition: background var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease), opacity var(--dur-fast) var(--ease); }

/* Header transparent au-dessus d'un hero foncé (data-dark-hero détecté par JS) */
.site-header[data-dark-hero]:not(.scrolled) .brand { color: rgba(245, 239, 224, 0.95); }
.site-header[data-dark-hero]:not(.scrolled) .brand-sub { color: var(--gold-soft); }
.site-header[data-dark-hero]:not(.scrolled) .nav a { color: rgba(245, 239, 224, 0.92); }
.site-header[data-dark-hero]:not(.scrolled) .nav a:hover,
.site-header[data-dark-hero]:not(.scrolled) .nav a.active { border-color: var(--gold-soft); color: var(--bg); }
.site-header[data-dark-hero]:not(.scrolled) .nav-toggle span { background: rgba(245, 239, 224, 0.95); }
.nav-toggle span + span { margin-top: 6px; }

@media (max-width: 768px) {
  .nav-toggle { display: block; }
  .nav {
    position: fixed; inset: 70px 0 0 0;
    flex-direction: column; align-items: flex-start;
    padding: 2rem var(--gutter);
    background: rgba(245, 239, 224, 0.98);
    backdrop-filter: blur(14px);
    transform: translateX(100%);
    transition: transform var(--dur) var(--ease);
    overflow-y: auto;
  }
  .nav a { font-size: 1.3rem; font-family: var(--ff-display); }
  body.nav-open .nav { transform: translateX(0); }
  body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
  body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
  body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 80vh;
  display: flex; align-items: center;
  padding: 8rem 0 5rem;
  overflow: hidden;
  background: var(--bg-warm);
}
.hero-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  z-index: 0;
}
.hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(46, 31, 21, 0.45) 0%, rgba(46, 31, 21, 0.65) 100%);
}
.hero-content { position: relative; z-index: 1; color: var(--bg); max-width: 820px; }
.hero-kicker { font-family: var(--ff-body); font-size: 0.85rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 1.2rem; font-weight: 600; }
.hero h1 { color: var(--bg); font-style: italic; margin-bottom: 1.2rem; }
.hero-description { font-size: 1.3rem; line-height: 1.55; color: rgba(245, 239, 224, 0.94); max-width: 640px; font-family: var(--ff-display); font-weight: 400; }
.hero-cta { display: flex; gap: 1.5rem; margin-top: 2.2rem; flex-wrap: wrap; }
.hero-scroll {
  position: absolute; bottom: 2rem; left: 50%;
  transform: translateX(-50%);
  font-family: var(--ff-body);
  font-size: 0.75rem; letter-spacing: 0.4em; text-transform: uppercase;
  color: var(--bg);
  opacity: 0.7;
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
}
.hero-scroll::after {
  content: ''; width: 1px; height: 32px; background: var(--bg);
  animation: scrollHint 2.4s ease-in-out infinite;
}
@keyframes scrollHint {
  0%, 100% { opacity: 0; transform: scaleY(0); transform-origin: top; }
  50% { opacity: 0.8; transform: scaleY(1); transform-origin: top; }
}

/* Hero article (variante) */
.hero.hero-article { min-height: 60vh; padding: 7rem 0 3.5rem; }
.hero-breadcrumb { font-family: var(--ff-body); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 1rem; }
.hero-breadcrumb a { color: var(--gold-soft); text-decoration: none; }
.hero-breadcrumb a:hover { color: var(--bg); }
.hero-meta { font-family: var(--ff-body); font-size: 0.85rem; letter-spacing: 0.1em; color: var(--bg); opacity: 0.85; margin-top: 1.5rem; }

/* ---------- CTA Buttons ---------- */
.btn {
  display: inline-block;
  padding: 0.95em 2em;
  font-family: var(--ff-body);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--gold);
  background: transparent;
  color: var(--gold);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.btn:hover { background: var(--gold); color: var(--ink-deep); transform: translateY(-2px); }
.btn-solid { background: var(--gold); color: var(--ink-deep); }
.btn-solid:hover { background: var(--gold-soft); color: var(--ink-deep); }
.btn-inverse { border-color: var(--bg); color: var(--bg); }
.btn-inverse:hover { background: var(--bg); color: var(--ink-deep); }

/* ---------- Section header (intro editoriale) ---------- */
.section-header { text-align: center; margin-bottom: 3.5rem; }
.section-kicker { font-family: var(--ff-body); font-size: 0.8rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--sepia); margin-bottom: 1rem; font-weight: 600; }
.section-title { font-size: clamp(2rem, 3.6vw, 2.8rem); font-weight: 500; font-style: italic; margin-bottom: 1rem; }
.section-lead { font-size: 1.2rem; line-height: 1.6; max-width: 640px; margin: 0 auto; color: var(--ink-soft); font-family: var(--ff-display); }

/* ---------- Cards ---------- */
.grid { display: grid; gap: 2rem; }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); }
.grid-pillars { grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.6rem; }

.card {
  background: var(--bg-alt);
  border: 1px solid var(--rule);
  padding: 1.8rem 1.6rem;
  text-decoration: none;
  color: var(--ink);
  display: flex; flex-direction: column;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  position: relative;
  overflow: hidden;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-deep); border-color: var(--gold); }
.card-image { aspect-ratio: 3 / 2; overflow: hidden; margin: -1.8rem -1.6rem 1.4rem; background: var(--bg-warm); }
.card-image img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; transition: transform var(--dur-slow) var(--ease); }
.card:hover .card-image img { transform: scale(1.04); }
.card-tag { font-family: var(--ff-body); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sepia); font-weight: 600; margin-bottom: 0.6rem; }
.card-title { font-family: var(--ff-display); font-size: 1.5rem; font-weight: 500; line-height: 1.3; margin-bottom: 0.7rem; color: var(--ink-deep); font-style: italic; }
.card-excerpt { font-size: 1rem; line-height: 1.55; color: var(--ink-soft); margin-bottom: 1rem; }
.card-meta { margin-top: auto; font-family: var(--ff-body); font-size: 0.8rem; letter-spacing: 0.08em; color: var(--sepia); text-transform: uppercase; }

/* Pillar cards (variante avec icone calligraphique) */
.card-pillar {
  background: var(--bg-alt);
  border: 1px solid var(--rule);
  padding: 2.2rem 1.8rem 1.8rem;
  text-decoration: none; color: var(--ink);
  display: flex; flex-direction: column;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  position: relative;
}
.card-pillar:hover { transform: translateY(-4px); box-shadow: var(--shadow-deep); border-color: var(--gold); }
.card-pillar::before {
  content: '\00AB';
  position: absolute; top: 0.4rem; right: 1rem;
  font-family: var(--ff-script);
  font-size: 4rem;
  color: var(--gold);
  opacity: 0.35;
  line-height: 1;
}
.card-pillar h3 { font-family: var(--ff-display); font-size: 1.6rem; font-weight: 500; font-style: italic; margin: 0 0 0.7rem; color: var(--ink-deep); }
.card-pillar p { font-size: 1rem; color: var(--ink-soft); line-height: 1.55; }
.card-pillar .arrow { margin-top: 1.2rem; font-family: var(--ff-body); font-size: 0.85rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); font-weight: 600; }

/* ---------- Article body ---------- */
.article-summary {
  font-family: var(--ff-display);
  font-size: 1.45rem;
  line-height: 1.55;
  font-style: italic;
  color: var(--ink-soft);
  max-width: var(--measure-article);
  margin: 3rem auto;
  padding: 0 var(--gutter);
  text-align: center;
}
.article-summary::before, .article-summary::after {
  content: '';
  display: block;
  width: 80px;
  height: 1px;
  background: var(--gold);
  margin: 1.2rem auto;
}

.article-body {
  max-width: var(--measure-article);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.article-body > p:first-of-type::first-letter {
  font-family: var(--ff-display);
  float: left;
  font-size: 4.5em;
  font-weight: 500;
  line-height: 0.9;
  margin: 0.08em 0.08em 0 0;
  color: var(--gold);
}
.article-body img { margin: 2rem 0; box-shadow: var(--shadow); }
.article-body figcaption { font-family: var(--ff-body); font-size: 0.85rem; color: var(--sepia); text-align: center; margin-top: 0.6rem; font-style: italic; }

.toc {
  background: var(--bg-alt);
  border: 1px solid var(--rule);
  padding: 1.4rem 1.6rem;
  margin: 0 0 2.5rem;
  font-family: var(--ff-body);
  font-size: 0.95rem;
}
.toc-title { font-family: var(--ff-display); font-style: italic; font-size: 1.1rem; color: var(--sepia); margin-bottom: 0.8rem; letter-spacing: 0.05em; }
.toc ol { padding-left: 1.2rem; margin: 0; }
.toc li { margin-bottom: 0.3rem; }
.toc a { color: var(--ink-soft); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
.toc a:hover { color: var(--sepia); }

@media (min-width: 1100px) {
  .article-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 3rem;
    align-items: start;
    max-width: calc(var(--measure-article) + 280px);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
  .article-layout > .article-body { padding: 0; max-width: none; }
  .article-layout:not(:has(.toc)) > .article-body { grid-column: 1 / -1; }
  .article-layout .toc { position: sticky; top: 100px; align-self: start; margin-top: 0.5em; max-height: calc(100vh - 120px); overflow-y: auto; }
}

/* ---------- FAQ ---------- */
.faq { max-width: var(--measure-article); margin: 4rem auto 0; padding: 0 var(--gutter); }
.faq h2 { text-align: center; margin-bottom: 2.5rem; }
.faq-item {
  border-top: 1px solid var(--rule);
  padding: 1.2rem 0;
}
.faq-item:last-child { border-bottom: 1px solid var(--rule); }
.faq-question {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  text-align: left;
  font-family: var(--ff-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--ink-deep);
  padding: 0.4rem 0;
}
.faq-question::after {
  content: '+';
  font-family: var(--ff-display);
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--gold);
  transition: transform var(--dur-fast) var(--ease);
}
.faq-item.open .faq-question::after { transform: rotate(45deg); }
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--dur) var(--ease), padding var(--dur) var(--ease);
}
.faq-item.open .faq-answer { max-height: 1000px; padding-top: 0.8rem; }
.faq-answer p { color: var(--ink-soft); font-size: 1.05rem; line-height: 1.65; }
.faq-answer p:last-child { margin-bottom: 0.4rem; }

/* ---------- Related ---------- */
.related { background: var(--bg-warm); padding: 4rem 0; margin-top: 5rem; }
.related .section-header { margin-bottom: 2.5rem; }
.related-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink-deep);
  color: var(--bg);
  padding: 4rem 0 2rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
.footer-brand { font-family: var(--ff-display); font-size: 1.5rem; font-style: italic; font-weight: 500; color: var(--gold-soft); margin-bottom: 0.5rem; }
.footer-tag { font-family: var(--ff-body); font-size: 0.75rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 1rem; }
.footer-text { font-size: 0.95rem; line-height: 1.6; color: rgba(245, 239, 224, 0.75); }

.footer-col h4 {
  font-family: var(--ff-body);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-soft);
  font-weight: 600;
  margin-bottom: 1.2rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(201, 168, 76, 0.25);
}
.footer-col ul { list-style: none; padding: 0; }
.footer-col li { margin-bottom: 0.6rem; }
.footer-col a { color: rgba(245, 239, 224, 0.8); text-decoration: none; font-size: 0.95rem; transition: color var(--dur-fast) var(--ease); }
.footer-col a:hover { color: var(--gold-soft); }

.footer-bottom {
  padding-top: 2rem;
  border-top: 1px solid rgba(201, 168, 76, 0.18);
  display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  font-size: 0.85rem;
  font-family: var(--ff-body);
  color: rgba(245, 239, 224, 0.55);
}
.footer-bottom .script {
  font-family: var(--ff-script);
  font-size: 1.6rem;
  color: var(--gold);
  letter-spacing: 0.02em;
  line-height: 1;
}

/* ---------- Pull quote (signature visuelle) ---------- */
.pull-quote {
  max-width: var(--measure-article);
  margin: 3rem auto;
  padding: 2rem var(--gutter);
  text-align: center;
  font-family: var(--ff-script);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  line-height: 1.3;
  color: var(--sepia);
  position: relative;
}

/* ---------- 404 ---------- */
.page-404 {
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  text-align: center;
  padding: 6rem var(--gutter);
}
.page-404 h1 { color: var(--error); font-size: clamp(4rem, 12vw, 7rem); font-style: italic; }
.page-404 .sub { font-family: var(--ff-script); font-size: clamp(2rem, 4vw, 3rem); color: var(--gold); margin-top: -0.5rem; margin-bottom: 1rem; }
.page-404 p { max-width: 560px; margin-bottom: 2rem; font-size: 1.15rem; color: var(--ink-soft); }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease); }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ---------- Page filler (a-propos, mentions, contact) ---------- */
.page-body { max-width: var(--measure-article); margin: 8rem auto 4rem; padding: 0 var(--gutter); }
.page-body h1 { margin-bottom: 1.5rem; }
.page-body h2 { margin-top: 2.5em; }

/* ---------- Forms ---------- */
.form-row { margin-bottom: 1.5rem; }
.form-row label { display: block; font-family: var(--ff-body); font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sepia); margin-bottom: 0.5rem; }
.form-row input, .form-row textarea {
  width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid var(--rule);
  background: var(--bg-alt);
  font-family: var(--ff-body);
  font-size: 1.05rem;
  color: var(--ink-deep);
  transition: border-color var(--dur-fast) var(--ease);
}
.form-row input:focus, .form-row textarea:focus { outline: none; border-color: var(--gold); }
.form-row textarea { min-height: 160px; resize: vertical; font-family: var(--ff-body); }

/* ---------- Print ---------- */
@media print {
  .site-header, .site-footer, .nav-toggle, .hero-scroll { display: none !important; }
  body { background: white; color: black; }
}
