/* ============================================================
   Village of Pleasantville — shared stylesheet
   Hand-written, framework-free. Replaces per-page generated CSS.
   ============================================================ */

:root{
  --blue:#265a88;          /* primary brand blue */
  --blue-dark:#1b486d;
  --navy:#1d3f5e;          /* deep header / footer */
  --navy-2:#173249;        /* footer base */
  --blue-600:#21527c;
  --blue-700:#1b486d;
  --ink:#243140;           /* body text on light */
  --muted:#5b6b7a;
  --line:#e2e8f0;
  --bg:#ffffff;
  --bg-alt:#f4f7fb;
  --gold:#e8b84b;
  --white:#ffffff;
  --radius:10px;
  --radius-sm:6px;
  --shadow-sm:0 1px 2px rgba(16,42,67,.08), 0 2px 6px rgba(16,42,67,.06);
  --shadow-md:0 6px 20px rgba(16,42,67,.12);
  --maxw:1200px;
  --pad:clamp(16px,4vw,40px);
  --font:"Open Sans",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --script:"Dancing Script","Open Sans",cursive;
  --display:"Montserrat","Open Sans",system-ui,sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--blue); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3,h4{ font-family:var(--display); color:var(--navy); line-height:1.15; margin:0 0 .5em; font-weight:700; }
p{ margin:0 0 1rem; text-wrap:pretty; }
ul{ margin:0 0 1rem; }

.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.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 link ---- */
.skip-main{
  position:absolute; left:-999px; top:0; z-index:1000;
  background:var(--navy); color:#fff; padding:12px 18px; border-radius:0 0 8px 0;
  font-weight:600;
}
.skip-main:focus{ left:0; text-decoration:none; outline:3px solid var(--gold); }

:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; border-radius:3px; }

/* ============================================================
   NAVBAR
   ============================================================ */
.site-nav{
  position:sticky; top:0; z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.site-nav .wrap{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  min-height:96px;
}
.brand{ display:inline-flex; align-items:center; }
.brand img{ width:auto; height:68px; }

.nav-toggle{
  display:none;
  align-items:center; gap:10px;
  background:var(--blue); color:#fff; border:0;
  font:inherit; font-weight:700; letter-spacing:.04em;
  padding:11px 16px; border-radius:var(--radius-sm); cursor:pointer;
}
.nav-toggle .bars{ display:inline-grid; gap:4px; }
.nav-toggle .bars span{ width:22px; height:2px; background:#fff; border-radius:2px; }

.menu{ list-style:none; display:flex; align-items:center; gap:6px; margin:0; padding:0; }
.menu > li{ position:relative; }
.menu > li > a,
.menu > li > button{
  display:inline-flex; align-items:center; gap:6px;
  font:inherit; font-weight:700; letter-spacing:.03em; font-size:15px;
  color:var(--navy); background:none; border:0; cursor:pointer;
  padding:12px 14px; border-radius:var(--radius-sm); text-transform:uppercase;
}
.menu > li > a:hover,
.menu > li > button:hover,
.menu > li.is-open > button{ background:var(--bg-alt); color:var(--blue); text-decoration:none; }
.menu .caret{ width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor; transition:transform .2s; }
.menu > li.is-open .caret{ transform:rotate(180deg); }

.submenu{
  list-style:none; margin:0; padding:8px; min-width:248px;
  position:absolute; top:calc(100% + 6px); left:0; z-index:60;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  opacity:0; visibility:hidden; transform:translateY(6px);
  transition:opacity .16s ease, transform .16s ease, visibility .16s;
}
.menu > li.is-open .submenu{ opacity:1; visibility:visible; transform:translateY(0); }
/* keep the trailing dropdown from overflowing the right edge */
.menu > li:last-child .submenu{ left:auto; right:0; }
.submenu a{
  display:block; padding:10px 12px; border-radius:var(--radius-sm);
  color:var(--ink); font-weight:600; font-size:15px;
}
.submenu a:hover{ background:var(--bg-alt); color:var(--blue); text-decoration:none; }

/* ============================================================
   HOME HERO
   ============================================================ */
.hero{
  position:relative; isolation:isolate;
  display:grid; place-items:end center;
  min-height:clamp(280px,42vw,560px);
  background:#1d3f5e center/cover no-repeat;
  text-align:center; padding:48px 24px clamp(40px,9vh,90px);
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(to top, rgba(0,0,0,.51) 0%, rgba(0,0,0,0) 60%);
}
.hero img{ width:min(400px,80%); height:auto; opacity:.9; filter:drop-shadow(0 4px 18px rgba(0,0,0,.35)); }

/* Interior page banner */
.page-banner{
  background:linear-gradient(120deg,var(--navy),var(--blue));
  color:#fff; padding:clamp(28px,5vw,60px) 0;
}
.page-banner .wrap{ display:flex; flex-wrap:wrap; align-items:flex-end; gap:6px 18px; }
.page-banner h1{ color:#fff; margin:0; font-size:clamp(28px,4.4vw,46px); }
.page-banner .eyebrow{ color:#dbe7f3; font-style:italic; font-size:clamp(16px,2vw,22px); }

/* Title-only band (home) */
.title-band{ background:var(--bg-alt); border-bottom:1px solid var(--line); }
.title-band h1{ margin:0; padding:22px 0; font-size:clamp(26px,3.6vw,40px); color:var(--navy); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:var(--blue); color:#fff; font-weight:700; letter-spacing:.03em;
  padding:14px 20px; border-radius:var(--radius-sm); border:1px solid var(--blue-700);
  text-align:center; cursor:pointer; transition:background .15s, transform .15s, box-shadow .15s;
  box-shadow:var(--shadow-sm); line-height:1.2;
}
.btn:hover{ background:var(--blue-700); color:#fff; text-decoration:none; transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn:active{ transform:translateY(0); }
.btn-block{ width:100%; }
.btn-outline{
  background:#fff; color:var(--blue); border:2px solid var(--blue);
  box-shadow:none;
}
.btn-outline:hover{ background:var(--blue); color:#fff; }

/* Latest-news callout (News / Notices page) */
.latest-callout{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:18px 28px; margin:0 0 30px;
  background:var(--bg-alt); border:1px solid var(--line);
  border-left:4px solid var(--gold); border-radius:var(--radius);
  padding:20px 24px;
}
.latest-callout-title{
  font-family:var(--display); font-weight:700; color:var(--navy);
  font-size:clamp(17px,2vw,20px); margin:0 0 2px;
}
.latest-callout-sub{ margin:0; color:var(--muted); font-size:15px; }
.latest-callout-actions{ display:flex; flex-wrap:wrap; gap:12px; }
@media (max-width:600px){
  .latest-callout-actions{ width:100%; }
  .latest-callout-actions .btn{ flex:1 1 auto; }
}

/* ============================================================
   HOME CONTENT
   ============================================================ */
.section{ padding:clamp(36px,6vw,68px) 0; }

.info-cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,3vw,30px);
}
.info-card{
  display:block; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); border:1px solid var(--line); background:#fff;
  transition:transform .18s, box-shadow .18s;
}
.info-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); text-decoration:none; }
.info-card img{ width:100%; aspect-ratio:1/1; object-fit:cover; }

.home-split{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:clamp(24px,4vw,48px);
  align-items:center; margin-top:clamp(36px,6vw,60px);
}
.home-split .photo img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow-md); }
.quicklinks{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.quicklinks .span-2{ grid-column:1 / -1; }

/* Village news & events rows */
.events{ margin-bottom:clamp(40px,6vw,64px); }
.events-head{
  text-align:center; color:var(--navy); margin:0 0 clamp(24px,3.5vw,40px);
  font-size:clamp(24px,3.2vw,34px);
}
.events-head::after{
  content:""; display:block; width:64px; height:4px; margin:14px auto 0;
  background:var(--gold); border-radius:2px;
}
.event-row{
  display:grid; grid-template-columns:minmax(0,340px) minmax(0,1fr);
  gap:clamp(20px,4vw,44px); align-items:center;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-sm); padding:clamp(16px,2.6vw,26px);
  margin-bottom:clamp(20px,3vw,28px);
}
.event-row .event-photo{
  display:block; border-radius:var(--radius-sm); overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .18s, box-shadow .18s;
}
.event-row .event-photo:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.event-row .event-photo img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.event-row.reverse{ grid-template-columns:minmax(0,1fr) minmax(0,340px); }
.event-row.reverse .event-photo{ grid-column:2; }
.event-row.reverse .event-body{ grid-column:1; grid-row:1; }
.event-eyebrow{
  font-family:var(--display); font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  font-size:13px; color:var(--blue); margin:0 0 8px;
}
.event-title{ font-size:clamp(22px,2.8vw,30px); margin:0 0 8px; color:var(--navy); }
.event-date{ font-weight:700; color:var(--gold); filter:saturate(.9) brightness(.82); margin:0 0 12px; letter-spacing:.01em; }
.event-summary{ font-size:17px; color:var(--ink); margin:0 0 20px; max-width:56ch; }
.event-body .btn{ align-self:flex-start; }
@media (max-width:760px){
  .event-row, .event-row.reverse{ grid-template-columns:1fr; }
  .event-row .event-photo img{ aspect-ratio:16/10; }
  .event-row.reverse .event-photo{ grid-column:1; grid-row:1; }
  .event-row.reverse .event-body{ grid-column:1; grid-row:2; }
}

/* Open-seat notices */
.notices{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,28px);
  margin-top:clamp(20px,3vw,28px);
}
.notice{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-sm); padding:clamp(22px,3vw,34px);
  border-top:4px solid var(--gold);
}
.notice-logo{ margin:0 auto 16px; height:64px; width:auto; }
.notice-title{ text-align:center; font-size:clamp(20px,2.2vw,25px); margin:0 0 4px; }
.notice-seat{
  text-align:center; font-family:var(--display); font-weight:700;
  text-transform:uppercase; letter-spacing:.14em; font-size:14px;
  color:var(--blue); margin:0 0 18px;
}
.notice-sub{
  font-family:var(--display); font-weight:700; color:var(--navy);
  margin:18px 0 8px; font-size:16px;
}
.notice-contact{ font-weight:600; color:var(--navy); }
.notice p{ font-size:16px; }
.notice p:last-child{ margin-bottom:0; }

/* Read-more accordion */
.notice-text{
  position:relative; overflow:hidden;
  max-height:8.5em; transition:max-height .45s ease;
}
.notice.open .notice-text{ max-height:200em; }
.notice-text::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:5em;
  background:linear-gradient(to bottom, rgba(255,255,255,0), #fff);
  pointer-events:none; transition:opacity .3s;
}
.notice.open .notice-text::after{ opacity:0; }
.notice-toggle{
  display:inline-flex; align-items:center; gap:8px; margin-top:14px;
  background:none; border:0; cursor:pointer; padding:6px 0;
  font-family:var(--display); font-weight:700; font-size:15px; color:var(--blue);
}
.notice-toggle:hover{ color:var(--blue-dark); text-decoration:underline; }
.notice-toggle .chev{
  width:10px; height:10px; border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  transform:rotate(45deg); transition:transform .3s; margin-bottom:3px;
}
.notice.open .notice-toggle .chev{ transform:rotate(-135deg); margin-bottom:-3px; }
@media (max-width:760px){
  .notices{ grid-template-columns:1fr; }
}

/* ============================================================
   INTERIOR CONTENT LAYOUT
   ============================================================ */
.content{ padding:clamp(32px,5vw,60px) 0; }
.content-split{
  display:grid; grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);
  gap:clamp(24px,4vw,44px); align-items:start;
}
.prose{ font-size:18px; color:var(--ink); }
.prose h2{ font-size:clamp(20px,2.4vw,26px); margin-top:1.5em; color:var(--blue); }
.prose a{ color:var(--blue); font-weight:600; text-decoration:underline; text-underline-offset:2px; }
.prose a.btn{ color:#fff; text-decoration:none; font-weight:700; }
.prose a.btn:hover{ color:#fff; text-decoration:none; }
.prose ul{ padding-left:1.25em; }
.prose li{ margin:.3em 0; }

.aside-card{
  background:linear-gradient(160deg,var(--navy),var(--blue));
  color:#fff; border-radius:var(--radius); padding:clamp(20px,3vw,28px);
  box-shadow:var(--shadow-md);
}
.aside-card :is(h2,h3,strong){ color:#fff; }
.aside-card h2{ font-size:20px; margin:0 0 .4em; }
.aside-card a{ color:#fff; text-decoration:underline; text-underline-offset:2px; }
.aside-card img{ border-radius:var(--radius-sm); margin:0 0 16px; }
.aside-card hr{ border:0; border-top:1px solid rgba(255,255,255,.25); margin:18px 0; }
.aside-card .label{ display:block; font-weight:700; margin-top:14px; }

/* Photo gallery */
.gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.gallery a{ display:block; border-radius:var(--radius-sm); overflow:hidden; box-shadow:var(--shadow-sm); }
.gallery img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .25s; }
.gallery a:hover img{ transform:scale(1.05); }

.band{ background:var(--blue); color:#fff; }
.band .wrap{ padding:18px 0; }
.band h2{ color:#fff; margin:0; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--navy-2); color:#fff; margin-top:60px; }
.site-footer a{ color:#fff; }
.footer-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
  padding:clamp(40px,6vw,64px) 0 32px;
}
.footer-col h2{ color:#fff; font-size:15px; letter-spacing:.06em; text-transform:uppercase; margin:0 0 14px; font-family:var(--font); }
.footer-col ul{ list-style:none; margin:0; padding:0; }
.footer-col li{ margin:0 0 9px; }
.footer-col a{ color:#d7e3ef; font-size:15px; }
.footer-col a:hover{ color:#fff; }
.footer-follow{ font-family:var(--script); font-size:28px; line-height:1; margin:0 0 12px; color:#fff; }
.social{ display:flex; gap:12px; margin-bottom:22px; }
.social a{ display:grid; place-items:center; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.12); transition:background .15s; }
.social a:hover{ background:var(--blue); }
.social svg{ width:20px; height:20px; fill:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.14); }
.footer-bottom .wrap{ padding:18px 0 28px; font-size:14px; color:#b9c8d8; text-align:center; }
.footer-bottom p{ margin:0; }
.footer-bottom .ft-credit{ margin-top:6px; }
.footer-bottom a{ color:#d7e3ef; text-decoration:underline; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .info-cards{ grid-template-columns:1fr; max-width:360px; margin-inline:auto; justify-items:center; }
  .info-card{ width:100%; }
  .home-split,.content-split{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .site-footer .wrap{ padding-inline:26px; }
  .gallery{ grid-template-columns:repeat(3,1fr); }

  .nav-toggle{ display:inline-flex; }
  .menu{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; align-items:stretch; gap:2px;
    background:#fff; border-top:1px solid var(--line); box-shadow:var(--shadow-md);
    padding:10px; max-height:0; overflow:hidden; visibility:hidden;
    transition:max-height .25s ease, visibility .25s;
  }
  .site-nav.open .menu{ max-height:80vh; overflow:auto; visibility:visible; }
  .site-nav .wrap{ position:relative; flex-wrap:wrap; }
  .menu > li > a,.menu > li > button{ width:100%; justify-content:space-between; font-size:16px; }
  .submenu{
    position:static; opacity:1; visibility:visible; transform:none; box-shadow:none;
    border:0; border-left:3px solid var(--line); border-radius:0; margin:2px 0 6px 8px;
    max-height:0; overflow:hidden; padding:0 8px; transition:max-height .22s ease;
  }
  .menu > li.is-open .submenu{ max-height:420px; padding:6px 8px; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .quicklinks{ grid-template-columns:1fr; }
}

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

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lb{
  position:fixed; inset:0; z-index:200; display:none;
  align-items:center; justify-content:center;
  background:rgba(15,28,41,.92); padding:24px;
}
.lb.is-open{ display:flex; }
.lb-stage{ margin:0; max-width:min(1100px,92vw); max-height:88vh; display:flex; flex-direction:column; align-items:center; gap:12px; }
.lb-stage img{ max-width:100%; max-height:78vh; width:auto; border-radius:6px; box-shadow:0 12px 48px rgba(0,0,0,.5); }
.lb-cap{ color:#e7eef6; font-size:15px; text-align:center; }
.lb-close{
  position:absolute; top:14px; right:18px; width:46px; height:46px;
  font-size:30px; line-height:1; color:#fff; background:rgba(255,255,255,.12);
  border:0; border-radius:50%; cursor:pointer;
}
.lb-close:hover{ background:var(--blue); }
.lb-nav{
  flex:0 0 auto; width:52px; height:52px; margin:0 6px; font-size:32px; line-height:1;
  color:#fff; background:rgba(255,255,255,.12); border:0; border-radius:50%; cursor:pointer;
}
.lb-nav:hover{ background:var(--blue); }
@media (max-width:640px){
  .lb-nav{ position:absolute; bottom:18px; }
  .lb-prev{ left:30%; } .lb-next{ right:30%; }
}

/* ============================================================
   NEWSLETTER CARDS
   ============================================================ */
.intro-note{ background:var(--bg-alt); border:1px solid var(--line); border-left:4px solid var(--blue); border-radius:var(--radius); padding:18px 22px; margin:0 0 28px; }
.intro-note strong{ color:var(--blue); }
.news-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,3vw,28px); }
.news-card{
  display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:#fff; box-shadow:var(--shadow-sm);
  transition:transform .18s, box-shadow .18s; color:var(--ink);
}
.news-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); text-decoration:none; }
.news-card img{ width:100%; aspect-ratio:4/5; object-fit:cover; background:var(--bg-alt); }
.news-card .label{ padding:14px 16px; font-weight:700; color:var(--navy); text-align:center; letter-spacing:.02em; }
@media (max-width:760px){ .news-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .news-grid{ grid-template-columns:1fr; max-width:320px; margin-inline:auto; } }

/* ============================================================
   COUNCIL MEMBERS
   ============================================================ */
.meeting-row{ display:grid; grid-template-columns:1fr 1fr auto; gap:24px; align-items:center; background:var(--bg-alt); border:1px solid var(--line); border-radius:var(--radius); padding:22px clamp(18px,3vw,28px); margin-bottom:36px; }
.meeting-row h2{ font-size:18px; color:var(--blue); margin:0 0 6px; font-family:var(--font); letter-spacing:.04em; }
.meeting-row p{ margin:0; font-size:16px; }
@media (max-width:760px){ .meeting-row{ grid-template-columns:1fr; } }
.member-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:clamp(16px,3vw,28px); }
.member{ text-align:center; }
.member img{ width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow-sm); background:var(--bg-alt); }
.member .ph-icon{ width:100%; aspect-ratio:3/4; border-radius:var(--radius); background:var(--bg-alt); display:grid; place-items:center; color:var(--blue); box-shadow:var(--shadow-sm) inset; }
.member .ph-icon svg{ width:46%; height:46%; opacity:.5; }
.member h3{ margin:.7em 0 .1em; font-size:18px; color:var(--navy); }
.member .role{ color:var(--blue); font-weight:600; font-size:15px; }
.member .term{ color:var(--muted); font-size:14px; font-style:italic; }
.member.mayor{ grid-column:1 / -1; max-width:300px; margin-inline:auto; }

/* ============================================================
   ACCORDION
   ============================================================ */
.acc{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.acc details{ border-top:1px solid var(--line); }
.acc details:first-child{ border-top:0; }
.acc summary{
  list-style:none; cursor:pointer; padding:18px 22px; font-weight:700; color:var(--navy);
  background:#fff; display:flex; align-items:center; justify-content:space-between; gap:12px;
  font-size:17px; letter-spacing:.02em; transition:background .15s;
}
.acc summary::-webkit-details-marker{ display:none; }
.acc summary:hover{ background:var(--bg-alt); color:var(--blue); }
.acc summary::after{ content:""; width:11px; height:11px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg); transition:transform .2s; flex:0 0 auto; }
.acc details[open] > summary{ background:var(--bg-alt); color:var(--blue); }
.acc details[open] > summary::after{ transform:rotate(-135deg); }
.acc .acc-body{ padding:8px 24px 22px; }
.acc .acc-body h3{ font-size:16px; color:var(--blue); margin:14px 0 6px; font-family:var(--font); }
.acc .acc-body ul{ padding-left:1.2em; }
.acc .acc-body li{ margin:.35em 0; }
.acc .acc-body a{ color:var(--blue); text-decoration:underline; text-underline-offset:2px; }

/* Grants list */
.grant-list{ list-style:none; padding:0; margin:1em 0 1.5em; }
.grant-list li{ padding:16px 0; margin:0; border-top:1px solid var(--line); font-size:17px; }
.grant-list li:first-child{ border-top:0; }
.grant-list li strong{ color:var(--blue); display:block; margin-bottom:3px; }
