@font-face {
  font-family: 'OverpassLocal';
  src: url('../assets/fonts/overpass/Overpass-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
}
:root {
  --primary: #2f6d45;
  --primary-dark: #1f4d30;
  --primary-soft: #e9f3ed;
  --gold: #d4a64a;
  --text: #24322b;
  --muted: #66756c;
  --line: #dfe8e1;
  --white: #fff;
  --dark: #122018;
  --container: 1200px;
  --shadow: 0 20px 50px rgba(10, 35, 20, .09);
  --radius: 18px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.egovt-site {
  margin: 0;
  font-family: 'Inter', 'OverpassLocal', Arial, sans-serif;
  color: var(--text);
  background: #f7faf8;
  line-height: 1.7;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; }
.site-main { min-height: 60vh; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:12px; text-transform:uppercase; letter-spacing:.18em; color:var(--primary); font-weight:700; }
.eyebrow::before { content:''; width:34px; height:2px; background: var(--gold); display:inline-block; }
.ticker-bar { background: var(--primary-dark); color:#e7f2ea; overflow:hidden; position:relative; z-index:30; transition: transform .3s ease, opacity .3s ease; }
.ticker-bar.hide { transform: translateY(-100%); opacity:0; }
.ticker-inner { display:flex; align-items:center; min-height:44px; gap:18px; }
.ticker-label { background: var(--gold); color:#1e2118; font-weight:800; padding:9px 14px; font-size:12px; text-transform:uppercase; letter-spacing:.12em; }
.ticker-track { display:flex; gap:52px; white-space:nowrap; overflow:hidden; font-size:14px; opacity:.95; }
.ticker-track span { position:relative; animation: ticker 30s linear infinite; }
@keyframes ticker { from { transform: translateX(0);} to { transform: translateX(-100%);} }
.site-header { position: sticky; top: 0; z-index: 40; background: transparent; }
.site-topbar { background: rgba(255,255,255,.96); border-bottom:1px solid rgba(47,109,69,.08); }
.topbar-inner { min-height:46px; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.topbar-left, .topbar-right { display:flex; align-items:center; gap:18px; flex-wrap:wrap; font-size:13px; color:var(--muted); }
.topbar-left span { display:inline-flex; align-items:center; gap:7px; }
.topbar-right a:hover { color: var(--primary); }
.nav-holder { background: rgba(255,255,255,.98); box-shadow: 0 10px 25px rgba(31,77,48,.05); }
.site-header.is-sticky .nav-holder { box-shadow: 0 16px 40px rgba(14,34,23,.12); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; min-height:92px; gap:18px; }
.brand { display:flex; align-items:center; gap:14px; min-width:0; }
.brand img { width:58px; height:58px; object-fit:contain; background:#fff; border-radius:16px; padding:6px; box-shadow: 0 10px 30px rgba(47,109,69,.12); }
.brand-copy { display:flex; flex-direction:column; }
.brand-copy strong { font-family:'Overpass','OverpassLocal',sans-serif; font-size:26px; line-height:1.05; color:#173323; font-weight:800; }
.brand-copy small { color: var(--muted); font-size:13px; }
.main-nav > ul { display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0; }
.main-nav li { position:relative; }
.main-nav > ul > li > a { display:flex; align-items:center; min-height:92px; font-weight:700; color:#183325; font-size:15px; }
.main-nav > ul > li > a.active, .main-nav > ul > li > a:hover { color: var(--primary); }
.submenu { position:absolute; top:100%; left:0; min-width:230px; background:#fff; border-radius:0 0 16px 16px; box-shadow: var(--shadow); padding:18px; opacity:0; visibility:hidden; transform: translateY(10px); transition: all .25s ease; border-top:3px solid var(--gold); }
.has-submenu:hover > .submenu { opacity:1; visibility:visible; transform:none; }
.submenu a { display:block; padding:10px 6px; color:#294033; font-weight:600; border-bottom:1px solid #edf3ee; }
.submenu a:last-child { border-bottom:0; }
.submenu a:hover { color: var(--primary); padding-left:10px; }
.mega-menu { min-width:420px; display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.nav-actions { display:flex; align-items:center; gap:12px; }
.action-btn { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 22px; border-radius:999px; background: var(--primary); color:#fff; font-weight:700; border:1px solid var(--primary); box-shadow: 0 14px 28px rgba(47,109,69,.18); transition: all .25s ease; }
.action-btn:hover { transform: translateY(-2px); background: var(--primary-dark); border-color: var(--primary-dark); color:#fff; }
.action-btn-outline { background:transparent; color: var(--primary); box-shadow:none; }
.action-btn-outline:hover { color:#fff; }
.action-btn.light { background:#fff; color: var(--primary); border-color:#fff; }
.action-btn.light:hover { background:#f1f7f3; color: var(--primary-dark); }
.mobile-toggle { display:none; background:none; border:0; padding:0; width:42px; }
.mobile-toggle span { display:block; height:3px; background:#183325; margin:7px 0; border-radius:999px; transition:.25s; }
.hero-classic { position:relative; background:#163223; overflow:hidden; }
.hero-slides { position:relative; min-height: min(820px, calc(100vh - 138px)); }
.hero-slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; visibility:hidden; transition: opacity .8s ease, transform 1.2s ease; transform: scale(1.02); }
.hero-slide::before { content:''; position:absolute; inset:0; background: linear-gradient(90deg, rgba(11,26,18,.75) 0%, rgba(12,28,18,.45) 42%, rgba(12,28,18,.25) 100%); }
.hero-slide.is-active { opacity:1; visibility:visible; transform: scale(1); }
.hero-content-wrap { position:relative; z-index:2; min-height: min(820px, calc(100vh - 138px)); display:flex; align-items:center; padding:90px 0 180px; }
.hero-copy { max-width: 670px; color:#fff; }
.hero-copy .eyebrow { color:#d7eadf; }
.hero-copy .eyebrow::before { background:#d4a64a; }
.hero-copy h1 { margin:18px 0 18px; font-family:'Overpass','OverpassLocal',sans-serif; font-size: clamp(2.7rem, 5.4vw, 5rem); line-height:1.02; color:#fff; font-weight:800; }
.hero-copy p { font-size:18px; color:rgba(255,255,255,.88); max-width: 600px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }
.hero-controls { position:relative; margin-top:-90px; z-index:5; padding-bottom:42px; display:flex; align-items:flex-end; justify-content:space-between; gap:24px; }
.hero-quick-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:16px; width:min(900px,100%); }
.quick-card { background:#fff; border-radius:20px; padding:26px 20px; box-shadow: var(--shadow); display:flex; flex-direction:column; gap:14px; font-weight:800; color:#173323; transition: transform .25s ease, box-shadow .25s ease; }
.quick-card i { color: var(--primary); width:26px; height:26px; }
.quick-card:hover { transform: translateY(-8px); box-shadow: 0 30px 55px rgba(23,51,35,.15); }
.hero-nav { display:flex; gap:12px; }
.hero-arrow { width:56px; height:56px; border-radius:50%; border:0; font-size:30px; background:#fff; color:var(--primary); box-shadow: var(--shadow); }
.section-block { padding: 72px 0; }
.section-block--compact { padding: 54px 0; }
.muted-bg { background:#f0f6f2; }
.section-heading { max-width:720px; margin-bottom:22px; }
.section-heading h2 { margin:14px 0 0; font-family:'Overpass','OverpassLocal',sans-serif; font-size: clamp(2rem, 4vw, 3.2rem); line-height:1.08; color:#173323; }
.about-grid { display:grid; grid-template-columns: 1.15fr .95fr; gap:34px; align-items:start; }
.about-copy p { font-size:17px; margin-top:0; color:#43564b; }
.about-points { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:24px; }
.about-box, .metric-card, .service-card, .project-card, .inner-content-wrap .card, .inner-content-wrap .dropdown-menu, .inner-content-wrap .table-responsive, .card.bg-transparent { background:#fff !important; border-radius: var(--radius); border:1px solid var(--line) !important; box-shadow: var(--shadow); }
.about-box { padding:24px; }
.about-box strong { display:block; font-family:'Overpass','OverpassLocal',sans-serif; font-size:22px; margin-bottom:8px; }
.metrics-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.metric-card { padding:30px; text-align:left; }
.metric-card strong { display:block; font-family:'Overpass','OverpassLocal',sans-serif; font-size:42px; color: var(--primary); line-height:1; margin-bottom:12px; }
.metric-card span { color:var(--muted); }
.service-grid, .project-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:22px; }
.service-card, .project-card { padding:34px 28px; transition: transform .3s ease, box-shadow .3s ease; }
.service-card:hover, .project-card:hover, .card:hover, .card.bg-transparent:hover { transform: translateY(-10px); box-shadow: 0 34px 58px rgba(24,51,35,.14); }
.service-card i { color: var(--primary); width:38px; height:38px; }
.service-card h3, .project-card h3, .site-footer h4 { font-family:'Overpass','OverpassLocal',sans-serif; font-size:24px; margin:18px 0 10px; line-height:1.2; color:#173323; }
.service-card p, .project-card p { color:#4f6458; margin-bottom:20px; }
.service-card a { color:var(--primary); font-weight:700; }
.project-card span { display:inline-flex; width:50px; height:50px; align-items:center; justify-content:center; border-radius:50%; background:var(--primary-soft); color:var(--primary); font-weight:800; }
.leadership-layout { display:grid; grid-template-columns: .9fr 1.1fr; gap:36px; align-items:center; }
.leadership-image img { width:100%; aspect-ratio: .95 / 1; object-fit:cover; border-radius:26px; box-shadow: var(--shadow); }
.leadership-copy h2, .cta-band__inner h2, .inner-hero h1 { font-family:'Overpass','OverpassLocal',sans-serif; color:#173323; line-height:1.08; }
.leadership-copy h2 { font-size: clamp(2rem, 4vw, 3rem); margin:16px 0; }
.cta-band { padding-top:0; }
.cta-band__inner { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%); color:#fff; border-radius:28px; padding:44px 48px; display:flex; align-items:center; justify-content:space-between; gap:24px; box-shadow: var(--shadow); }
.cta-band__inner .eyebrow { color:#d9ebdf; }
.cta-band__inner .eyebrow::before { background:#f2d08c; }
.cta-band__inner h2 { font-size: clamp(2rem, 4vw, 2.9rem); color:#fff; margin:14px 0 0; max-width: 700px; }
.inner-hero { position:relative; padding: 40px 0 40px; background: linear-gradient(180deg, rgba(28,65,41,.96), rgba(25,55,36,.9)), url('../images/egovt-demo/slide-1.jpg') center/cover no-repeat; }
.inner-hero__content { color:#fff; }
.inner-hero h1 { margin:14px 0 10px; font-size: clamp(2.2rem, 5vw, 4rem); color:#fff; }
.inner-hero p { margin:0; max-width:680px; color:rgba(255,255,255,.85); }
.inner-content-wrap { padding: 10px 0 86px; }
.page-content { background:transparent; }
.page-content > h1, .page-content > h2, .page-content > h3, .page-content > h4 { font-family:'Overpass','OverpassLocal',sans-serif; font-size: clamp(1.8rem, 3vw, 2.5rem); color:#173323; margin:0 0 22px; }
.page-content .row { margin-bottom:24px; }
.card, .card.bg-transparent { overflow:hidden; }
.card .card-header { background: linear-gradient(135deg, #f3f8f4, #ffffff); border-bottom:1px solid var(--line); padding:24px; }
.card .card-body, .inner-content-wrap .page-content, .inner-content-wrap .dropdown-menu { padding:28px; }
.card-title { font-family:'Overpass','OverpassLocal',sans-serif; color:#173323; font-weight:700; }
.text-success, .text-primary, .badge-primary { color: var(--primary) !important; }
.badge-primary { background: var(--primary-soft); border:1px solid rgba(47,109,69,.12); padding:8px 14px; border-radius:999px; }
.btn, .dropdown-toggle { border-radius:999px; padding:13px 22px; font-weight:700; border:1px solid var(--primary) !important; background: var(--primary) !important; color:#fff !important; box-shadow:none !important; }
.btn:hover, .dropdown-toggle:hover { background: var(--primary-dark) !important; }
.dropdown-menu { width:100%; position:relative !important; inset:auto !important; transform:none !important; margin-top:12px; }
.table { margin:0; background:#fff; border-radius:var(--radius); overflow:hidden; }
.table thead th { border-top:none; background:#f1f6f2; color:#173323; font-family:'Overpass','OverpassLocal',sans-serif; font-size:16px; padding:18px 16px; }
.table td { padding:16px; vertical-align:middle; color:#43564b; }
.table tbody tr:not(:last-child) td { border-bottom:1px solid #edf3ee; }
.card-deck { display:grid; grid-template-columns: repeat( auto-fit, minmax(240px, 1fr)); gap:22px; }
.site-footer { background:#132219; color:#dbe9de; margin-top:30px; }
.footer-top { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:24px; padding:64px 0 32px; }
.footer-branding p, .site-footer li, .site-footer a { color:#c8d7cc; }
.site-footer ul { list-style:none; padding:0; margin:0; }
.site-footer li { margin-bottom:10px; }
.brand--footer img { background:rgba(255,255,255,.08); }
.brand--footer .brand-copy strong { color:#fff; }
.brand--footer .brand-copy small { color:#cad9ce; }
.footer-bottom { display:flex; justify-content:space-between; gap:18px; border-top:1px solid rgba(255,255,255,.08); padding:20px 0 28px; font-size:14px; color:#afc2b5; }
.back-to-top { position:fixed; right:24px; bottom:24px; width:54px; height:54px; border-radius:50%; display:grid; place-items:center; background:var(--primary); color:#fff; box-shadow: var(--shadow); opacity:0; visibility:hidden; transform:translateY(12px); transition:.25s; z-index:35; }
.back-to-top.show { opacity:1; visibility:visible; transform:none; }
.reveal { opacity:0; transform: translateY(28px); transition: opacity .75s ease, transform .75s ease; }
.reveal.is-visible { opacity:1; transform:none; }
@media (max-width: 1180px) {
  .main-nav > ul { gap:18px; }
  .hero-slides, .hero-content-wrap { min-height: 720px; }
  .service-grid, .project-grid { grid-template-columns: repeat(2,1fr); }
  .footer-top, .about-grid, .leadership-layout { grid-template-columns:1fr; }
}
@media (max-width: 992px) {
  .ticker-inner, .topbar-inner, .nav-actions { display:none; }
  .mobile-toggle { display:block; }
  .nav-inner { min-height:82px; }
  .main-nav { position:absolute; top:100%; left:16px; right:16px; background:#fff; box-shadow: var(--shadow); border-radius: 0 0 18px 18px; padding:16px 18px 8px; display:none; }
  .main-nav.open { display:block; }
  .main-nav > ul { display:block; }
  .main-nav > ul > li > a { min-height:50px; }
  .submenu, .mega-menu { position:static; min-width:0; opacity:1; visibility:visible; transform:none; display:none; box-shadow:none; border-top:1px solid #edf3ee; padding:8px 0 0; margin:0 0 8px; }
  .has-submenu.open > .submenu { display:block; }
  .mega-menu { grid-template-columns:1fr; }
  .hero-slides, .hero-content-wrap { min-height: 640px; }
  .hero-content-wrap { padding-bottom: 160px; }
  .hero-controls { display:block; margin-top:-66px; }
  .hero-quick-grid { grid-template-columns: repeat(2,1fr); width:100%; }
  .hero-nav { justify-content:flex-end; margin-top:18px; }
}
@media (max-width: 767px) {
  .container { width: min(var(--container), calc(100% - 20px)); }
  .brand-copy strong { font-size:20px; }
  .brand-copy small { font-size:11px; }
  .hero-slides, .hero-content-wrap { min-height: 540px; }
  .hero-content-wrap { align-items:flex-end; padding: 70px 0 150px; }
  .hero-copy h1 { font-size: clamp(2.1rem, 10vw, 3.5rem); }
  .hero-copy p { font-size:16px; }
  .hero-quick-grid, .about-points, .metrics-grid, .service-grid, .project-grid { grid-template-columns:1fr; }
  .section-block { padding: 80px 0; }
  .cta-band__inner, .footer-bottom { display:block; }
  .cta-band__inner { padding:32px 26px; }
  .footer-top { padding-top:56px; }
  .inner-hero { padding: 44px 0 44px; }
  .inner-content-wrap { padding: 42px 0 80px; }
  .card .card-body, .inner-content-wrap .page-content, .inner-content-wrap .dropdown-menu { padding:22px; }
}

/* ticker links */
.ticker-track { position: relative; flex: 1; }
.ticker-loop { display:flex; align-items:center; gap:48px; white-space:nowrap; min-width:max-content; animation: ticker-loop 34s linear infinite; }
.ticker-track:hover .ticker-loop { animation-play-state: paused; }
.ticker-loop a { display:inline-flex; align-items:center; gap:10px; color:#e7f2ea; font-weight:500; }
.ticker-loop a:hover { color:#fff; }
.ticker-loop .feather { width:14px; height:14px; }
@keyframes ticker-loop { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* richer card motion */
.service-card, .project-card, .quick-card, .news-card, .article-panel, .page-council .card, .page-management .card, .page-mayor .card, .page-gallery .card {
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.service-card:hover, .project-card:hover, .quick-card:hover, .news-card:hover, .article-panel:hover, .page-council .card:hover, .page-management .card:hover, .page-mayor .card:hover, .page-gallery .card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgba(12, 44, 26, .14);
}

.section-heading--split { display:flex; align-items:end; justify-content:space-between; gap:20px; }
.section-link { display:inline-flex; align-items:center; gap:10px; color:var(--primary); font-weight:800; }
.section-link .feather { width:18px; height:18px; }

.news-highlights { background: linear-gradient(180deg, #f7faf8 0%, #eef5f0 100%); }
.news-carousel { position:relative; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:18px; }
.news-track {
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: calc((100% - 40px) / 3);
  gap:20px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  scroll-behavior:smooth;
  padding: 4px 2px 12px;
}
.news-track::-webkit-scrollbar { display:none; }
.news-card {
  scroll-snap-align:start;
  background:#fff;
  border:1px solid rgba(47,109,69,.10);
  border-radius:24px;
  overflow:hidden;
  box-shadow: 0 16px 40px rgba(16, 39, 26, .07);
}
.news-card__media { display:block; aspect-ratio: 16 / 10; overflow:hidden; }
.news-card__media img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.news-card:hover .news-card__media img { transform: scale(1.08); }
.news-card__body { padding:24px; }
.news-meta { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:14px; color:var(--muted); font-size:13px; }
.news-meta span { display:inline-flex; align-items:center; gap:7px; }
.news-meta .feather { width:14px; height:14px; color:var(--primary); }
.news-card h3, .article-panel__content h3 {
  font-family:'Overpass','OverpassLocal',sans-serif;
  line-height:1.25;
  margin:0 0 12px;
  color:#173323;
}
.news-card h3 { font-size:1.3rem; }
.news-card p { margin:0 0 14px; color:#55675d; }
.read-more { display:inline-flex; align-items:center; gap:8px; color:var(--primary); font-weight:800; }
.carousel-arrow {
  width:52px; height:52px; border:none; border-radius:50%; background:#fff; color:var(--primary);
  display:grid; place-items:center; box-shadow:0 12px 30px rgba(16,39,26,.10); transition:.25s ease;
}
.carousel-arrow:hover { background:var(--primary); color:#fff; transform:translateY(-2px); }
.carousel-arrow .feather { width:20px; height:20px; }
.article-list { display:grid; gap:28px; }
.article-panel {
  background:#fff; border:1px solid rgba(47,109,69,.10); border-radius:28px; overflow:hidden;
  display:grid; grid-template-columns: 340px 1fr; box-shadow:0 18px 48px rgba(16,39,26,.08);
  scroll-margin-top: 150px;
}
.article-panel__media img { width:100%; height:100%; min-height:100%; object-fit:cover; }
.article-panel__content { padding:34px; }
.article-panel__content p { color:#52665a; margin:0 0 14px; }
.article-panel:target { outline:3px solid rgba(212,166,74,.5); }

/* standardise profile images */
.page-council .card-deck,
.page-management .card-deck,
.page-council .row,
.page-management .row { gap:22px; }
.page-council .card, .page-management .card, .page-mayor .card {
  border:1px solid rgba(47,109,69,.10);
  border-radius:24px;
  background:#fff !important;
  box-shadow:0 14px 34px rgba(16,39,26,.07);
}
.page-council .card .card-header,
.page-management .card .card-header,
.page-mayor .card .card-header {
  padding:28px 24px 16px;
  background:linear-gradient(180deg, #f4f8f5 0%, #ffffff 100%);
}
.page-council .card .card-header img,
.page-management .card .card-header img,
.page-mayor .card .card-header img {
  width: 210px !important;
  max-width:100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position:center top;
  margin:0 auto;
  border-radius:20px;
  border:4px solid #fff;
  box-shadow:0 14px 30px rgba(16,39,26,.10);
  background:#eef4ef;
}
.page-council .card-body, .page-management .card-body, .page-mayor .card-body { padding-top:14px; }
.page-council .card-title a, .page-management .card-title a, .page-mayor .card-title a { color:#173323; }
.page-council .text-success { display:inline-block; padding:4px 10px; border-radius:999px; background:var(--primary-soft); }

@media (max-width: 992px) {
  .section-heading--split { display:block; }
  .news-carousel { grid-template-columns: 1fr; }
  .carousel-arrow { display:none; }
  .news-track { grid-auto-columns: calc((100% - 20px) / 2); }
  .article-panel { grid-template-columns: 1fr; }
  .article-panel__media img { aspect-ratio: 16 / 10; }
}
@media (max-width: 767px) {
  .ticker-label { display:none; }
  .ticker-inner { min-height:40px; }
  .news-track { grid-auto-columns: 88%; }
  .news-card__body, .article-panel__content { padding:22px; }
  .page-council .card .card-header img,
  .page-management .card .card-header img,
  .page-mayor .card .card-header img { width: 180px !important; }
}

/* ======= 2026 professional refinement + CMS-ready components ======= */
:root {
  --gradient-1: linear-gradient(135deg, #18422b 0%, #2f6d45 55%, #3e8257 100%);
  --gradient-2: linear-gradient(135deg, rgba(24,66,43,.96) 0%, rgba(20,49,32,.88) 48%, rgba(14,34,23,.82) 100%);
  --card-shadow-lg: 0 24px 70px rgba(10, 34, 20, .12);
}
body.egovt-site {
  background:
    radial-gradient(circle at top right, rgba(212,166,74,.12), transparent 22%),
    radial-gradient(circle at top left, rgba(47,109,69,.08), transparent 28%),
    #f6faf7;
}
.site-topbar,
.nav-holder,
.card,
.content-card,
.listing-card,
.profile-card,
.gallery-card,
.news-card,
.table-shell,
.department-showcase,
.cta-band__inner,
.quick-card,
.metric-card,
.service-card,
.project-card,
.article-panel {
  backdrop-filter: blur(6px);
}
.hero-classic {
  position: relative;
  overflow: clip;
  background: #102117;
}
.hero-classic::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(12,26,18,.3), rgba(12,26,18,.12));
  pointer-events: none;
  z-index: 0;
}
.hero-slides {
  position: relative;
  min-height: clamp(520px, 68vh, 760px);
  max-height: 760px;
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .9s ease, visibility .9s ease, transform 1.2s ease;
  background-size: cover;
  background-position: center center;
  transform: scale(1.03);
}
.hero-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-2);
}
.hero-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
}
.hero-content-wrap {
  position: relative;
  z-index: 1;
  min-height: clamp(520px, 68vh, 760px);
  max-height: 760px;
  display: flex;
  align-items: center;
  padding: 120px 0 170px;
}
.hero-copy {
  max-width: 760px;
  color: #fff;
}
.hero-copy h1 {
  font-family:'Overpass','OverpassLocal',sans-serif;
  font-size: clamp(2.6rem, 5vw, 5rem);
  line-height: 1.02;
  margin: 16px 0;
  color: #fff;
  text-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.hero-copy p {
  font-size: 1.08rem;
  max-width: 640px;
  color: rgba(255,255,255,.9);
}
.hero-controls {
  position: relative;
  z-index: 4;
  margin-top: -88px;
  padding-bottom: 22px;
}
.hero-quick-grid {
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(47,109,69,.08);
  box-shadow: var(--card-shadow-lg);
}
.hero-arrow,
.carousel-btn {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: 1px solid rgba(47,109,69,.14);
  background: #fff;
  color: #173323;
  box-shadow: 0 12px 30px rgba(17,38,26,.1);
  display: inline-grid;
  place-items: center;
  font-size: 22px;
  transition: transform .25s ease, background .25s ease, color .25s ease;
}
.hero-arrow:hover,
.carousel-btn:hover { background: var(--primary); color:#fff; transform: translateY(-3px); }
.about-split,
.services-section,
.news-highlights,
.leadership-band { position: relative; }
.section-heading h2,
.about-copy h2 { font-family:'Overpass','OverpassLocal',sans-serif; font-size: clamp(2rem, 3vw, 3rem); color:#173323; margin: 16px 0 10px; }
.content-shell { display: grid; gap: 26px; }
.department-showcase {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
  padding: 36px;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(244,249,245,.98));
  box-shadow: var(--card-shadow-lg);
  border: 1px solid rgba(47,109,69,.08);
}
.department-showcase__copy .lead,
.article-panel__content .lead { font-size: 1.05rem; color:#496055; }
.info-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.content-card,
.table-shell {
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,248,.98));
  border-radius: 24px;
  border: 1px solid rgba(47,109,69,.08);
  box-shadow: 0 16px 40px rgba(16,39,26,.07);
  padding: 28px;
}
.content-card__head { display:flex; align-items:center; gap:14px; margin-bottom: 18px; }
.content-card__head i { width: 40px; height: 40px; border-radius: 14px; display:grid; place-items:center; background: var(--primary-soft); color: var(--primary); }
.feature-list { list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.feature-list li { display:flex; gap:12px; align-items:flex-start; color:#41564b; }
.feature-list i { width:18px; height:18px; color: var(--primary); margin-top:4px; flex:0 0 auto; }
.profile-grid,
.gallery-grid,
.listing-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.profile-card,
.listing-card,
.gallery-card {
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,248,.98));
  border-radius: 24px;
  border: 1px solid rgba(47,109,69,.08);
  box-shadow: 0 16px 40px rgba(16,39,26,.07);
}
.profile-card__image,
.listing-card__image,
.gallery-card__trigger {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 4.2;
  overflow: hidden;
  background: linear-gradient(135deg,#dce9df,#f7fbf8);
}
.profile-card__image img,
.listing-card__image img,
.gallery-card__trigger img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.profile-card--dept .profile-card__image { aspect-ratio: 1 / 1; }
.profile-card__body,
.listing-card__body { padding: 24px; }
.profile-card__body h3,
.listing-card__body h3,
.content-card h2,
.content-card h3 { font-family:'Overpass','OverpassLocal',sans-serif; color:#173323; margin:0 0 10px; }
.profile-card__body p,
.listing-card__body p { color:#607368; margin:0; }
.listing-card__meta {
  display:inline-flex;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: var(--primary);
  margin-bottom: 12px;
}
.inline-link { display:inline-flex; align-items:center; gap:10px; margin-top:16px; font-weight:800; color:var(--primary); }
.inline-link:hover { color: var(--primary-dark); }
.article-stack { display:grid; gap: 24px; }
.article-panel {
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,248,.98));
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(47,109,69,.08);
  box-shadow: 0 16px 40px rgba(16,39,26,.07);
}
.article-panel__media { min-height: 320px; }
.article-panel__media img { width:100%; height:100%; object-fit:cover; }
.article-panel__content { padding: 30px; }
.gallery-card__trigger { border: 0; padding: 0; cursor: pointer; width: 100%; text-align: left; background: none; }
.gallery-card__overlay {
  position:absolute;
  inset:auto 0 0 0;
  padding: 18px;
  display:grid;
  gap: 4px;
  color:#fff;
  background: linear-gradient(180deg, transparent, rgba(11,28,19,.88));
}
.gallery-card__overlay strong { font-family:'Overpass','OverpassLocal',sans-serif; font-size:1.1rem; }
.gallery-card__overlay small { color:rgba(255,255,255,.82); }
.gallery-lightbox[hidden] { display:none; }
.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99;
  display:grid;
  place-items:center;
}
.gallery-lightbox__backdrop { position:absolute; inset:0; background: rgba(5,10,7,.7); }
.gallery-lightbox__dialog {
  position:relative;
  z-index:1;
  width:min(980px, calc(100% - 24px));
  background:#fff;
  border-radius: 22px;
  overflow:hidden;
  box-shadow: 0 32px 90px rgba(0,0,0,.3);
}
.gallery-lightbox__dialog img { width:100%; max-height: 70vh; object-fit: contain; background:#0f1913; }
.gallery-lightbox__caption { padding: 22px 24px; }
.gallery-lightbox__close {
  position:absolute;
  top: 14px; right: 14px;
  width: 42px; height: 42px; border-radius:50%; border:0; background:#fff; color:#173323; font-size: 28px; cursor:pointer;
}
body.lightbox-open { overflow:hidden; }
.table-shell { overflow-x:auto; }
.status-pill { display:inline-flex; padding:8px 12px; border-radius:999px; background:var(--primary-soft); color:var(--primary); font-weight:800; font-size:12px; letter-spacing:.08em; }
.leadership-mini-grid { display:grid; gap:14px; margin-top:22px; }
.mini-profile { display:flex; align-items:center; gap:14px; padding:12px 14px; border-radius:18px; background:#fff; border:1px solid rgba(47,109,69,.08); box-shadow: 0 12px 30px rgba(16,39,26,.06); }
.mini-profile img { width:62px; height:62px; object-fit:cover; border-radius:18px; }
.mini-profile strong { display:block; color:#173323; }
.mini-profile span { color:#607368; font-size:14px; }
.ticker-loop a { pointer-events:auto; }
.ticker-track:hover .ticker-loop { animation-play-state: paused; }
.site-footer { background: linear-gradient(180deg, #122018 0%, #0d1610 100%); }
.page-gallery .inner-content-wrap,
.page-news .inner-content-wrap,
.page-ts .inner-content-wrap,
.page-central .inner-content-wrap,
.page-housing .inner-content-wrap,
.page-eng .inner-content-wrap,
.page-finance .inner-content-wrap,
.page-council .inner-content-wrap,
.page-mayor .inner-content-wrap,
.page-management .inner-content-wrap { background: linear-gradient(180deg, #f6faf7 0%, #edf5ef 100%); }

@media (max-width: 1180px) {
  .profile-grid,
  .gallery-grid,
  .listing-grid,
  .news-track { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .department-showcase,
  .article-panel,
  .leadership-layout,
  .info-grid { grid-template-columns: 1fr; }
}
@media (max-width: 992px) {
  .hero-slides,
  .hero-content-wrap { min-height: 620px; max-height:none; }
  .hero-content-wrap { padding-top: 96px; padding-bottom: 150px; }
  .hero-controls { margin-top:-66px; }
  .news-track { grid-auto-columns: calc((100% - 20px) / 2); }
}
@media (max-width: 767px) {
  .hero-slides,
  .hero-content-wrap { min-height: 520px; }
  .hero-content-wrap { align-items: end; padding: 86px 0 145px; }
  .department-showcase,
  .content-card,
  .table-shell { padding: 22px; }
  .profile-grid,
  .gallery-grid,
  .listing-grid { grid-template-columns: 1fr; }
  .news-track { grid-auto-columns: 100%; }
  .article-panel__media { min-height: 220px; }
}


/* Additions for MySQL CMS public pages */
.content-shell{padding:18px 0 8px}
.news-list-grid,.album-grid,.committee-grid,.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}
.news-list-card,.album-card,.committee-card,.article-panel,.content-card{background:#fff;border-radius:28px;box-shadow:0 18px 55px rgba(16,46,28,.08);overflow:hidden;border:1px solid rgba(31,83,54,.08)}
.news-list-card img,.album-card img,.article-panel__media img{width:100%;height:240px;object-fit:cover;display:block}
.news-list-card__body,.album-card__body,.article-panel__content{padding:24px}
.news-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;color:#6d7c72;font-size:14px}
.inline-link{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-weight:700;color:var(--egovt-primary,#24583a);text-decoration:none}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:28px;flex-wrap:wrap}.pagination a{width:44px;height:44px;display:grid;place-items:center;border-radius:999px;background:#fff;border:1px solid rgba(31,83,54,.12);text-decoration:none;color:#20412d;font-weight:700}.pagination a.active,.pagination a:hover{background:linear-gradient(135deg,#21573a,#2f744c);color:#fff;border-color:transparent}
.article-detail,.committee-detail{display:grid;gap:28px}.comments-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:28px}.comment-item{padding:16px 0;border-bottom:1px solid #edf1ee}.comment-item strong{display:block;color:#183526}.comment-item span{font-size:13px;color:#6e7c72}.comment-form input,.comment-form textarea{width:100%;border:1px solid #d8e0d8;border-radius:16px;padding:14px 16px}.notice-success{padding:14px 16px;border-radius:14px;background:#eef7f0;color:#29533b;border:1px solid #dce9de;margin-bottom:16px}
.filter-chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}.filter-chips a{padding:10px 16px;border-radius:999px;background:#fff;border:1px solid rgba(31,83,54,.12);text-decoration:none;color:#1c3829;font-weight:700}.filter-chips a.active,.filter-chips a:hover{background:linear-gradient(135deg,#21573a,#2f744c);color:#fff}
.album-viewer{background:#fff;border-radius:28px;box-shadow:0 20px 60px rgba(16,46,28,.08);padding:24px;border:1px solid rgba(31,83,54,.08)}.album-main{position:relative;border-radius:20px;overflow:hidden;background:#eff4f0}.album-main img{width:100%;height:min(72vh,620px);object-fit:cover;display:block}.album-nav{position:absolute;top:50%;transform:translateY(-50%);border:0;width:48px;height:48px;border-radius:999px;background:rgba(255,255,255,.88);box-shadow:0 10px 25px rgba(0,0,0,.12);font-size:28px;line-height:1}.album-nav.prev{left:18px}.album-nav.next{right:18px}.album-thumbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin-top:16px}.album-thumb{padding:0;border:2px solid transparent;border-radius:14px;overflow:hidden;background:#fff}.album-thumb.active{border-color:#2b6f48}.album-thumb img{width:100%;height:88px;object-fit:cover;display:block}
.committee-meta,.committee-leads,.member-list{display:grid;gap:12px}.member-item{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid #edf1ee}.member-item span{color:#6f7a72}
@media (max-width: 991px){.comments-wrap{grid-template-columns:1fr}.news-list-card img,.album-card img,.article-panel__media img{height:220px}}


.submenu--compact{min-width:420px}.footer-social{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.footer-social a{width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;color:#fff;text-decoration:none;background:rgba(255,255,255,.06);transition:all .2s ease}.footer-social a:hover{transform:translateY(-2px);background:rgba(255,255,255,.14)}.footer-social .social-text{font-size:12px;font-weight:800;letter-spacing:.04em}
.department-page .department-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;margin-top:28px}.department-page .content-card,.committee-detail .content-card,.committee-card{padding:28px}.department-page .department-hero-card,.committee-detail .department-hero-card{align-items:stretch}.department-page .department-hero-card__copy,.committee-detail .department-hero-card__copy{padding:34px}.department-page .department-hero-card__media img{width:100%;height:100%;min-height:320px;object-fit:cover;display:block}.department-page ul,.committee-detail ul{margin:0;padding-left:18px}.department-page li,.committee-detail li{margin-bottom:10px}.committee-card h3,.department-page h3,.committee-detail h3{margin-bottom:14px;color:#143424}.committee-card .inline-link{margin-top:18px}
.contact-intro-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;margin-bottom:28px}.contact-overview-card,.location-card{padding:30px}.contact-overview-list,.location-meta,.location-summary-list{display:grid;gap:14px}.contact-overview-list div,.location-meta div,.location-summary-item{padding:14px 16px;border-radius:18px;background:#f5f8f6;border:1px solid rgba(31,83,54,.08)}.location-summary-item{text-decoration:none;color:#20412d}.location-summary-item strong{display:block;margin-bottom:4px}.location-summary-item span,.contact-overview-list span,.location-meta span{display:block;color:#637269}.location-stack{display:grid;gap:28px}.location-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,460px);gap:28px;align-items:start}.location-card__map iframe{width:100%;height:100%;min-height:360px;border:0;border-radius:24px;background:#eef3ef}.location-actions{margin-top:22px}.location-meta{margin-top:20px}
@media (max-width: 991px){.submenu--compact{min-width:0}.department-page .department-grid-2,.contact-intro-grid,.location-card{grid-template-columns:1fr}.location-card__map iframe{min-height:300px}}

.presidential-band { padding-top: 0; }
.presidential-band__inner {
  background: linear-gradient(135deg, rgba(31,77,48,.96), rgba(47,109,69,.95));
  border-radius: 28px;
  padding: 34px 38px;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 28px;
  color: #fff;
  box-shadow: var(--shadow);
}
.presidential-band__inner .eyebrow { color: #d9ebdf; }
.presidential-band__inner .eyebrow::before { background: #f2d08c; }
.presidential-band__inner h2 {
  margin: 14px 0 0;
  color: #fff;
  font-family:'Overpass','OverpassLocal',sans-serif;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
}
.presidential-band__inner p { margin: 0; color: rgba(255,255,255,.88); font-size: 16px; }

.values-section { background: linear-gradient(180deg, #f8fbf9 0%, #f1f6f3 100%); }
.vmv-grid, .payment-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.payment-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.vmv-card, .payment-card {
  background: #fff;
  border: 1px solid rgba(47,109,69,.10);
  border-radius: 24px;
  padding: 28px 24px;
  box-shadow: 0 16px 40px rgba(16, 39, 26, .07);
}
.vmv-icon, .payment-icon {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-soft);
  color: var(--primary);
}
.vmv-icon .feather, .payment-icon .feather { width: 24px; height: 24px; }
.vmv-card h3, .payment-card h3 {
  margin: 18px 0 12px;
  font-family:'Overpass','OverpassLocal',sans-serif;
  font-size: 1.45rem;
  color: #173323;
}
.vmv-card p, .payment-card p { margin: 0; color: #55675d; }
.values-list { margin: 0; padding-left: 18px; color: #55675d; }
.values-list li + li { margin-top: 8px; }

.payment-platforms { background: #fff; }
.payment-actions { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:28px; }
.payment-card { transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.payment-card:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(12, 44, 26, .14); }

@media (max-width: 1180px) {
  .payment-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .presidential-band__inner { grid-template-columns: 1fr; }
}
@media (max-width: 992px) {
  .section-block--compact { padding: 42px 0; }
  .vmv-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .section-block { padding: 54px 0; }
  .section-block--compact { padding: 34px 0; }
  .payment-grid { grid-template-columns: 1fr; }
  .presidential-band__inner { padding: 28px 24px; }
}


.document-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap:22px; }
.document-card { height:100%; }
.document-meta { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.document-date { display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:14px; }
.document-date .feather { width:16px; height:16px; }
.document-actions { margin-top:18px; }
.document-section + .document-section { margin-top: 28px; }

.department-section-stack { display:grid; gap:18px; }
.department-section-card { border: 1px solid rgba(47,109,69,.1); border-radius: 22px; padding: 24px; background: rgba(255,255,255,.86); }
.department-section-card__header { display:grid; grid-template-columns: minmax(0, 1fr) auto; gap: 18px; align-items:start; margin-bottom: 18px; }
.department-section-card__header h4 { margin: 6px 0 8px; color:#173323; }
.department-section-card__header p { margin:0; color:#607368; }
.section-head-chip { min-width: 220px; padding: 16px 18px; border-radius: 18px; background: linear-gradient(135deg, rgba(47,109,69,.10), rgba(47,109,69,.04)); border: 1px solid rgba(47,109,69,.12); display:grid; gap:4px; }
.section-head-chip strong { color:#173323; }
.section-head-chip span { color:#607368; }
.team-member-list { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.team-member-list--general { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.team-member-item { border-radius: 18px; padding: 16px 18px; background: linear-gradient(180deg, rgba(244,249,245,.92), rgba(255,255,255,.96)); border: 1px solid rgba(47,109,69,.08); display:grid; gap:4px; }
.team-member-item strong { color:#173323; }
.team-member-item span, .team-member-item small, .empty-state { color:#607368; }
.empty-state { margin:0; }
@media (max-width: 991px) { .department-section-card__header { grid-template-columns: 1fr; } .section-head-chip { min-width: 0; } .team-member-list, .team-member-list--general { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px) { .team-member-list, .team-member-list--general { grid-template-columns: 1fr; } }
