/* =====================================================================
   Masonic Heritage of North Munster — bespoke heritage stylesheet
   Palette: deep navy + antique gold + parchment + claret. No UI framework.
   Content is ALWAYS visible with CSS alone; JS is enhancement only.
   ===================================================================== */

:root{
  --navy-900:#0c1f33;
  --navy-800:#10283f;
  --navy-700:#14304d;
  --navy-600:#1f4e79;
  --gold-500:#c6a24a;
  --gold-400:#d8bd73;
  --gold-600:#a5842f;
  --claret:#7a1f2b;
  --parch-50:#faf6ee;
  --parch-100:#f6f1e6;
  --parch-200:#efe7d6;
  --ink:#23272e;
  --ink-soft:#4a5560;
  --muted:#6b7480;
  --rule:#ded2b8;
  --white:#ffffff;
  --maxw:1160px;
  --read:44rem;
  --serif-display:"Playfair Display",Georgia,"Times New Roman",serif;
  --serif-body:"Spectral",Georgia,"Times New Roman",serif;
  --shadow-sm:0 1px 2px rgba(12,31,51,.08),0 4px 14px rgba(12,31,51,.06);
  --shadow-md:0 10px 34px rgba(12,31,51,.16);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--serif-body);
  font-size:1.08rem;
  line-height:1.72;
  color:var(--ink);
  background:var(--parch-100);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy-600);text-underline-offset:2px;text-decoration-thickness:1px}
a:hover{color:var(--claret)}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.2rem)}

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

/* ---- CSS-only entrance: always ENDS visible (fill-mode both). If the
        animation never runs, content is already visible. ---------------- */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.reveal{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}

/* ---- Skip link ------------------------------------------------------- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy-700);color:#fff;padding:.6rem 1rem;z-index:200}
.skip-link:focus{left:.5rem;top:.5rem;color:#fff}

/* ---- Navigation ------------------------------------------------------ */
.site-nav{position:sticky;top:0;z-index:100;background:rgba(12,31,51,.98);border-bottom:2px solid var(--gold-600);box-shadow:var(--shadow-sm)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:68px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:#fff}
.brand-mark{width:30px;height:30px;flex:0 0 auto;background:
  linear-gradient(135deg,var(--gold-400),var(--gold-600));
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M8 52 L32 10 L56 52' fill='none' stroke='black' stroke-width='6' stroke-linejoin='round'/%3E%3Cpath d='M18 52 L32 26 L46 52' fill='none' stroke='black' stroke-width='4'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M8 52 L32 10 L56 52' fill='none' stroke='black' stroke-width='6' stroke-linejoin='round'/%3E%3Cpath d='M18 52 L32 26 L46 52' fill='none' stroke='black' stroke-width='4'/%3E%3C/svg%3E") center/contain no-repeat;
}
.brand-mark--gold{width:36px;height:36px}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:var(--serif-display);font-weight:700;font-size:1.12rem;letter-spacing:.02em;color:#fff}
.brand-sub{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-400)}
.nav-menu{list-style:none;display:flex;flex-wrap:wrap;gap:.15rem;margin:0;padding:0;align-items:center}
.nav-menu a{
  display:block;color:#e7ecf2;text-decoration:none;font-size:.82rem;letter-spacing:.05em;
  text-transform:uppercase;padding:.55rem .7rem;border-radius:3px;transition:color .18s,background .18s;white-space:nowrap;
}
.nav-menu a:hover{color:#fff;background:rgba(198,162,74,.16)}
.nav-menu a.is-active{color:var(--gold-400)}
.nav-menu a.is-active::after{content:"";display:block;height:2px;background:var(--gold-500);margin-top:3px;border-radius:2px}
.nav-toggle{display:none;background:transparent;border:1px solid rgba(216,189,115,.5);border-radius:5px;width:44px;height:40px;cursor:pointer;padding:9px 10px}
.nav-toggle span{display:block;height:2px;background:var(--gold-400);margin:4px 0;transition:.2s}

/* ---- Hero (home) ----------------------------------------------------- */
.hero{position:relative;background-size:cover;background-position:center;color:#fff;overflow:hidden}
.hero--home{min-height:clamp(440px,72vh,640px);display:flex;align-items:center}
.hero-inner{max-width:var(--maxw);margin-inline:auto;padding:clamp(2.4rem,7vw,5rem) clamp(1.1rem,4vw,2.2rem)}
.hero-inner h1{font-family:var(--serif-display);font-weight:800;color:#fff;font-size:clamp(2.3rem,5.6vw,4rem);line-height:1.04;margin:.2em 0 .3em;text-shadow:0 2px 18px rgba(0,0,0,.35);max-width:16ch}
.hero-sub{font-size:clamp(1.05rem,2vw,1.32rem);max-width:40ch;color:#f2ede2;font-style:italic}
.hero-cta{margin-top:1.7rem;display:flex;gap:.8rem;flex-wrap:wrap}
.hero-rule{position:absolute;left:0;right:0;bottom:0;height:5px;background:linear-gradient(90deg,var(--gold-600),var(--gold-400),var(--gold-600))}
.kicker{font-family:var(--serif-body);text-transform:uppercase;letter-spacing:.3em;font-size:.74rem;font-weight:600;color:var(--gold-600);margin:0 0 .2rem}
.kicker--light{color:var(--gold-400)}

/* ---- Buttons --------------------------------------------------------- */
.btn{display:inline-block;font-family:var(--serif-body);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.8rem 1.5rem;border-radius:2px;text-decoration:none;transition:.2s;border:1px solid transparent;cursor:pointer}
.btn--gold{background:linear-gradient(180deg,var(--gold-400),var(--gold-600));color:#22190a;font-weight:600;box-shadow:var(--shadow-sm)}
.btn--gold:hover{filter:brightness(1.07);color:#22190a;transform:translateY(-1px)}
.btn--ghost{border-color:rgba(216,189,115,.7);color:#fff}
.btn--ghost:hover{background:rgba(216,189,115,.16);color:#fff}

/* ---- Interior page header ------------------------------------------- */
.page-header{background:
  radial-gradient(120% 140% at 80% -10%, rgba(31,78,121,.55), transparent 60%),
  linear-gradient(160deg,var(--navy-800),var(--navy-700));
  color:#fff;padding:clamp(2.4rem,6vw,3.8rem) 0 clamp(2rem,5vw,3rem);border-bottom:3px solid var(--gold-600)}
.page-header h1{font-family:var(--serif-display);font-weight:800;font-size:clamp(1.9rem,4.4vw,3.1rem);line-height:1.08;color:#fff;margin:.15em 0 .1em;max-width:22ch}
.page-header--404 h1{max-width:18ch}
.divider{display:block;width:88px;height:0;border-top:2px solid var(--gold-500);margin-top:1.2rem;position:relative}
.divider::after{content:"";position:absolute;left:36px;top:-6px;width:11px;height:11px;background:var(--gold-500);transform:rotate(45deg)}

/* ---- Prose / reading column ----------------------------------------- */
.prose{padding-block:clamp(2.2rem,5vw,3.4rem);max-width:calc(var(--read) + 6rem)}
.prose > *{max-width:var(--read)}
.prose figure,.prose .callout{max-width:100%}
.prose h1{font-family:var(--serif-display);font-weight:800;font-size:2.3rem;line-height:1.1;color:var(--navy-700);margin:.2em 0 .5em}
.prose h2{font-family:var(--serif-display);font-weight:700;font-size:1.68rem;line-height:1.18;color:var(--navy-700);margin:2.1rem 0 .6rem;padding-bottom:.35rem;border-bottom:1px solid var(--rule)}
.prose h3{font-family:var(--serif-display);font-weight:700;font-size:1.28rem;color:var(--navy-800);margin:1.5rem 0 .4rem}
.prose p{margin:0 0 1.15rem}
.prose a{font-weight:500}
.prose ul,.prose ol{margin:0 0 1.2rem;padding-left:1.3rem}
.prose li{margin:.35rem 0}
.prose strong{color:var(--navy-800)}
.prose em{color:var(--ink-soft)}
.lede{font-size:1.28rem;line-height:1.6;color:var(--ink-soft);font-style:italic;margin-bottom:1.4rem}
.lede::first-letter{font-family:var(--serif-display);font-style:normal;font-weight:800;float:left;font-size:3.4rem;line-height:.82;padding:.2rem .6rem .1rem 0;color:var(--claret)}

/* figures */
.prose figure{margin:1.8rem 0 1.9rem}
.prose figure img{width:100%;border-radius:3px;box-shadow:var(--shadow-md);border:1px solid var(--parch-200)}
.prose figcaption{font-size:.9rem;color:var(--muted);font-style:italic;margin-top:.6rem;padding-left:.9rem;border-left:2px solid var(--gold-500)}

/* blockquote */
.prose blockquote{margin:1.6rem 0;padding:1.1rem 1.4rem;background:var(--parch-50);border-left:4px solid var(--gold-500);
  font-family:var(--serif-display);font-style:italic;font-size:1.24rem;color:var(--navy-800);border-radius:0 4px 4px 0}
.prose blockquote p{margin:.2rem 0}

/* callout card */
.callout{background:var(--white);border:1px solid var(--parch-200);border-top:3px solid var(--gold-500);
  border-radius:4px;padding:1.3rem 1.5rem;margin:1.8rem 0;box-shadow:var(--shadow-sm)}
.callout h3{margin-top:.2rem;color:var(--navy-700)}
.callout ul{margin-bottom:.2rem}

/* independence note */
.note-independent{font-size:.9rem;color:var(--muted);border-top:1px solid var(--rule);padding-top:1rem;margin-top:2.2rem}

/* sitemap list */
.sitemap-list{list-style:none;padding-left:0}
.sitemap-list li{padding:.5rem 0;border-bottom:1px dashed var(--rule)}
.sitemap-list a{font-weight:600;font-family:var(--serif-display)}

/* ---- Contact form ---------------------------------------------------- */
.contact-form{background:var(--white);border:1px solid var(--parch-200);border-radius:5px;padding:1.5rem;margin:1.4rem 0 1.8rem;box-shadow:var(--shadow-sm);max-width:var(--read)}
.contact-form .field{margin-bottom:1rem}
.contact-form label{display:block;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.35rem}
.contact-form input,.contact-form textarea{width:100%;padding:.7rem .8rem;font-family:var(--serif-body);font-size:1rem;color:var(--ink);
  background:var(--parch-50);border:1px solid var(--rule);border-radius:3px}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--navy-600);box-shadow:0 0 0 3px rgba(31,78,121,.14)}
.contact-form .btn{background:linear-gradient(180deg,var(--navy-600),var(--navy-700));color:#fff;border:none;font-weight:600}
.contact-form .btn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* ---- Footer ---------------------------------------------------------- */
.site-footer{background:linear-gradient(180deg,var(--navy-800),var(--navy-900));color:#c9d3de;margin-top:3rem;border-top:3px solid var(--gold-600)}
.site-footer .wrap{padding-block:2.6rem}
.foot-brand{display:flex;flex-direction:column;gap:.15rem;margin-bottom:1.8rem}
.foot-name{font-family:var(--serif-display);font-weight:700;font-size:1.3rem;color:#fff;margin:.5rem 0 0}
.foot-tag{color:#9fb0c1;font-style:italic;margin:.2rem 0 0}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.foot-col h4{font-family:var(--serif-body);text-transform:uppercase;letter-spacing:.2em;font-size:.76rem;color:var(--gold-400);margin:0 0 .7rem}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{margin:.35rem 0}
.foot-col a{color:#cdd8e4;text-decoration:none;font-size:.96rem}
.foot-col a:hover{color:#fff;text-decoration:underline;text-decoration-color:var(--gold-500)}
.foot-legal{border-top:1px solid rgba(255,255,255,.12);padding-block:1.3rem !important}
.foot-legal p{font-size:.82rem;color:#8394a6;margin:0;line-height:1.55}

/* ---- Responsive ------------------------------------------------------ */
@media (max-width:860px){
  .nav-toggle{display:block}
  .nav-menu{
    position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(10,26,42,.99);border-bottom:2px solid var(--gold-600);
    max-height:0;overflow:hidden;transition:max-height .28s ease;padding:0}
  .nav-menu.open{max-height:80vh;padding:.4rem 0 .8rem}
  .nav-menu li{border-top:1px solid rgba(255,255,255,.06)}
  .nav-menu a{padding:.9rem 1.4rem;font-size:.92rem}
  .nav-menu a.is-active::after{display:none}
  .foot-cols{grid-template-columns:1fr 1fr;gap:1.2rem}
}
@media (max-width:520px){
  .foot-cols{grid-template-columns:1fr}
  .lede::first-letter{font-size:2.8rem}
  .hero-cta{flex-direction:column;align-items:flex-start}
  .btn{width:auto}
}
