
:root{
  --ink:#23343B; --muted:#6C7A80; --paper:#FFF8F0; --ivory:#FFFDF8;
  --red:#8B2F2F; --red2:#B84A3A; --gold:#D9A441; --teal:#264653; --line:#EADBC8;
  --shadow:0 18px 45px rgba(35,52,59,.10);
  --radius:22px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;background:linear-gradient(180deg,#fff8f0 0%,#ffffff 40%,#f8f4ed 100%);color:var(--ink);font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Arial, sans-serif;line-height:1.65}
a{color:inherit} img{max-width:100%}
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,248,240,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{max-width:1220px;margin:auto;padding:16px 20px;display:flex;gap:22px;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.brand img{width:220px;max-height:140px;height:auto;object-fit:contain}.brand b{font-family:Georgia,serif;font-size:24px}.brand span{display:block;font-size:15px;color:var(--muted);margin-top:-2px}
.navlinks{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.navlinks a{font-size:14px;text-decoration:none;padding:9px 12px;border-radius:999px;color:#30444c}
.navlinks a:hover,.navlinks a.active{background:#fff;border:1px solid var(--line);box-shadow:0 5px 18px rgba(0,0,0,.04)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff!important;text-decoration:none;padding:12px 18px;border-radius:999px;border:0;cursor:pointer;font-weight:700;box-shadow:0 12px 24px rgba(139,47,47,.20)}
.btn.secondary{background:#fff;color:var(--red)!important;border:1px solid var(--line);box-shadow:none}.btn.gold{background:var(--gold);color:#34210d!important}
.hero{max-width:1220px;margin:auto;padding:70px 20px 42px;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.eyebrow{color:var(--red);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:12px}
h1,h2,h3{line-height:1.15;margin:0 0 16px} h1{font-family:Georgia,serif;font-size:clamp(44px,6vw,76px);letter-spacing:-.04em} h2{font-family:Georgia,serif;font-size:clamp(30px,4vw,46px)} h3{font-size:22px}
.lead{font-size:20px;color:#3e5158;max-width:760px}
.hero-card{background:rgba(255,255,255,.76);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;position:relative;overflow:hidden}
.hero-card:before{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;background:radial-gradient(circle,var(--gold),transparent 68%);opacity:.3}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;text-align:center}.stat b{font-size:29px;color:var(--red);display:block}.stat span{font-size:13px;color:var(--muted)}
.section{max-width:1220px;margin:auto;padding:42px 20px}.section.narrow{max-width:920px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.grid.two{grid-template-columns:repeat(2,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}
.card{background:rgba(255,255,255,.86);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:0 12px 32px rgba(35,52,59,.07)}
.card h3{color:var(--teal)}.muted{color:var(--muted)}.kicker{display:inline-block;padding:5px 10px;border-radius:999px;background:#F7E9D9;color:var(--red);font-weight:700;font-size:12px;margin-bottom:12px}
.content-layout{max-width:1220px;margin:auto;padding:34px 20px 70px;display:grid;grid-template-columns:270px minmax(0,1fr);gap:28px}
.content-layout.no-sidebar{grid-template-columns:1fr;max-width:980px}
.sidebar{position:sticky;top:95px;height:max-content;background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.05)}
.sidebar a{display:block;text-decoration:none;padding:9px 10px;border-radius:12px;color:#425961;font-size:14px}.sidebar a:hover{background:#fff8f0;color:var(--red)}
.doc-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.doc-block{padding:14px 0;border-bottom:1px solid #f2e8dc;white-space:pre-wrap}.doc-block:first-child{font-size:23px;font-family:Georgia,serif;font-weight:800;color:var(--red)}.doc-block:last-child{border-bottom:0}
.content-subtitle{font-size:30px;margin:30px 0 8px;padding:18px 0 10px;border-bottom:2px solid var(--line);color:var(--red)}
.form{display:grid;gap:14px}.input,.textarea,.select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:14px;background:#fff;font:inherit}.textarea{min-height:110px}
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}.table th{background:#fff8f0;color:var(--red)}
.footer{margin-top:40px;background:#24343b;color:#fff}.footer-inner{max-width:1220px;margin:auto;padding:42px 20px;display:grid;grid-template-columns:1.3fr .7fr .7fr;gap:30px}.footer a{color:#fff;text-decoration:none}.micro-login{font-size:10px;opacity:.25;text-align:center;padding:10px}.micro-login:hover{opacity:.9}
.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.admin-side{background:#24343b;color:#fff;padding:24px}.admin-side a{display:block;color:#fff;text-decoration:none;padding:10px;border-radius:12px}.admin-side a:hover,.admin-side a.active{background:rgba(255,255,255,.12)}.admin-main{padding:28px;background:#f8f4ed}
.notice{border-left:4px solid var(--gold);background:#fff8e8;padding:14px 16px;border-radius:12px;margin:12px 0}.success{border-left-color:#2e7d32;background:#edf8ee}
.full-doc{max-height:72vh;overflow:auto}
.map{width:100%;height:360px;border:0;border-radius:20px;border:1px solid var(--line)}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.photo{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px}.photo .thumb{aspect-ratio:4/3;border-radius:14px;background:#fff8f0;display:grid;place-items:center;overflow:hidden}.photo .thumb img{height:100%;object-fit:contain}
@media(max-width:900px){.hero,.content-layout,.grid,.grid.two,.grid.four,.footer-inner,.admin-shell{grid-template-columns:1fr}.nav{align-items:flex-start}.navlinks{display:none}.sidebar{position:relative;top:0}.hero{padding-top:34px}}
/* v2.2: Section navigation removed from public document pages. */
.content-layout.no-sidebar .sidebar{display:none}

/* v2.6: Hide paid membership pricing content only; keep membership registration visible. */
.hidden-paid-membership,
#plansGrid.hidden-paid-membership {
  display: none !important;
}

/* v2.7: Remove the paid membership plan area on the Membership page. */
body[data-page="membership"] #plansGrid,
body[data-page="membership"] .hidden-paid-membership {
  display: none !important;
}

/* v2.9: Hide fee/pricing panels on Membership page only. */
body[data-page="membership"] #plansGrid,
body[data-page="membership"] .hidden-paid-membership {
  display: none !important;
}

/* v3.0: Membership page is registration-only. Pricing/payment areas are removed from renderer and hidden as fallback. */
body[data-page="membership"] #plansGrid,
body[data-page="membership"] .hidden-paid-membership,
body[data-page="membership"] .payment-area,
body[data-page="membership"] .pricing-area,
body[data-page="membership"] .fee-area,
body[data-page="membership"] .donation-area {
  display: none !important;
}


/* v3.2: Mobile-friendly responsive layout */
.mobile-menu-toggle {
  display: none;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0,0,0,.05);
}

@media (max-width: 900px) {
  body {
    font-size: 16px;
    overflow-x: hidden;
  }

  .topbar {
    position: sticky;
    top: 0;
  }

  .nav {
    padding: 10px 14px;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
  }

  .brand {
    flex: 1 1 auto;
    min-width: 0;
    gap: 10px;
  }

  .brand img {
    width: 96px !important;
    max-height: 96px !important;
  }

  .brand b {
    font-size: 20px !important;
    line-height: 1.1;
  }

  .brand span {
    font-size: 14px !important;
  }

  .mobile-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .navlinks {
    display: none !important;
    flex: 1 0 100%;
    width: 100%;
    background: rgba(255,255,255,.96);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 10px;
    box-shadow: 0 10px 28px rgba(35,52,59,.12);
  }

  .navlinks.open {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .navlinks a {
    display: block;
    text-align: center;
    padding: 12px 10px;
    font-size: 14px;
    border: 1px solid #f1e4d4;
    background: #fff;
  }

  .hero {
    display: block;
    padding: 34px 16px 22px;
  }

  .hero-card {
    margin-top: 22px;
    padding: 18px;
  }

  h1 {
    font-size: clamp(36px, 12vw, 52px);
  }

  h2 {
    font-size: clamp(28px, 9vw, 38px);
  }

  h3 {
    font-size: 20px;
  }

  .lead {
    font-size: 18px;
  }

  .section,
  .content-layout,
  .content-layout.no-sidebar {
    padding-left: 16px;
    padding-right: 16px;
    max-width: 100%;
  }

  .content-layout,
  .content-layout.no-sidebar,
  .grid,
  .grid.two,
  .grid.four,
  .stats,
  .footer-inner,
  .admin-shell {
    grid-template-columns: 1fr !important;
  }

  .doc-panel,
  .card {
    padding: 20px;
    border-radius: 18px;
  }

  .doc-block {
    font-size: 15.5px;
    line-height: 1.75;
  }

  .content-subtitle {
    font-size: 24px;
  }

  .table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .input,
  .textarea,
  .select,
  .btn {
    width: 100%;
    font-size: 16px;
  }

  .btn {
    justify-content: center;
    padding: 13px 16px;
  }

  .map {
    height: 300px;
  }

  .photo-grid {
    grid-template-columns: 1fr !important;
  }

  .footer-inner {
    padding: 30px 18px;
  }

  .footer-inner img {
    max-width: 220px !important;
  }

  .admin-shell {
    display: block;
  }

  .admin-side {
    position: relative;
    width: 100%;
  }

  .admin-main {
    padding: 18px;
  }
}

@media (max-width: 480px) {
  .brand img {
    width: 82px !important;
    max-height: 82px !important;
  }

  .brand b {
    font-size: 18px !important;
  }

  .navlinks.open {
    grid-template-columns: 1fr;
  }

  .hero,
  .section,
  .content-layout,
  .content-layout.no-sidebar {
    padding-left: 12px;
    padding-right: 12px;
  }

  h1 {
    font-size: 36px;
  }

  .lead {
    font-size: 17px;
  }

  .card,
  .doc-panel,
  .hero-card {
    padding: 18px;
  }
}



/* v3.3: Reliable mobile menu toggle visibility */
@media (max-width: 900px) {
  .navlinks.open {
    display: grid !important;
    visibility: visible !important;
    opacity: 1 !important;
    max-height: none !important;
    position: static !important;
    z-index: 999 !important;
  }
  .mobile-menu-toggle {
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
  }
}


/* v3.4: Phone-only category tags under the logo/header section */
.mobile-category-tags {
  display: none;
}

@media (max-width: 900px) {
  .mobile-category-tags {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 8px 14px 12px;
    border-top: 1px solid rgba(234,219,200,.75);
    background: rgba(255,248,240,.96);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .mobile-category-tags a {
    flex: 0 0 auto;
    text-decoration: none;
    color: #30444c;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 4px 12px rgba(35,52,59,.05);
    white-space: nowrap;
  }

  .mobile-category-tags a.active,
  .mobile-category-tags a:hover {
    color: #fff;
    background: var(--red);
    border-color: var(--red);
  }

  /* With always-visible mobile tags, keep the drop-down menu as an optional secondary nav. */
  .navlinks.open {
    margin-top: 6px;
  }
}

@media (max-width: 480px) {
  .mobile-category-tags {
    padding-left: 12px;
    padding-right: 12px;
  }

  .mobile-category-tags a {
    font-size: 12.5px;
    padding: 8px 11px;
  }
}


/* v3.5: Phone category tags use solid backgrounds, larger spacing, and wrap to multiple lines */
@media (max-width: 900px) {
  .mobile-category-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px 12px !important;
    overflow-x: visible !important;
    padding: 14px 16px 16px !important;
    background: #fff8f0 !important;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }

  .mobile-category-tags a {
    flex: 0 0 auto !important;
    color: #ffffff !important;
    background: var(--red) !important;
    border: 1px solid var(--red) !important;
    border-radius: 999px !important;
    padding: 11px 16px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    box-shadow: 0 7px 16px rgba(139,47,47,.18) !important;
    white-space: nowrap !important;
  }

  .mobile-category-tags a.active {
    background: var(--gold) !important;
    border-color: var(--gold) !important;
    color: #34210d !important;
    box-shadow: 0 7px 16px rgba(217,164,65,.22) !important;
  }

  .mobile-category-tags a:hover {
    background: var(--teal) !important;
    border-color: var(--teal) !important;
    color: #ffffff !important;
  }
}

@media (max-width: 480px) {
  .mobile-category-tags {
    gap: 10px 10px !important;
    padding: 12px 12px 14px !important;
  }

  .mobile-category-tags a {
    padding: 10px 14px !important;
    font-size: 13.5px !important;
  }
}


/* v3.6: Remove phone Menu button and tighten solid category tag spacing */
.mobile-menu-toggle {
  display: none !important;
}

@media (max-width: 900px) {
  .mobile-category-tags {
    gap: 6px 6px !important;
    padding: 10px 12px 12px !important;
  }

  .mobile-category-tags a {
    padding: 9px 12px !important;
    font-size: 13.5px !important;
    box-shadow: 0 4px 10px rgba(139,47,47,.14) !important;
  }
}

@media (max-width: 480px) {
  .mobile-category-tags {
    gap: 5px 5px !important;
    padding: 9px 10px 11px !important;
  }

  .mobile-category-tags a {
    padding: 8px 10px !important;
    font-size: 13px !important;
  }
}


/* v3.7: Lighter phone category tags with no gaps between them */
@media (max-width: 900px) {
  .mobile-category-tags {
    gap: 0 !important;
    padding: 10px 12px 12px !important;
  }

  .mobile-category-tags a {
    margin: 0 !important;
    background: #F6D7C8 !important;
    border-color: #E8B9A7 !important;
    color: #5B2424 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  .mobile-category-tags a:first-child {
    border-top-left-radius: 999px !important;
    border-bottom-left-radius: 999px !important;
  }

  .mobile-category-tags a:last-child {
    border-top-right-radius: 999px !important;
    border-bottom-right-radius: 999px !important;
  }

  .mobile-category-tags a.active {
    background: #E7B96A !important;
    border-color: #D9A441 !important;
    color: #34210d !important;
  }

  .mobile-category-tags a:hover {
    background: #EDD0BE !important;
    border-color: #E3B49D !important;
    color: #5B2424 !important;
  }
}

@media (max-width: 480px) {
  .mobile-category-tags {
    gap: 0 !important;
    padding: 9px 10px 11px !important;
  }

  .mobile-category-tags a {
    padding: 8px 9px !important;
    font-size: 12.5px !important;
  }
}
