/* Greater Peterborough Guide — "Monadnock Almanac" civic-editorial theme
   Garnet + harvest gold on cream. Zilla Slab (display) + Public Sans (body).
   Content is ALWAYS visible: no opacity:0 / JS-gated reveals anywhere. */

:root{
  --garnet:#8a2b2b;
  --garnet-dark:#6b1f1f;
  --garnet-soft:#a84a45;
  --gold:#b9852b;
  --gold-light:#e6c079;
  --ink:#2b2723;
  --ink-soft:#5d554c;
  --cream:#f7f1e5;
  --paper:#fffdf7;
  --line:#e5dcc6;
  --forest:#37503f;
  --shadow:0 6px 22px rgba(43,39,35,.10);
  --shadow-sm:0 2px 8px rgba(43,39,35,.08);
  --wrap:1140px;
  --radius:6px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--garnet);text-decoration:none}
a:hover{color:var(--garnet-dark);text-decoration:underline}
.container{max-width:var(--wrap);margin:0 auto;padding:0 22px}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,253,247,.96);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 var(--gold-light);
}
.nav-bar{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none}
.brand:hover{text-decoration:none}
.brand .mark{color:var(--garnet);font-size:1.7rem;line-height:1}
.brand .word{display:flex;flex-direction:column;line-height:1.05}
.brand .word b{font-family:"Zilla Slab",Georgia,serif;font-weight:700;font-size:1.28rem;letter-spacing:.2px;color:var(--ink)}
.brand .word span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700}

.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav-links a{
  color:var(--ink-soft);font-weight:600;font-size:.95rem;padding:9px 12px;border-radius:var(--radius);
  text-decoration:none;transition:color .15s,background .15s;
}
.nav-links a:hover,.nav-links a.active{color:var(--garnet);background:#f3e9d5}
.nav-toggle,.nav-toggle-label{display:none}

/* ---------- Hero image banner ---------- */
.page-hero{margin:0 0 8px}
.page-hero figure{margin:0}
.page-hero img{
  width:100%;max-height:440px;object-fit:cover;border-radius:10px;
  border:1px solid var(--line);box-shadow:var(--shadow);
}
main{display:block;padding:28px 0 10px}
.home main{padding-top:24px}

/* ---------- Prose / article ---------- */
.prose{max-width:768px;margin:0 auto}
.home .prose{max-width:860px}
.prose h1{
  font-family:"Zilla Slab",Georgia,serif;font-weight:700;
  font-size:2.5rem;line-height:1.12;color:var(--ink);margin:.2em 0 .35em;letter-spacing:-.01em;
}
.prose h2{
  font-family:"Zilla Slab",Georgia,serif;font-weight:600;
  font-size:1.6rem;color:var(--garnet);margin:1.8em 0 .5em;padding-top:.2em;
}
.prose h2::after{content:"";display:block;width:52px;height:3px;background:var(--gold);margin-top:.35em;border-radius:2px}
.prose h3{font-family:"Zilla Slab",Georgia,serif;font-weight:600;font-size:1.24rem;color:var(--ink);margin:1.4em 0 .4em}
.prose p{margin:0 0 1.1em}
.prose .lede{font-size:1.24rem;line-height:1.6;color:var(--ink-soft);margin-bottom:1.2em}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em}
.prose li{margin:.35em 0}
.prose strong{color:var(--ink)}
.prose em{color:var(--ink-soft)}

/* ---------- Non-affiliation disclaimer ---------- */
.disclaimer{
  background:#f6ecd6;border:1px solid var(--gold-light);border-left:5px solid var(--gold);
  border-radius:var(--radius);padding:14px 18px;margin:0 0 1.6em;
}
.disclaimer p{margin:0;font-size:.95rem;color:var(--ink-soft)}
.disclaimer strong{color:var(--garnet-dark)}

/* ---------- Home explore grid ---------- */
.explore{margin:2.6em 0 1em}
.explore h2{font-family:"Zilla Slab",Georgia,serif;color:var(--garnet);font-size:1.6rem;margin:0 0 .1em}
.explore .sub{color:var(--ink-soft);margin:0 0 1.1em}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:16px}
.card{
  display:block;background:var(--paper);border:1px solid var(--line);border-radius:8px;
  padding:20px 20px 18px;color:var(--ink);text-decoration:none;box-shadow:var(--shadow-sm);
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold-light);text-decoration:none}
.card .ic{color:var(--garnet);font-size:1.35rem;margin-bottom:.5em}
.card b{display:block;font-family:"Zilla Slab",Georgia,serif;font-size:1.12rem;color:var(--ink);margin-bottom:.25em}
.card span{color:var(--ink-soft);font-size:.92rem}

/* ---------- Contact form ---------- */
.contact-form{display:grid;gap:14px;max-width:560px;margin:1.2em 0 1em}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--ink);font-size:.95rem}
.contact-form input,.contact-form textarea{
  font:inherit;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--paper);color:var(--ink);
}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--gold-light);border-color:var(--gold)}
.contact-form button,.btn{
  justify-self:start;background:var(--garnet);color:#fff;border:0;border-radius:var(--radius);
  padding:12px 22px;font:inherit;font-weight:700;cursor:pointer;transition:background .15s;
}
.contact-form button:hover,.btn:hover{background:var(--garnet-dark);color:#fff;text-decoration:none}
.small{font-size:.9rem;color:var(--ink-soft)}

/* ---------- Footer ---------- */
.site-footer{margin-top:44px;background:var(--ink);color:#d9cfc0}
.site-footer a{color:#ecd9b0}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;padding:44px 0 26px}
.footer-brand .fb{font-family:"Zilla Slab",Georgia,serif;font-weight:700;font-size:1.25rem;color:#fff;margin:0 0 .3em}
.footer-brand p{font-size:.92rem;line-height:1.6;color:#c3b8a7;margin:.2em 0 .8em}
.footer-brand .note{font-size:.82rem;color:#a99e8c;border-top:1px solid #40382f;padding-top:.8em;margin-top:.6em}
.footer-col h4{font-family:"Zilla Slab",Georgia,serif;font-size:1rem;color:var(--gold-light);margin:.2em 0 .6em;letter-spacing:.03em}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:.34em 0}
.footer-col a{font-size:.92rem;text-decoration:none}
.footer-bottom{border-top:1px solid #40382f;padding:16px 0;font-size:.85rem;color:#a99e8c;text-align:center}

/* ---------- 404 ---------- */
.err{max-width:640px;margin:60px auto;text-align:center}
.err h1{font-family:"Zilla Slab",Georgia,serif;font-size:5rem;color:var(--garnet);margin:0}
.err p{color:var(--ink-soft);font-size:1.15rem}

/* ---------- Safeguard: never leave content hidden waiting on JS ---------- */
[data-aos]{opacity:1 !important;transform:none !important}

/* ---------- Responsive ---------- */
@media (max-width:820px){
  body{font-size:17px}
  .prose h1{font-size:2.05rem}
  .nav-toggle-label{
    display:inline-flex;align-items:center;justify-content:center;
    width:44px;height:40px;border:1px solid var(--line);border-radius:var(--radius);
    color:var(--garnet);font-size:1.2rem;cursor:pointer;background:var(--paper);
  }
  .nav-links{
    position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    max-height:0;overflow:hidden;transition:max-height .25s ease;
  }
  .nav-links a{padding:14px 22px;border-top:1px solid var(--line);border-radius:0}
  .nav-toggle:checked ~ .nav-links{max-height:640px}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .page-hero img{max-height:300px}
}
@media (max-width:480px){
  .prose h1{font-size:1.8rem}
  .card-grid{grid-template-columns:1fr}
}
