/* ============================================================
   Bloom Township — interior page styles
   Extends styles.css. Loaded only on sub-pages.
   ============================================================ */

/* ---- Active nav state (interior pages) ---- */
.nav a.current,.nav .has-drop.current > .navlink{background:rgba(255,255,255,.16)}
.dropdown a.current{background:#eef3e9;color:var(--green)}
/* Keep the CTA button readable on its own page (avoid green-on-green) */
.nav a.nav-cta.current{background:#fff!important;color:var(--green)!important;box-shadow:inset 0 0 0 2px var(--green)}

/* ---- Legal / long-form prose pages ---- */
.legal-prose{max-width:820px}
.legal-prose h2{font-size:clamp(22px,2.4vw,28px)}
.legal-prose h3{font-size:18px;margin:26px 0 8px}
.legal-prose .updated{font-size:14px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin:0 0 26px}
.legal-prose ul li::before{top:10px}

/* ---- 404 ---- */
.nf{min-height:52vh;display:grid;place-items:center;text-align:center;padding:70px 0}
.nf .code{font-size:clamp(72px,16vw,150px);font-weight:700;line-height:.9;letter-spacing:-.04em;color:var(--green);margin:0}
.nf h1{font-size:clamp(26px,4vw,38px);margin:14px 0 10px;color:var(--ink)}
.nf p{color:var(--ink-soft);font-size:17px;max-width:520px;margin:0 auto 8px;text-wrap:pretty}
.nf .nf-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.nf .links{margin-top:30px;display:flex;gap:8px 18px;justify-content:center;flex-wrap:wrap;font-size:15.5px}
.nf .links a{color:var(--blue);font-weight:500}

/* ---- Page banner ---- */
.page-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(150deg,#0a5d18 0%,#004300 58%,#012c00 100%);
  color:#fff;
}
.page-hero::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background:
    radial-gradient(720px 320px at 88% -30%,rgba(255,255,255,.10),transparent),
    radial-gradient(560px 260px at 8% 130%,rgba(0,0,0,.30),transparent);
}
.page-hero .wrap{position:relative;z-index:1;padding:30px 28px 46px;max-width:var(--maxw)}
.crumb{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13.5px;color:#bfe0bd;margin-bottom:26px}
.crumb a{color:#dcefda}
.crumb a:hover{color:#fff;text-decoration:none}
.crumb .sep{opacity:.5}
.crumb .here{color:#fff;font-weight:500}
.page-hero .eyebrow{color:#a7d9ab;margin-bottom:12px}
.page-head{display:flex;align-items:center;gap:20px}
.page-head .hicon{
  width:60px;height:60px;border-radius:14px;flex:none;display:grid;place-items:center;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;
}
.page-head .hicon svg{width:30px;height:30px;stroke-width:1.7;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.page-hero h1{font-size:clamp(30px,4.4vw,46px);letter-spacing:-.02em;line-height:1.04}
.page-hero .lede{font-size:clamp(17px,2vw,20px);color:#e3efe1;font-weight:300;max-width:680px;margin-top:18px}
.page-hero .lede strong{font-weight:600;color:#fff}

/* ---- Page layout: content + aside ---- */
.page{padding:56px 0 76px}
.page-layout{display:grid;grid-template-columns:minmax(0,1fr) 332px;gap:52px;align-items:start}
.page-main{min-width:0}

/* ---- Prose ---- */
.prose{color:var(--ink-soft);font-size:17px}
.prose > *:first-child{margin-top:0}
.prose h2{
  font-size:clamp(23px,2.6vw,30px);color:var(--ink);letter-spacing:-.01em;
  margin:46px 0 16px;padding-bottom:12px;border-bottom:2px solid var(--line);
}
.prose h2:first-child{margin-top:0}
.prose h2 a{color:inherit;font-weight:inherit;text-decoration:none}
.prose h2 a:hover{color:var(--green-600);text-decoration:underline;text-underline-offset:3px}
.prose h3{font-size:20px;color:var(--ink);margin:30px 0 10px}
.prose p{margin:0 0 1.05em;max-width:68ch;text-wrap:pretty}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--blue);font-weight:500}
.prose ul{margin:0 0 1.2em;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;max-width:64ch}
.prose ul li{position:relative;padding-left:30px;line-height:1.5}
.prose ul li::before{
  content:"";position:absolute;left:4px;top:9px;width:8px;height:8px;border-radius:2px;
  background:var(--green-600);transform:rotate(45deg);
}
.prose .lead{font-size:19px;color:var(--ink);font-weight:400;line-height:1.55;max-width:66ch}

/* ---- Callout ---- */
.callout{
  display:flex;gap:16px;align-items:flex-start;
  background:#eef3e9;border:1px solid #d6e3cd;border-left:4px solid var(--green-600);
  border-radius:var(--radius);padding:20px 22px;margin:26px 0;
}
.callout svg{width:22px;height:22px;flex:none;color:var(--green);stroke-width:1.8;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;margin-top:1px}
.callout p{margin:0;font-size:15.5px;color:#3c4733}
.callout p b{color:var(--green-900)}
.callout.warn{background:#fbf3df;border-color:#ecdcb0;border-left-color:var(--gold)}
.callout.warn svg{color:var(--gold)}
.callout.warn p{color:#5a4711}

/* ---- Spec list (setbacks / requirements) ---- */
.spec-block{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;margin:18px 0;box-shadow:var(--shadow-sm);
}
.spec-block h3{margin:0 0 4px;font-size:19px;color:var(--ink)}
.spec-block .sub{font-size:14px;color:var(--ink-faint);margin-bottom:16px}
.spec{display:flex;gap:14px;align-items:baseline;padding:12px 0;border-bottom:1px dashed var(--line)}
.spec:last-child{border-bottom:0;padding-bottom:0}
.spec .num{
  flex:none;min-width:74px;font-weight:700;color:var(--green);font-size:17px;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;
}
.spec .lab{color:var(--ink-soft);font-size:15.5px}

/* ---- Pricing ---- */
.price-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:8px 0 6px}
.price-card{
  background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.price-card .ph{
  padding:18px 24px;background:var(--green);color:#fff;display:flex;align-items:center;gap:10px;
}
.price-card.alt .ph{background:#0a5d18}
.price-card .ph b{font-size:17px;font-weight:600}
.price-card .ph .pill{
  margin-left:auto;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  background:rgba(255,255,255,.18);padding:4px 10px;border-radius:999px;
}
.price-row{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:14px 24px;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:0}
.price-row .it{color:var(--ink-soft);font-size:15.5px}
.price-row .it small{display:block;color:var(--ink-faint);font-size:13px}
.price-row .pr{font-weight:700;color:var(--ink);font-size:17px;flex:none;font-variant-numeric:tabular-nums}
.price-note{font-size:14.5px;color:var(--ink-faint);margin-top:14px;display:flex;flex-direction:column;gap:6px}
.price-note span{display:flex;gap:8px;align-items:baseline}
.price-note b{color:var(--ink);font-weight:600}

/* ---- Aside / sidebar ---- */
.page-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:120px}
.aside-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 24px;box-shadow:var(--shadow-sm);
}
.aside-card.dark{background:var(--green);color:#fff;border-color:transparent}
.aside-card h4{
  font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;
  color:var(--ink-faint);margin:0 0 16px;
}
.aside-card.dark h4{color:#a7d9ab}
.fact{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line);font-size:15px}
.aside-card.dark .fact{border-color:rgba(255,255,255,.14)}
.fact:last-child{border-bottom:0}
.fact:first-of-type{padding-top:0}
.fact svg{width:18px;height:18px;flex:none;margin-top:2px;color:var(--green);stroke-width:1.8;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.aside-card.dark .fact svg{color:#a7d9ab}
.fact .k{display:block;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:600;margin-bottom:1px}
.aside-card.dark .fact .k{color:#9cc79f}
.fact .v{color:var(--ink-soft)}
.fact .v a{color:var(--blue);font-weight:500}
.aside-card.dark .fact .v{color:#eaf3e8}
.aside-card.dark .fact .v a{color:#fff;text-decoration:underline}
.aside-links{display:flex;flex-direction:column;gap:2px}
.aside-links a{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 12px;border-radius:8px;color:var(--ink);font-weight:500;font-size:15.5px;
  transition:background .15s var(--ease);
}
.aside-links a:hover{background:#eef3e9;color:var(--green);text-decoration:none}
.aside-links a .arr{color:var(--ink-faint);font-size:14px}
.aside-card .btn{width:100%;justify-content:center;margin-top:4px}

/* ---- Gallery / figure ---- */
.figrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:24px 0}
.figure{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
.figure .ph{aspect-ratio:4/3;background:linear-gradient(135deg,#dfe6d6,#c7d4ba);display:grid;place-items:center;color:#6c7a5d;position:relative;overflow:hidden}
.figure .ph > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.figure .ph svg{width:40px;height:40px;opacity:.5;stroke-width:1.4;fill:none;stroke:currentColor}
.figure .cap{padding:14px 16px}
.figure .cap b{display:block;color:var(--ink);font-size:15.5px;margin-bottom:3px;font-weight:600}
.figure .cap span{font-size:13.5px;color:var(--ink-faint);line-height:1.45}

/* ---- Definition / quiet list ---- */
.deflist{display:flex;flex-direction:column;gap:0;margin:18px 0}
.deflist .row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:16px 0;border-bottom:1px solid var(--line)}
.deflist .row:last-child{border-bottom:0}
.deflist dt{font-weight:600;color:var(--ink)}
.deflist dd{margin:0;color:var(--ink-soft);font-size:15.5px}

/* ---- Section intro reused ---- */
.page-main > .prose + .prose{margin-top:8px}

/* ---- Contact page (full width, no aside) ---- */
.contact-wrap{max-width:var(--maxw)}
.contact-wrap .eyebrow{margin-bottom:22px;font-size:15px}
.info-2col{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-bottom:8px}
.info-2col .prose h2{margin-top:0}
.office-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:6px 22px;margin:6px 0 12px}
.office-box .line{display:flex;gap:18px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--line);font-size:16px;color:var(--ink-soft);line-height:1.45}
.office-box .line:last-child{border-bottom:0}
.office-box .line .lbl{flex:none;min-width:104px;font-weight:600;color:var(--ink);font-size:12px;text-transform:uppercase;letter-spacing:.07em}
.office-box .line a{color:var(--blue);font-weight:500}
.contact-note{font-size:14.5px;color:var(--ink-faint);margin:0}
.dept-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:32px 0 4px}
.dept-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;text-align:center}
.dept-card .hd{background:var(--green);color:#fff;padding:18px 12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:15px;line-height:1.25}
.dept-card .bd{padding:22px 16px;display:flex;flex-direction:column;gap:13px;align-items:center}
.dept-card .num{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:18px;color:var(--ink);text-decoration:none}
.dept-card .num svg{width:18px;height:18px;color:var(--green);stroke-width:1.8;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.dept-card .num:hover{color:var(--green);text-decoration:none}
.dept-card .em{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;color:var(--blue);word-break:break-word;text-decoration:none}
.dept-card .em svg{width:16px;height:16px;flex:none;color:var(--ink-faint);stroke-width:1.8;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.dept-card .em:hover{text-decoration:underline}
@media (max-width:820px){.info-2col{grid-template-columns:1fr;gap:28px}.dept-cards{grid-template-columns:1fr;max-width:420px}}

/* ---- Minutes / document download list ---- */
.doc-year{
  display:flex;align-items:center;gap:14px;margin:26px 0 16px;
  font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--ink-faint);
}
.doc-year:first-child{margin-top:8px}
.doc-year::after{content:"";flex:1;height:1px;background:var(--line)}
.doc-year .count{
  flex:none;background:#eef3e9;color:var(--green);border-radius:999px;
  padding:2px 10px;font-size:11px;letter-spacing:.06em;
}
.doclist{display:flex;flex-direction:column;gap:10px;margin:0 0 22px;max-width:none}
.doclist.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:680px){.doclist.grid{grid-template-columns:1fr}}
.docitem{
  display:flex;align-items:center;gap:16px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:13px 18px;box-shadow:var(--shadow-sm);color:var(--ink);
  transition:border-color .15s var(--ease),box-shadow .2s var(--ease),transform .15s var(--ease);
}
.docitem:hover{
  border-color:var(--green-600);text-decoration:none;transform:translateY(-1px);
  box-shadow:0 8px 22px -12px rgba(10,40,8,.45);
}
.docicon{flex:none;width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:#eef3e9;color:var(--green)}
.docicon svg{width:21px;height:21px;stroke-width:1.7;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.docmeta{display:flex;flex-direction:column;min-width:0;flex:1}
.docmeta b{color:var(--ink);font-size:16.5px;font-weight:600;letter-spacing:-.01em;line-height:1.25}
.docmeta small{color:var(--ink-faint);font-size:13.5px;margin-top:2px}
.doctag{
  flex:none;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--red);
  border:1px solid #e6c7ca;background:#fbf0f1;border-radius:6px;padding:3px 8px;
}
.docarr{flex:none;color:var(--ink-faint);display:grid;place-items:center;transition:color .15s var(--ease),transform .15s var(--ease)}
.docarr svg{width:20px;height:20px;stroke-width:1.8;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.docitem:hover .docarr{color:var(--green-600);transform:translateY(2px)}
@media (max-width:560px){
  .doctag{display:none}
  .docitem{gap:13px;padding:12px 14px}
}

/* ---- Park blocks ---- */
.parkblock{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:start;margin:14px 0 34px}
.parkblock .figure{margin:0}
.parkblock .figure .ph{aspect-ratio:4/3}
.parkblock h3{margin:0 0 10px}
.parkblock p{margin:0 0 .9em}
@media (max-width:680px){.parkblock{grid-template-columns:1fr;gap:16px}}

/* ---- Historical / general figure with graceful image fallback ---- */
.histfig{margin:26px 0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card);box-shadow:var(--shadow-sm)}
.histfig .imgwrap{display:block}
.histfig img{display:block;width:100%;height:auto}
.histfig figcaption{padding:13px 18px;font-size:13.5px;color:var(--ink-faint);line-height:1.5;border-top:1px solid var(--line)}
.histfig figcaption b{color:var(--ink-soft);font-weight:600}
.histfig.noimg .imgwrap{aspect-ratio:16/10;background:linear-gradient(135deg,#e7e2d2,#d2cab1);display:grid;place-items:center;color:#8a7f63;position:relative}
.histfig.noimg .imgwrap::after{content:attr(data-ph);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.histfig.right{max-width:340px;float:right;margin:6px 0 18px 28px}
@media (max-width:680px){.histfig.right{float:none;max-width:none;margin:26px 0}}

/* ---- Responsive ---- */
@media (max-width:960px){
  .page-layout{grid-template-columns:1fr;gap:36px}
  .page-aside{position:static;flex-direction:row;flex-wrap:wrap}
  .page-aside > *{flex:1 1 260px}
  .price-cols{grid-template-columns:1fr}
}
@media (max-width:760px){
  .page{padding:40px 0 56px}
  .page-head{gap:14px}
  .page-head .hicon{width:50px;height:50px}
  .deflist .row{grid-template-columns:1fr;gap:4px}
  .page-aside{flex-direction:column}
}
