/*
Theme Name: Garden Plot 19
Theme URI: https://linestorgaardconley.com
Author: Garden Plot 19
Author URI: https://linestorgaardconley.com
Description: A field-journal theme for an allotment garden — growing food, sustainability and a small medicine garden. Journal entries are WordPress posts; the home page, beds and almanac are built in. Converted from the Garden Plot 19 static site.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: garden-plot-19
*/

/* ============================================================
   Garden Plot 19 — shared stylesheet
   Edit colours & fonts in :root below.
   ============================================================ */

:root {
  --paper:      #EFF1E9;  /* greenhouse-glass pale            */
  --paper-warm: #E7EAdf;  /* a touch deeper, for panels       */
  --pine:       #1B3A2A;  /* deep forest, for dark sections   */
  --pine-soft:  #2E5240;  /* hover / borders on dark          */
  --sage:       #7E9474;  /* mid herbal green                 */
  --ink:        #25291F;  /* body text, green-black           */
  --ink-soft:   #555c49;  /* muted body                       */
  --berry:      #7D4D63;  /* dusty elderberry accent          */
  --berry-deep: #5d3349;
  --line:       #c9cfbd;  /* hairline on paper                */

  --serif: "Fraunces", Georgia, serif;
  --sans:  "DM Sans", system-ui, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1140px;
  --gut: clamp(1.25rem, 5vw, 4rem);

  /* Hero image — change this one line to swap the photo.
     Paths here are relative to THIS css file (assets/css/), so drop
     your own photo in assets/img/ and point to it like this:
     --hero-img: url('../img/hero.jpg');  */
  --hero-img: url('assets/img/hero.svg');
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 18px;
  line-height: 1.65;
  overflow-x: hidden;
}

::selection { background: var(--berry); color: var(--paper); }
a { color: inherit; }
img { max-width: 100%; display: block; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }

.eyebrow {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--berry);
}

.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--mono); font-size: .78rem; letter-spacing: .1em;
  text-transform: uppercase; text-decoration: none; cursor: pointer;
  padding: .85rem 1.4rem; border: 1px solid var(--ink);
  background: var(--ink); color: var(--paper); border-radius: 2px;
  transition: background .2s, border-color .2s, gap .25s;
}
.btn:hover { background: var(--berry); border-color: var(--berry); gap: .95rem; }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: transparent; color: var(--berry); }
.btn--light { background: var(--paper); color: var(--pine); border-color: var(--paper); }
.btn--light:hover { background: var(--berry); border-color: var(--berry); color: var(--paper); }
.btn--outline-light { background: transparent; color: var(--paper); border-color: var(--paper); }
.btn--outline-light:hover { background: var(--paper); color: var(--pine); border-color: var(--paper); }

.link-arrow {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--mono); font-size: .78rem; letter-spacing: .1em;
  text-transform: uppercase; text-decoration: none;
  border-bottom: 1.5px solid currentColor; padding-bottom: .25rem;
  transition: gap .25s, color .2s, border-color .2s;
}
.link-arrow:hover { gap: 1.1rem; color: var(--berry); }

/* ---------- top bar ---------- */
.topbar {
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: blur(8px);
}
.topbar .wrap {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; min-height: 60px;
  font-family: var(--mono); font-size: .74rem;
  letter-spacing: .1em; text-transform: uppercase;
}
.brand-mark { display: flex; align-items: baseline; gap: .55rem; font-weight: 500; text-decoration: none; }
.brand-mark .plot {
  background: var(--pine); color: var(--paper);
  padding: .12em .42em; border-radius: 2px; letter-spacing: .05em;
}
.topbar nav { display: flex; gap: 1.5rem; color: var(--ink-soft); align-items: center; }
.topbar nav a { text-decoration: none; transition: color .2s; padding: .2rem 0; }
.topbar nav a:hover { color: var(--berry); }
.topbar nav a[aria-current="page"] { color: var(--ink); border-bottom: 1.5px solid var(--berry); }

.nav-toggle {
  display: none; background: none; border: 1px solid var(--line); border-radius: 2px;
  font-family: var(--mono); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink); padding: .5rem .7rem; cursor: pointer;
}

@media (max-width: 860px) {
  .topbar .wrap { flex-wrap: wrap; }
  .nav-toggle { display: inline-block; }
  .topbar nav {
    display: none; flex-direction: column; align-items: flex-start;
    width: 100%; gap: 0; padding-bottom: .5rem;
  }
  .topbar nav.open { display: flex; }
  .topbar nav a { width: 100%; padding: .7rem 0; border-top: 1px solid var(--line); }
  .topbar nav a[aria-current="page"] { border-bottom: none; color: var(--berry); }
}

/* ---------- home hero (image) ---------- */
.hero {
  position: relative; min-height: clamp(500px, 80vh, 740px);
  display: flex; align-items: flex-end; color: var(--paper);
  background-color: var(--pine);
  background-image:
    linear-gradient(180deg, rgba(27,58,42,.15) 0%, rgba(27,58,42,.20) 45%, rgba(27,58,42,.86) 100%),
    var(--hero-img);
  background-size: cover; background-position: center;
}
.hero .wrap { padding-block: clamp(2.5rem, 6vw, 4.5rem); width: 100%; }
.hero-inner { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: clamp(1.5rem, 4vw, 3rem); align-items: end; }
.hero-copy { min-width: 0; }
.hero .eyebrow { color: color-mix(in srgb, var(--paper) 80%, var(--sage)); }
.hero h1 {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(3rem, 11vw, 7.5rem); line-height: .92;
  letter-spacing: -.02em; margin-block: 1rem 1.2rem;
}
.hero h1 .nineteen { font-style: italic; color: color-mix(in srgb, var(--berry) 70%, var(--paper)); }
.hero .lede {
  font-size: clamp(1.05rem, 2vw, 1.3rem); max-width: 40ch;
  color: color-mix(in srgb, var(--paper) 88%, transparent);
}
.hero .lede em { color: var(--paper); font-style: italic; }
.hero .cta-row { margin-top: 2rem; display: flex; gap: 1rem; flex-wrap: wrap; }

/* hero with no image -> clean paper variant */
.hero--plain {
  background-image: none; background-color: var(--paper); color: var(--ink);
  min-height: auto; padding-block: 0;
}
.hero--plain .eyebrow { color: var(--berry); }
.hero--plain h1 .nineteen { color: var(--berry); }
.hero--plain .lede { color: var(--ink-soft); }
.hero--plain .lede em { color: var(--ink); }

/* status ledger (sits inside the hero banner) */
.ledger {
  width: min(380px, 100%); position: relative; z-index: 2;
  border: 1px solid rgba(255,255,255,.55); background: #ffffff;
  font-family: var(--mono); font-size: .8rem; line-height: 1.45;
  box-shadow: 0 24px 50px -24px rgba(0,0,0,.45);
}
.ledger-head {
  display: flex; justify-content: space-between; align-items: center;
  background: var(--pine); color: var(--paper); padding: .55rem .9rem;
  letter-spacing: .14em; text-transform: uppercase; font-size: .68rem;
}
.ledger-head .dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--sage);
  display: inline-block; margin-right: .4rem; animation: pulse 2.6s infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--sage) 70%, transparent); }
  70%  { box-shadow: 0 0 0 7px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}
.ledger ul { list-style: none; }
.ledger li {
  display: flex; justify-content: space-between; gap: 1rem;
  padding: .5rem .9rem; border-top: 1px dashed var(--line);
}
.ledger li:first-child { border-top: none; }
.ledger li .k { color: var(--ink-soft); }
.ledger li .v { color: var(--ink); text-align: right; }
.ledger li .v.flower { color: var(--berry); }
.ledger-foot { padding: .5rem .9rem; border-top: 1px solid var(--line); color: var(--ink-soft); font-size: .7rem; }

/* ---------- section label ---------- */
.section-label { display: flex; align-items: center; gap: 1rem; margin-bottom: 2.5rem; }
.section-label::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.section-label h2 {
  font-family: var(--mono); font-weight: 400; font-size: .78rem;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft);
}

/* ---------- beds ---------- */
.beds { padding-block: clamp(3rem, 7vw, 5.5rem); }
.beds-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 3vw, 2.5rem); }
.bed { display: flex; flex-direction: column; padding-top: 1.5rem; border-top: 2px solid var(--pine); text-decoration: none; color: inherit; }
.bed .tag { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--berry); }
.bed h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 3vw, 2.05rem); line-height: 1.05; margin-block: .5rem .85rem; }
.bed p { font-size: .98rem; color: var(--ink-soft); }
.bed .grows { margin-top: 1.1rem; font-family: var(--mono); font-size: .72rem; color: var(--ink); line-height: 1.9; }
.bed .grows span { display: inline-block; border: 1px solid var(--line); padding: .1rem .5rem; border-radius: 100px; margin: 0 .25rem .35rem 0; }
.bed .bed-more { margin-top: 1.2rem; font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); display: inline-flex; gap: .4rem; transition: gap .25s, color .2s; }
a.bed:hover .bed-more { gap: .9rem; color: var(--berry); }

/* ---------- journal entries ---------- */
.journal { padding-block: clamp(3rem, 7vw, 5.5rem); }
.entries { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.entries--three { grid-template-columns: repeat(3, 1fr); }
.entry { background: #ffffff; padding: clamp(1.5rem, 3vw, 2.4rem); text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: .7rem; transition: background .25s; min-height: 220px; }
.entry:hover { background: var(--paper-warm); }
.entry .row { display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.entry .season { color: var(--berry); border: 1px solid var(--berry); padding: .08rem .45rem; border-radius: 100px; }
.entry h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.4rem, 2.5vw, 1.75rem); line-height: 1.1; margin-top: auto; }
.entry p { font-size: .95rem; color: var(--ink-soft); }
.entry .more { font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); margin-top: .3rem; display: inline-flex; gap: .4rem; transition: gap .25s, color .2s; }
.entry:hover .more { gap: .9rem; color: var(--berry); }

/* ---------- almanac ---------- */
.almanac { background: var(--pine); color: var(--paper); padding-block: clamp(3.5rem, 8vw, 6rem); }
.almanac .section-label h2 { color: color-mix(in srgb, var(--paper) 65%, transparent); }
.almanac .section-label::after { background: var(--pine-soft); }
.almanac-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.almanac .month { font-family: var(--serif); font-weight: 500; font-style: italic; font-size: clamp(2.5rem, 7vw, 4.5rem); line-height: .95; }
.almanac .month span { display: block; font-style: normal; font-size: .9rem; font-family: var(--mono); letter-spacing: .2em; text-transform: uppercase; color: var(--sage); margin-bottom: .6rem; }
.tasklist { list-style: none; }
.tasklist li { display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; align-items: baseline; padding: 1rem 0; border-top: 1px solid var(--pine-soft); }
.tasklist li:last-child { border-bottom: 1px solid var(--pine-soft); }
.tasklist .verb { font-family: var(--mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--sage); white-space: nowrap; }
.tasklist .what { color: color-mix(in srgb, var(--paper) 88%, transparent); font-size: 1rem; }

/* ---------- instagram strip ---------- */
.ig { padding-block: clamp(3rem, 7vw, 5.5rem); }
.ig-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 1rem; flex-wrap: wrap; margin-bottom: 2rem; }
.ig-head h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 3.5vw, 2.4rem); line-height: 1.05; letter-spacing: -.01em; }
.ig-head .handle { font-family: var(--mono); font-size: .8rem; color: var(--berry); text-decoration: none; }
.ig-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: .6rem; }
.ig-tile { position: relative; aspect-ratio: 1; overflow: hidden; border-radius: 3px; display: block; background: var(--paper-warm); }
.ig-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.ig-tile:hover img { transform: scale(1.06); }
.ig-tile .ig-cap {
  position: absolute; inset: 0; display: flex; align-items: flex-end; padding: .6rem;
  background: linear-gradient(180deg, transparent 40%, rgba(27,58,42,.78));
  color: var(--paper); font-family: var(--mono); font-size: .64rem; letter-spacing: .04em;
  opacity: 0; transition: opacity .3s;
}
.ig-tile:hover .ig-cap { opacity: 1; }
@media (max-width: 860px) { .ig-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 460px) { .ig-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- about ---------- */
.about { padding-block: clamp(3.5rem, 8vw, 6rem); }
.about-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.about .portrait { aspect-ratio: 4/5; border: 1px solid var(--line); background: #ffffff; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.about .portrait svg { width: 70%; height: 70%; opacity: .9; }
.about .portrait img { width: 100%; height: 100%; object-fit: cover; }
.about .portrait .cap { position: absolute; bottom: 0; left: 0; right: 0; font-family: var(--mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); padding: .6rem .8rem; border-top: 1px solid var(--line); background: #ffffff; }
.about h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.05; margin-block: 1rem 1.2rem; letter-spacing: -.01em; }
.about p { color: var(--ink-soft); margin-bottom: 1rem; max-width: 52ch; }
.about p em { color: var(--ink); font-style: italic; }

/* ---------- sub-page hero ---------- */
.page-hero { padding-block: clamp(2.5rem, 6vw, 4.5rem) clamp(2rem, 4vw, 3rem); border-bottom: 1px solid var(--line); }
.page-hero.on-pine { background: var(--pine); color: var(--paper); border-bottom: none; }
.page-hero.on-pine .eyebrow { color: var(--sage); }
.page-hero.on-pine .lede { color: color-mix(in srgb, var(--paper) 85%, transparent); }
.breadcrumb { font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 1.2rem; }
.breadcrumb a { text-decoration: none; }
.breadcrumb a:hover { color: var(--berry); }
.page-hero.on-pine .breadcrumb { color: color-mix(in srgb, var(--paper) 60%, transparent); }
.page-hero h1 { font-family: var(--serif); font-weight: 500; font-size: clamp(2.4rem, 6vw, 4.2rem); line-height: 1; letter-spacing: -.02em; margin-block: 1rem .9rem; max-width: 16ch; }
.page-hero .lede { font-size: clamp(1.05rem, 2vw, 1.25rem); color: var(--ink-soft); max-width: 52ch; }

/* ---------- prose (articles & topic pages) ---------- */
.prose { padding-block: clamp(3rem, 7vw, 5rem); }
.prose .col { max-width: 68ch; }
.prose p { margin-bottom: 1.3rem; color: var(--ink); }
.prose p.intro { font-size: 1.25rem; line-height: 1.55; color: var(--ink); }
.prose h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 3.5vw, 2.2rem); line-height: 1.1; margin: 2.6rem 0 1rem; letter-spacing: -.01em; }
.prose h3 { font-family: var(--serif); font-weight: 500; font-size: 1.35rem; margin: 1.8rem 0 .7rem; }
.prose ul, .prose ol { margin: 0 0 1.4rem 1.2rem; }
.prose li { margin-bottom: .55rem; }
.prose blockquote { border-left: 3px solid var(--berry); margin: 2rem 0; padding: .4rem 0 .4rem 1.4rem; font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--ink); }
.prose figure { margin: 2rem 0; }
.prose figure img { border: 1px solid var(--line); border-radius: 3px; }
.prose figcaption { font-family: var(--mono); font-size: .72rem; color: var(--ink-soft); margin-top: .6rem; letter-spacing: .03em; }
.prose hr { border: none; border-top: 1px solid var(--line); margin: 2.5rem 0; }

.callout {
  background: var(--paper-warm); border: 1px solid var(--line); border-radius: 4px;
  padding: 1.4rem 1.6rem; margin: 2rem 0;
}
.callout .label { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--berry); margin-bottom: .5rem; }
.callout p:last-child { margin-bottom: 0; }

.post-meta { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.post-meta .season { color: var(--berry); border: 1px solid var(--berry); padding: .08rem .45rem; border-radius: 100px; }

/* topic page: "what grows / what I do" two-up list */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); padding-block: clamp(2rem,5vw,3.5rem); }
.split .panel { border-top: 2px solid var(--pine); padding-top: 1.2rem; }
.split h3 { font-family: var(--serif); font-weight: 500; font-size: 1.5rem; margin-bottom: .8rem; }
.split ul { list-style: none; }
.split li { padding: .65rem 0; border-top: 1px dashed var(--line); display: flex; justify-content: space-between; gap: 1rem; font-size: .98rem; }
.split li:first-child { border-top: none; }
.split li .note { color: var(--ink-soft); font-family: var(--mono); font-size: .72rem; text-align: right; }

/* ---------- footer / subscribe ---------- */
footer { border-top: 1px solid var(--line); padding-block: clamp(3rem, 6vw, 4.5rem) 2.5rem; }
.sub h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 4vw, 2.4rem); line-height: 1.05; max-width: 18ch; letter-spacing: -.01em; }
.sub p { color: var(--ink-soft); margin-top: .8rem; max-width: 40ch; }
.sub-form { display: flex; gap: .6rem; margin-top: 1.6rem; max-width: 460px; flex-wrap: wrap; }
.sub-form input { flex: 1; min-width: 200px; font-family: var(--mono); font-size: .85rem; padding: .85rem 1rem; border: 1px solid var(--ink); background: transparent; color: var(--ink); border-radius: 2px; }
.sub-form input:focus { outline: 2px solid var(--berry); outline-offset: 1px; }
.sub-note { font-family: var(--mono); font-size: .74rem; color: var(--sage); margin-top: 1rem; min-height: 1.2em; }
.foot-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-top: clamp(2.5rem, 6vw, 4rem); padding-top: 1.5rem; border-top: 1px solid var(--line); font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); }
.foot-bottom a { text-decoration: none; }
.foot-bottom a:hover { color: var(--berry); }
.foot-links { display: flex; gap: 1.4rem; flex-wrap: wrap; }

/* ---------- journal filter ---------- */
.filters { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 2rem; }
.chip {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
  padding: .5rem .95rem; border: 1px solid var(--line); background: transparent; color: var(--ink-soft);
  border-radius: 100px; cursor: pointer; transition: color .2s, border-color .2s, background .2s;
}
.chip:hover { color: var(--berry); border-color: var(--berry); }
.chip.is-active { background: var(--pine); color: var(--paper); border-color: var(--pine); }
.chip:focus-visible { outline: 2px solid var(--berry); outline-offset: 2px; }

/* ---------- reveal ---------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  .almanac-grid { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .about .portrait { max-width: 320px; }
  .hero-inner { grid-template-columns: 1fr; }
  .ledger { width: 100%; max-width: 420px; margin-top: .25rem; }
}
@media (max-width: 760px) {
  .beds-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .entries, .entries--three { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .ledger-head .dot { animation: none; }
  .ig-tile img { transition: none; }
  html { scroll-behavior: auto; }
}


/* ============================================================
   WordPress-specific overrides (nav menus, content, comments)
   ============================================================ */

/* primary nav rendered as a <ul> by wp_nav_menu */
.topbar nav ul.nav-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 1.5rem; align-items: center; }
.topbar nav ul.nav-menu li { margin: 0; }
.topbar nav ul.nav-menu a { text-decoration: none; transition: color .2s; padding: .2rem 0; color: var(--ink-soft); }
.topbar nav ul.nav-menu a:hover { color: var(--berry); }
.topbar nav .current-menu-item > a,
.topbar nav .current_page_item > a { color: var(--ink); border-bottom: 1.5px solid var(--berry); }

@media (max-width: 860px) {
  .topbar nav { display: none; width: 100%; }
  .topbar nav.open { display: block; }
  .topbar nav ul.nav-menu { flex-direction: column; align-items: flex-start; gap: 0; width: 100%; }
  .topbar nav ul.nav-menu li { width: 100%; }
  .topbar nav ul.nav-menu a { display: block; width: 100%; padding: .7rem 0; border-top: 1px solid var(--line); }
  .topbar nav .current-menu-item > a,
  .topbar nav .current_page_item > a { border-bottom: none; color: var(--berry); }
}

/* footer menu */
.foot-links .nav-menu { display: flex; gap: 1.4rem; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.foot-links .nav-menu li { margin: 0; }
.foot-links .nav-menu a { text-decoration: none; }
.foot-links .nav-menu a:hover { color: var(--berry); }

/* the_content() lands inside .prose .col — make WP defaults behave */
.prose .col > *:first-child { margin-top: 0; }
.prose img { max-width: 100%; height: auto; border: 1px solid var(--line); border-radius: 3px; }
.prose .wp-caption, .prose figure { margin: 2rem 0; }
.prose .wp-caption-text, .prose figcaption { font-family: var(--mono); font-size: .72rem; color: var(--ink-soft); margin-top: .6rem; letter-spacing: .03em; }
.prose .alignleft { float: left; margin: .4rem 1.4rem 1rem 0; }
.prose .alignright { float: right; margin: .4rem 0 1rem 1.4rem; }
.prose .aligncenter { display: block; margin-inline: auto; }
.sticky, .bypostauthor { display: block; }
.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
