/* ============================================================
   Bloom Township — refreshed civic style
   Brand: deep forest green #004300 + warm paper + Ohio-flag red
   Type: Poppins (kept from current site)
   ============================================================ */

:root{
  --green:#004300;
  --green-700:#0a5d18;
  --green-600:#147a26;
  --green-900:#012c00;
  --green-band:#003a00;

  --paper:#ffffff;        /* page background */
  --card:#ffffff;
  --ink:#1d2618;
  --ink-soft:#525a48;
  --ink-faint:#646b58;
  --line:#e4e1d2;
  --line-strong:#d2cdb8;

  --red:#bd1f2d;          /* Ohio-flag red — accent, used sparingly */
  --blue:#1f3a6d;         /* navy — links / Ohio-flag blue family */
  --gold:#b9892f;

  --radius:10px;
  --radius-sm:7px;
  --shadow-sm:0 1px 2px rgba(18,32,12,.06), 0 1px 1px rgba(18,32,12,.04);
  --shadow:0 6px 24px -10px rgba(10,40,8,.28);
  --shadow-lg:0 24px 60px -24px rgba(10,40,8,.45);
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{margin:0;line-height:1.12;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* skip link */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-main{position:absolute;left:-999px;top:0;background:var(--green);color:#fff;padding:12px 18px;z-index:200;border-radius:0 0 8px 0}
.skip-main:focus{left:0}

.eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--green-600);margin:0 0 14px;
}
.eyebrow.on-dark{color:#a7d9ab}

/* ============================================================
   Utility bar
   ============================================================ */
.util{
  background:var(--green-900);color:#dfeadb;font-size:14px;
}
.util .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;min-height:42px;flex-wrap:wrap}
.util a{color:#fff}
.util-left{display:flex;align-items:center;gap:8px;letter-spacing:.04em}
.util-right{display:flex;align-items:center;gap:22px}
.util-item{display:flex;align-items:center;gap:8px;color:#dfeadb}
.util-item svg{width:15px;height:15px;flex:none;opacity:.8}
.util .ohio{display:inline-flex;width:18px;height:12px;border-radius:2px;overflow:hidden;flex:none}

/* ============================================================
   Header / nav
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:120;
  background:var(--green);
  box-shadow:0 1px 0 rgba(255,255,255,.06), 0 6px 20px -14px rgba(0,0,0,.6);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:96px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:60px;width:auto}
.nav{display:flex;align-items:center;gap:4px}
.nav > li{list-style:none;position:relative}
.nav a, .nav .navlink{
  display:inline-flex;align-items:center;gap:7px;
  color:#fff;font-weight:500;font-size:16.5px;
  padding:12px 16px;border-radius:8px;cursor:pointer;
  transition:background .15s var(--ease);text-decoration:none;
}
.nav a:hover,.nav .navlink:hover,.nav .has-drop:hover .navlink{background:rgba(255,255,255,.12);text-decoration:none}
.nav .caret{width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s var(--ease);opacity:.85}
.nav .has-drop.open .caret,.nav .has-drop:hover .caret{transform:rotate(225deg) translateY(2px)}
.nav ul{list-style:none;margin:0;padding:0}

.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:264px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow-lg);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility .18s;
}
.has-drop:hover .dropdown,.has-drop.open .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{
  position:relative;display:flex;flex-direction:column;gap:2px;color:var(--ink);font-weight:500;font-size:16px;
  padding:11px 14px;border-radius:8px;
}
.dropdown a:hover{background:#eef3e9;color:var(--green);text-decoration:none}
.dropdown a small{color:var(--ink-faint);font-weight:400;font-size:13px;letter-spacing:0}
.dropdown a.ext{padding-right:30px}
.dropdown a.ext::after{content:"↗";position:absolute;top:11px;right:14px;color:var(--ink-faint);font-size:13px}

.nav-cta{
  background:#fff;color:var(--green)!important;font-weight:600!important;
  padding:11px 18px!important;border-radius:8px;
}
.nav-cta:hover{background:#eef4ec!important}

.hamburger{display:none;background:transparent;border:0;cursor:pointer;padding:10px;border-radius:8px}
.hamburger:hover{background:rgba(255,255,255,.12)}
.hamburger span{display:block;width:26px;height:2.5px;background:#fff;border-radius:2px;margin:5px 0;transition:.25s var(--ease)}
.menu-open .hamburger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.menu-open .hamburger span:nth-child(2){opacity:0}
.menu-open .hamburger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   Notice strip
   ============================================================ */
.notice{
  background:#fbf3df;border-bottom:1px solid #ecdcb0;color:#5a4711;
}
.notice .wrap{display:flex;align-items:center;gap:16px;padding-top:12px;padding-bottom:12px}
.notice .tag{
  flex:none;display:inline-flex;align-items:center;gap:7px;
  background:var(--red);color:#fff;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;
}
.notice .tag svg{width:13px;height:13px}
.notice p{font-size:15.5px;margin:0;line-height:1.4}
.notice strong{color:#3f3209}
.notice .dismiss{margin-left:auto;flex:none;background:transparent;border:0;cursor:pointer;color:#977a2b;padding:6px;border-radius:6px;line-height:0}
.notice .dismiss:hover{background:#f2e6c4}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--green)}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 60%;}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(98deg,rgba(1,34,2,.86) 0%,rgba(1,40,2,.6) 42%,rgba(1,42,2,.34) 75%,rgba(1,42,2,.22) 100%),
    linear-gradient(180deg,rgba(0,30,0,.10) 0%,rgba(1,40,0,.34) 60%,rgba(1,42,0,.6) 100%);
}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:#001500;opacity:var(--hero-dim,0);pointer-events:none}
.hero .wrap{position:relative;z-index:2;padding:74px 28px 66px;max-width:980px}
body.hide-notice .notice{display:none}
body.hide-quick .quick{display:none}
.hero h1{font-size:clamp(40px,6vw,68px);line-height:1.03;letter-spacing:-.02em}
.hero .lede{font-size:clamp(18px,2.2vw,22px);color:#e3efe1;max-width:640px;margin:20px 0 34px;font-weight:300}
.hero .lede strong{font-weight:600;color:#fff}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

.btn{
  display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:16.5px;
  padding:14px 24px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .12s var(--ease),background .15s,box-shadow .15s;text-decoration:none;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn svg{width:18px;height:18px}
.btn-primary{background:#fff;color:var(--green);box-shadow:var(--shadow)}
.btn-primary:hover{background:#eef4ec}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-green{background:var(--green);color:#fff;box-shadow:var(--shadow)}
.btn-green:hover{background:var(--green-700)}
.btn-outline{background:transparent;color:var(--green);border-color:var(--line-strong)}
.btn-outline:hover{background:#fff;border-color:var(--green)}

/* ============================================================
   Quick actions
   ============================================================ */
.quick{position:relative;margin-top:-46px;z-index:5}
.quick-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
.qcard{
  display:flex;flex-direction:column;gap:12px;align-items:flex-start;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 18px;box-shadow:var(--shadow-sm);color:var(--ink);
  transition:transform .15s var(--ease),box-shadow .2s,border-color .2s;
  position:relative;overflow:hidden;
}
.qcard::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.qcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong);text-decoration:none}
.qcard:hover::before{transform:scaleX(1)}
.qicon{
  width:44px;height:44px;border-radius:10px;flex:none;
  display:grid;place-items:center;background:#eef3e9;color:var(--green);
}
.qicon svg{width:23px;height:23px;stroke-width:1.7}
.qcard h3{font-size:16px;font-weight:600;letter-spacing:-.01em}
.qcard span{font-size:13px;color:var(--ink-faint);line-height:1.35}

/* ============================================================
   Sections
   ============================================================ */
section{scroll-margin-top:140px}
.band{padding:72px 0}
.band-tight{padding:54px 0}
.section-head{margin-bottom:36px;max-width:760px}
.section-head h2{font-size:clamp(28px,3.4vw,40px);color:var(--ink)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head p{color:var(--ink-soft);font-size:18px;margin-top:14px}

/* News */
.news-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:40px;align-items:start}
.news-feature{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.news-feature .ph{width:100%;aspect-ratio:1704/404;object-fit:cover;background:#dfe3d6}
.news-feature .body{padding:24px 26px 28px}
.news-feature .kicker{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.news-feature h3{font-size:24px;margin-bottom:8px}
.news-feature .cap{color:var(--ink-soft);font-size:16px}

.updates{display:flex;flex-direction:column;gap:0}
.updates h3{font-size:15px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);font-weight:600;margin-bottom:6px}
.update{
  display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);
}
.update:last-of-type{border-bottom:0}
.update .date{
  flex:none;width:58px;text-align:center;border-radius:8px;border:1px solid var(--line);
  padding:8px 4px;background:#fff;line-height:1.05;
}
.update .date .m{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--red);font-weight:600}
.update .date .d{font-size:22px;font-weight:700;color:var(--ink)}
.update .txt{font-size:15.5px;color:var(--ink-soft)}
.update .txt b{color:var(--ink);font-weight:600;display:block;margin-bottom:2px}

/* Meetings */
.meet-wrap{background:var(--green);color:#fff;border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1fr 1.25fr}
.meet-next{padding:44px 44px;background:linear-gradient(160deg,#0a5d18,#004300);position:relative}
.meet-next .eyebrow{color:#a7d9ab}
.meet-next .big-date{font-size:54px;font-weight:700;line-height:1;letter-spacing:-.02em;margin:6px 0 4px}
.meet-next .when{font-size:20px;color:#d9ead6}
.meet-next .where{margin-top:18px;display:flex;gap:10px;align-items:flex-start;color:#e7f1e5;font-size:16px}
.meet-next .where svg{width:19px;height:19px;flex:none;margin-top:2px;opacity:.85}
.meet-next .exec{margin-top:18px;font-size:14.5px;background:rgba(255,255,255,.12);padding:10px 14px;border-radius:8px;color:#eaf3e8}
.meet-info{padding:44px;background:#fff;color:var(--ink)}
.meet-info h3{font-size:22px;margin-bottom:14px}
.meet-info .sched-line{display:flex;gap:12px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line);font-size:16px}
.meet-info .sched-line:last-of-type{border-bottom:0}
.meet-info .sched-line svg{width:20px;height:20px;color:var(--green);flex:none;margin-top:2px;stroke-width:1.8}
.meet-info .sched-line b{color:var(--ink)}
.meet-info .sched-line span{color:var(--ink-soft)}
.meet-info .actions{margin-top:22px;display:flex;gap:10px;flex-wrap:wrap}
.meet-info .actions .btn{padding:12px 15px;font-size:15px;white-space:nowrap}
.meet-info .actions .btn svg{width:17px;height:17px}

/* FAQ */
.faq{max-width:880px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:var(--radius);background:var(--card);margin-bottom:12px;overflow:hidden;transition:box-shadow .2s,border-color .2s}
.faq-item.open{box-shadow:var(--shadow-sm);border-color:var(--line-strong)}
.faq-q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  display:flex;align-items:center;gap:18px;padding:22px 24px;font-family:inherit;
  font-size:18.5px;font-weight:600;color:var(--ink);
}
.faq-q .ic{flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--green);color:var(--green);display:grid;place-items:center;position:relative;transition:background .2s,color .2s}
.faq-item.open .faq-q .ic{background:var(--green);color:#fff}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;background:currentColor;border-radius:2px}
.faq-q .ic::before{width:12px;height:2px}
.faq-q .ic::after{width:2px;height:12px;transition:transform .25s var(--ease)}
.faq-item.open .faq-q .ic::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a .inner{padding:0 24px 24px 68px;color:var(--ink-soft);font-size:16.5px}
.faq-a .inner a{font-weight:600}

/* Savvy citizen */
.savvy{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1fr 1.1fr;box-shadow:var(--shadow-sm)}
.savvy .pic{background:#fff;display:grid;place-items:center;padding:24px}
.savvy .pic img{border-radius:10px;box-shadow:var(--shadow-sm);max-width:420px}
.savvy .body{padding:48px 48px}
.savvy .body h2{font-size:30px;margin-bottom:12px}
.savvy .body p{color:var(--ink-soft);font-size:17px}
.savvy .stores{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:11px 18px;border-radius:9px;font-size:14px}
.store:hover{text-decoration:none;background:#000;color:#fff}
.store svg{width:22px;height:22px}
.store .s{display:flex;flex-direction:column;line-height:1.1}
.store .s small{font-size:10px;opacity:.8;letter-spacing:.04em}
.store .s b{font-size:15px;font-weight:600}

/* Trustees */
.trustees{background:var(--green);color:#fff;position:relative;overflow:hidden}
.trustees::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 380px at 50% -10%,rgba(255,255,255,.08),transparent)}
.trustees .wrap{position:relative}
.trustee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:720px;margin:0 auto}
.trustee{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:14px;overflow:hidden;text-align:center;transition:transform .15s var(--ease),background .2s}
.trustee:hover{transform:translateY(-3px);background:rgba(255,255,255,.09)}
.trustee .pic{aspect-ratio:1/1;overflow:hidden;background:#0b3b0b}
.trustee .pic img{width:100%;height:100%;object-fit:cover;object-position:center top}
.trustee .meta{padding:18px 12px 22px}
.trustee .meta b{display:block;font-size:19px;font-weight:600}
.trustee .meta span{font-size:14px;color:#a7d9ab;letter-spacing:.04em;text-transform:uppercase;font-weight:500}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--green-900);color:#d7e4d3}
.foot-top{padding:60px 0 48px;display:grid;grid-template-columns:1.1fr 1.2fr 1fr;gap:48px}
.foot-col h3{font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:#fff;margin-bottom:18px;font-weight:600}
.foot-col p{font-size:15.5px;line-height:1.7;color:#cfe0cb}
.foot-col a{color:#fff}
/* Links sitting inline within paragraph text must not rely on color alone (WCAG 1.4.1) */
.foot-col p a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.foot-contact b{color:#fff}
.foot-links{display:flex;flex-direction:column;gap:9px}
.foot-links a{color:#d7e4d3;font-size:15.5px;width:fit-content}
.foot-links a:hover{color:#fff}
.foot-sub{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:#8fb38b;font-weight:600;margin:22px 0 10px}
.foot-links.row{flex-direction:row;flex-wrap:wrap;gap:6px 4px}
.foot-links.row a{position:relative;padding-right:14px}
.foot-links.row a:not(:last-child)::after{content:"·";position:absolute;right:3px;color:#5d7d5a}

/* In memory */
.memory{background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}
.memory{max-width:360px}
.memory img{width:100%;height:auto;display:block}
.memory .cap{padding:16px 18px;font-size:14px;line-height:1.55;color:#cfe0cb;text-align:center}
.memory .cap b{display:block;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}

.foot-bottom{border-top:1px solid rgba(255,255,255,.1)}
.foot-bottom .wrap{padding:24px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-size:14px;color:#bcd0b8}
.foot-bottom em{color:#e9f2e6;font-style:italic;font-weight:500}
.foot-bottom a{color:#d7e4d3}
/* Inline-in-text credit link ("Website by Web Chick") must not rely on color alone */
.foot-bottom .legal span a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.foot-bottom .legal{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.foot-bottom .legal a{position:relative;padding-right:14px}
.foot-bottom .legal a:not(:last-child)::after{content:"·";position:absolute;right:4px;color:#5d7d5a}

/* mobile nav panel base (hidden desktop) */
.mobile-only{display:none}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1080px){
  .quick-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:980px){
  .news-grid{grid-template-columns:1fr;gap:28px}
  .meet-wrap{grid-template-columns:1fr}
  .savvy{grid-template-columns:1fr}
  .savvy .pic{padding:28px 28px 0}
  .savvy .pic img{max-width:300px}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .foot-col.mem-col{grid-column:1/-1}
  .foot-col.mem-col .memory{margin-left:auto}
}
@media (max-width:820px){
  body{font-size:17px}
  .util-right{display:none}
  .hamburger{display:block}
  .nav{
    position:absolute;top:100%;left:0;right:0;background:var(--green);
    flex-direction:column;align-items:stretch;gap:2px;padding:14px 18px 24px;
    border-top:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-lg);
    transform:translateY(-12px);opacity:0;visibility:hidden;
    transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;
    max-height:80vh;overflow:auto;
  }
  .menu-open .nav{transform:translateY(0);opacity:1;visibility:visible}
  .nav a,.nav .navlink{padding:14px 14px;font-size:18px;border-radius:8px;justify-content:space-between}
  .nav .has-drop .navlink{width:100%}
  .dropdown{
    position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    background:rgba(0,0,0,.18);border:0;border-radius:8px;margin:2px 0 6px;
    max-height:0;overflow:hidden;padding:0 8px;transition:max-height .25s var(--ease),padding .2s;
  }
  .has-drop.open .dropdown{max-height:520px;padding:6px 8px}
  .has-drop:hover .dropdown{max-height:0}
  .has-drop.open .dropdown{max-height:520px}
  .dropdown a{color:#eaf3e8}
  .dropdown a:hover{background:rgba(255,255,255,.1);color:#fff}
  .dropdown a small{color:#a7d9ab}
  .nav-cta{background:#fff;color:var(--green)!important;text-align:center;justify-content:center!important}
}
@media (max-width:760px){
  .quick{margin-top:28px}
  .foot-col.mem-col .memory{margin:0 auto;max-width:300px}
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .hero .wrap{padding:54px 28px 60px}
  .band{padding:52px 0}
  .trustee-grid{grid-template-columns:1fr;max-width:360px}
  .foot-top{grid-template-columns:1fr}
  .meet-next,.meet-info,.savvy .body{padding:32px 26px}
  .faq-a .inner{padding-left:24px}
  .notice .wrap{flex-wrap:wrap}
  .notice .dismiss{order:2}
}
@media (max-width:420px){
  .quick-grid{grid-template-columns:1fr 1fr;gap:10px}
  .wrap{padding:0 18px}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;animation:none!important}
}
