/* ============================================================
   Wayfarer — a CivMC travel journal
   Shared stylesheet. Warm parchment / field-journal identity.
   ============================================================ */

:root {
  /* Palette — aged paper, ink, and a sealing-wax accent */
  --paper:        #ece3cf;   /* page background, aged parchment */
  --paper-deep:   #e3d8bd;   /* card / inset panels */
  --ink:          #2e2618;   /* primary text, dark sepia */
  --ink-soft:     #5c5034;   /* secondary text */
  --rule:         #c4b48d;   /* hairlines, borders */
  --wax:          #9c3b2e;   /* sealing-wax red accent */
  --wax-deep:     #7c2c22;   /* accent hover */
  --gilt:         #b08a3c;   /* gold detail, used sparingly */

  /* Type */
  --display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --body:    "Spectral", Georgia, serif;
  --util:    "IBM Plex Mono", ui-monospace, "Courier New", monospace;

  --measure: 38rem;          /* readable line length */
}

/* ---------- Reset-ish ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background-color: var(--paper);
  background-image:
    radial-gradient(circle at 20% 15%, rgba(156,59,46,0.04), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(176,138,60,0.05), transparent 45%);
  color: var(--ink);
  font-family: var(--body);
  font-size: 1.125rem;
  line-height: 1.7;
  font-variant-ligatures: common-ligatures;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--wax); text-decoration: none; }
a:hover { color: var(--wax-deep); text-decoration: underline; text-underline-offset: 3px; }

/* ---------- Layout shell ---------- */
.wrap { max-width: 60rem; margin: 0 auto; padding: 0 1.5rem; }
.measure { max-width: var(--measure); margin-inline: auto; }

/* ---------- Masthead ---------- */
.masthead {
  border-bottom: 2px solid var(--ink);
  padding: 2.5rem 0 1.25rem;
  margin-bottom: 2.5rem;
  text-align: center;
}
.masthead .mark {
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 0 0 0.6rem;
  padding-left: 0.38em;
}
.masthead h1 {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(2.6rem, 7vw, 4.4rem);
  line-height: 0.95;
  margin: 0;
  letter-spacing: -0.01em;
}
.masthead h1 .amp { color: var(--wax); font-style: italic; }
.masthead .sub {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.25rem;
  color: var(--ink-soft);
  margin: 0.5rem 0 0;
}
.masthead nav {
  margin-top: 1.4rem;
  font-family: var(--util);
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.masthead nav a { margin: 0 0.7rem; color: var(--ink-soft); }
.masthead nav a:hover { color: var(--wax); text-decoration: none; }

/* ---------- Index: the ledger of entries ---------- */
.entry-list { list-style: none; margin: 0; padding: 0; }
.entry {
  display: grid;
  grid-template-columns: 7.5rem 1fr;
  gap: 1.75rem;
  padding: 2rem 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.entry:first-child { border-top: 1px solid var(--rule); }
.entry .meta {
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  line-height: 1.5;
}
.entry .meta .num { color: var(--wax); display: block; font-size: 0.92rem; margin-bottom: 0.3rem; }
.entry h2 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 1.85rem;
  line-height: 1.1;
  margin: 0 0 0.5rem;
}
.entry h2 a { color: var(--ink); }
.entry h2 a:hover { color: var(--wax); text-decoration: none; }
.entry .dek { margin: 0; color: var(--ink-soft); font-style: italic; font-family: var(--display); font-size: 1.18rem; }
.entry .nation {
  display: inline-block;
  margin-top: 0.6rem;
  font-family: var(--util);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  border: 1px solid var(--rule);
  padding: 0.15rem 0.55rem;
}

@media (max-width: 33rem) {
  .entry { grid-template-columns: 1fr; gap: 0.5rem; }
}

/* ---------- Article ---------- */
.article { padding-bottom: 4rem; }
.article-head { text-align: center; margin-bottom: 2.5rem; }
.article-head .num {
  font-family: var(--util);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wax);
  margin: 0 0 0.8rem;
}
.article-head h1 {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(2.1rem, 5.5vw, 3.4rem);
  line-height: 1.02;
  margin: 0 auto;
  max-width: 18ch;
}
.article-head .dek {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.3rem;
  color: var(--ink-soft);
  margin: 0.8rem auto 0;
  max-width: 30ch;
}
.article-head .byline {
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 1.2rem;
}
.article-head .byline .star { color: var(--wax); }

/* Body modules */
.m-text p { margin: 0 0 1.3rem; }
.m-text p:first-letter { } /* hook for drop cap if desired later */

.m-image { margin: 2.5rem auto; }
.m-image img { border: 1px solid var(--ink); box-shadow: 0 2px 0 var(--rule); }
.m-image figcaption {
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  text-align: center;
  margin-top: 0.7rem;
}

.m-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 2.5rem 0;
}
.m-pair img { border: 1px solid var(--ink); box-shadow: 0 2px 0 var(--rule); width: 100%; }
.m-pair figcaption {
  grid-column: 1 / -1;
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  text-align: center;
  margin-top: 0.2rem;
}
@media (max-width: 33rem) { .m-pair { grid-template-columns: 1fr; } }

/* Lore box — a margin note pulled inline */
.m-lore {
  border-left: 3px solid var(--wax);
  background: var(--paper-deep);
  padding: 1.3rem 1.5rem;
  margin: 2.5rem 0;
}
.m-lore .lore-label {
  font-family: var(--util);
  font-size: 0.66rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--wax);
  margin: 0 0 0.6rem;
}
.m-lore p { margin: 0 0 0.9rem; }
.m-lore p:last-child { margin-bottom: 0; }

/* Section heading inside an article */
.m-heading {
  font-family: var(--display);
  font-weight: 600;
  font-size: 1.7rem;
  margin: 2.8rem 0 1rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--rule);
}

/* Verdict — the wax-seal closer */
.m-verdict {
  text-align: center;
  margin: 3.5rem auto 0;
  padding-top: 2rem;
  border-top: 2px solid var(--ink);
  max-width: 34rem;
}
.m-verdict .seal {
  font-family: var(--util);
  font-size: 0.7rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--wax);
  margin-bottom: 0.8rem;
}
.m-verdict p {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 0;
}

/* Pull-quote */
.m-quote {
  font-family: var(--display);
  font-style: italic;
  font-size: 1.7rem;
  line-height: 1.4;
  text-align: center;
  color: var(--ink);
  margin: 2.8rem auto;
  max-width: 26ch;
}
.m-quote::before { content: "“"; color: var(--wax); }
.m-quote::after  { content: "”"; color: var(--wax); }

/* ---------- Footer ---------- */
.foot {
  border-top: 2px solid var(--ink);
  margin-top: 3rem;
  padding: 1.6rem 0 2.5rem;
  text-align: center;
  font-family: var(--util);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* ---------- Back link ---------- */
.backlink {
  font-family: var(--util);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: inline-block;
  margin-bottom: 2rem;
}
.backlink::before { content: "← "; color: var(--wax); }

/* ---------- Accessibility ---------- */
:focus-visible { outline: 2px solid var(--wax); outline-offset: 2px; }
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}
