.wb-cms-page .entry-header,
.wb-cms-page .wp-block-post-title,
.wb-cms-page .site-main > .page-header { display: none !important; }

.wb-cms-page .entry-content,
.wb-cms-page .site-main,
.wb-cms-page .wp-site-blocks { margin: 0 !important; max-width: none !important; padding: 0 !important; }

.wb-site {
  --green: #09845e;
  --green-dark: #075f46;
  --lime: #b6dc46;
  --ink: #13261f;
  --muted: #65756e;
  --paper: #f5f8f5;
  --line: #dce7e1;
  background: #fff;
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.65;
  overflow: hidden;
}

.wb-site * { box-sizing: border-box; }
.wb-site h1, .wb-site h2, .wb-site h3, .wb-site p { margin-top: 0; }
.wb-site a { text-decoration: none; }
.wb-container { margin: 0 auto; max-width: 1180px; padding-left: 24px; padding-right: 24px; }

.wb-logo-strip {
  align-items: center;
  background: #fff;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(16px, 4vw, 52px);
  justify-content: center;
  min-height: 104px;
  padding: 18px 24px;
}

.wb-logo-strip > img {
  height: clamp(50px, 7vw, 76px);
  max-width: min(240px, 35vw);
  object-fit: contain;
  width: auto;
}

.wb-wordmark {
  align-items: center;
  color: var(--ink);
  display: grid;
  grid-template-columns: 62px auto;
  line-height: 1.1;
}

.wb-wordmark > span {
  align-items: center;
  background: var(--green);
  border-radius: 50% 50% 44% 56%;
  color: #fff;
  display: flex;
  font-size: 32px;
  font-weight: 950;
  grid-row: 1 / 3;
  height: 54px;
  justify-content: center;
  margin-right: 12px;
  transform: rotate(-5deg);
}

.wb-wordmark strong { font-size: 25px; font-weight: 900; letter-spacing: -.03em; }
.wb-wordmark small { color: var(--green); font-size: 10px; font-weight: 800; letter-spacing: .1em; margin-top: 5px; text-transform: uppercase; }

.wb-slider { background: #173a30; height: clamp(390px, 52vw, 610px); overflow: hidden; position: relative; }
.wb-slides, .wb-slide { height: 100%; }

.wb-slide {
  background-image: var(--wb-bg), linear-gradient(135deg, #194f40, #0a2d24);
  background-position: center;
  background-size: cover;
  display: none;
  inset: 0;
  position: absolute;
}

.wb-slide.is-active { animation: wbFade .7s ease; display: block; }
.wb-slide-overlay { background: linear-gradient(90deg, rgba(5,30,23,.88) 0%, rgba(5,30,23,.57) 48%, rgba(5,30,23,.1) 100%); inset: 0; position: absolute; }

.wb-slide-content {
  color: #fff;
  left: max(24px, calc((100vw - 1180px) / 2 + 24px));
  max-width: 680px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.wb-slide-content > span,
.wb-page-hero span,
.wb-section-heading > span,
.wb-event-card > div > span,
.wb-event-slide div > span,
.wb-story > div > span,
.wb-contact-card > span {
  color: var(--lime);
  display: block;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  margin-bottom: 12px;
  text-transform: uppercase;
}

.wb-slide-content h2 {
  color: #fff;
  font-size: clamp(38px, 6vw, 72px);
  font-weight: 900;
  letter-spacing: -.055em;
  line-height: .98;
  margin-bottom: 20px;
}

.wb-slide-content p { color: #d8e9e2; font-size: clamp(16px, 2vw, 20px); max-width: 620px; }
.wb-slide-content a { background: var(--lime); border-radius: 999px; color: #173328; display: inline-block; font-weight: 900; margin-top: 10px; padding: 13px 21px; }

.wb-slide-prev, .wb-slide-next {
  align-items: center;
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 50%;
  color: #fff;
  cursor: pointer;
  display: flex;
  font-size: 28px;
  height: 46px;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  z-index: 3;
}

.wb-slide-prev { left: 18px; }
.wb-slide-next { right: 18px; }
.wb-dots { bottom: 24px; display: flex; gap: 8px; left: 50%; position: absolute; transform: translateX(-50%); z-index: 4; }
.wb-dots button { background: rgba(255,255,255,.45); border: 0; border-radius: 9px; cursor: pointer; height: 7px; padding: 0; transition: .25s; width: 7px; }
.wb-dots button.is-active { background: var(--lime); width: 30px; }

.wb-nav-wrap { background: #fff; border-bottom: 1px solid var(--line); box-shadow: 0 9px 30px rgba(17,49,39,.08); position: relative; z-index: 10; }
.wb-nav { display: flex; justify-content: center; }
.wb-nav a { border-bottom: 3px solid transparent; color: var(--muted); font-size: 14px; font-weight: 800; padding: 19px 26px 16px; }
.wb-nav a:hover, .wb-nav a.is-active { border-color: var(--green); color: var(--green); }
.wb-menu-toggle { display: none; }

.wb-page-hero { background: radial-gradient(circle at 85% 20%, rgba(182,220,70,.2), transparent 28%), var(--paper); padding: 78px 0 72px; text-align: center; }
.wb-page-hero span { color: var(--green); }
.wb-page-hero h1 { font-size: clamp(36px, 5vw, 60px); font-weight: 900; letter-spacing: -.045em; line-height: 1.05; margin-bottom: 16px; }
.wb-page-hero p { color: var(--muted); font-size: 18px; margin: 0 auto; max-width: 760px; }
.wb-sections { display: grid; gap: 88px; padding-bottom: 96px; padding-top: 80px; }

.wb-home-intro {
  background: radial-gradient(circle at 85% 10%, rgba(182,220,70,.28), transparent 25%), linear-gradient(135deg, #f3f8f4, #fff);
  padding: 88px 0;
  text-align: center;
}

.wb-home-intro span,
.wb-home-story > .wb-container > div:last-child > span,
.wb-home-cta span {
  color: var(--green);
  display: block;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  margin-bottom: 12px;
  text-transform: uppercase;
}

.wb-home-intro h1 {
  font-size: clamp(42px, 6vw, 68px);
  font-weight: 900;
  letter-spacing: -.055em;
  line-height: 1;
  margin: 0 auto 20px;
  max-width: 900px;
}

.wb-home-intro p { color: var(--muted); font-size: 19px; margin: 0 auto; max-width: 780px; }
.wb-home-features, .wb-home-services, .wb-home-gallery { padding-bottom: 88px; padding-top: 88px; }
.wb-feature-grid { display: grid; gap: 20px; grid-template-columns: repeat(3, 1fr); }

.wb-feature-grid article {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(17,49,39,.06);
  padding: 30px;
}

.wb-feature-grid article > span {
  align-items: center;
  background: #def3e8;
  border-radius: 14px;
  color: var(--green);
  display: flex;
  font-size: 26px;
  height: 58px;
  justify-content: center;
  margin-bottom: 35px;
  width: 58px;
}

.wb-feature-grid h3 { font-size: 23px; margin-bottom: 10px; }
.wb-feature-grid p { color: var(--muted); margin: 0; }

.wb-home-story { background: var(--paper); padding: 90px 0; }
.wb-home-story > .wb-container { align-items: center; display: grid; gap: 65px; grid-template-columns: 1.05fr .95fr; }
.wb-home-story-image { background: linear-gradient(145deg, #2aa378, #075f46); border-radius: 24px; height: 520px; overflow: hidden; }
.wb-home-story-image img { height: 100%; object-fit: cover; width: 100%; }
.wb-home-story-image > span { align-items: center; color: rgba(255,255,255,.9); display: flex; font-size: 110px; height: 100%; justify-content: center; }
.wb-home-story h2 { font-size: clamp(36px, 5vw, 55px); letter-spacing: -.05em; line-height: 1.04; }
.wb-home-story p { color: var(--muted); font-size: 18px; }
.wb-home-story a, .wb-text-link { color: var(--green); display: inline-block; font-weight: 900; margin-top: 12px; }
.wb-home-milestones { padding-bottom: 88px; }

.wb-home-cta { background: linear-gradient(125deg, #087555, #064331); color: #fff; padding: 72px 0; }
.wb-home-cta .wb-container { align-items: center; display: flex; gap: 40px; justify-content: space-between; }
.wb-home-cta span { color: var(--lime); }
.wb-home-cta h2 { color: #fff; font-size: clamp(34px, 5vw, 52px); letter-spacing: -.045em; line-height: 1.05; margin-bottom: 12px; }
.wb-home-cta p { color: #c5dfd5; margin: 0; max-width: 720px; }
.wb-home-cta a { background: var(--lime); border-radius: 999px; color: #173328; flex: 0 0 auto; font-weight: 900; padding: 14px 22px; }

.wb-social-strip { background: #eaf5ef; padding: 28px 0; }
.wb-social-strip .wb-container { align-items: center; display: flex; gap: 25px; justify-content: space-between; }
.wb-social-strip strong { font-size: 18px; }
.wb-social-strip .wb-container > div { display: flex; flex-wrap: wrap; gap: 10px; }
.wb-social-strip a { background: #fff; border: 1px solid #d4e5dd; border-radius: 999px; color: var(--green-dark); font-size: 13px; font-weight: 800; padding: 9px 14px; }

.wb-section-heading { margin-bottom: 28px; }
.wb-section-heading > span { color: var(--green); margin-bottom: 7px; }
.wb-section-heading h2 { font-size: clamp(30px, 4vw, 44px); letter-spacing: -.04em; line-height: 1.1; margin: 0; }

.wb-team-section { border-bottom: 1px solid var(--line); padding-bottom: 72px; }
.wb-team-section:last-child { border: 0; padding-bottom: 0; }
.wb-team-grid { display: grid; gap: 22px; grid-template-columns: repeat(2, minmax(0, 1fr)); }

.wb-profile {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 13px 34px rgba(17,49,39,.07);
  display: grid;
  gap: 24px;
  grid-template-columns: 150px 1fr;
  min-height: 220px;
  overflow: hidden;
  padding: 18px;
}

.wb-profile-photo { background: linear-gradient(145deg, #dbefe6, #a9d9c5); border-radius: 13px; height: 184px; overflow: hidden; }
.wb-profile-photo img { height: 100%; object-fit: cover; width: 100%; }
.wb-profile-photo span { align-items: center; color: #fff; display: flex; font-size: 60px; font-weight: 900; height: 100%; justify-content: center; }
.wb-profile small { color: var(--green); font-size: 11px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.wb-profile h3 { font-size: 23px; line-height: 1.1; margin: 6px 0 10px; }
.wb-profile p { color: var(--muted); font-size: 14px; line-height: 1.65; margin: 0; }
.wb-dropcap::first-letter { color: var(--green); float: left; font-size: 43px; font-weight: 900; line-height: .8; margin: 8px 7px 0 0; }

.wb-service-grid { display: grid; gap: 20px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.wb-service-card { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; min-height: 280px; padding: 30px 25px; transition: transform .25s, box-shadow .25s; }
.wb-service-card:hover { box-shadow: 0 18px 40px rgba(17,49,39,.1); transform: translateY(-5px); }
.wb-service-card > span { align-items: center; background: #dff3e9; border-radius: 13px; color: var(--green); display: flex; font-size: 25px; height: 54px; justify-content: center; margin-bottom: 40px; width: 54px; }
.wb-service-card h2 { font-size: 21px; line-height: 1.15; margin-bottom: 12px; }
.wb-service-card p { color: var(--muted); font-size: 14px; margin: 0; }

.wb-milestones { background: linear-gradient(130deg, #0a7656, #064d39); border-radius: 22px; color: #fff; display: grid; gap: 1px; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); overflow: hidden; padding: 18px; }
.wb-milestones div { border-right: 1px solid rgba(255,255,255,.18); padding: 28px; text-align: center; }
.wb-milestones div:last-child { border: 0; }
.wb-milestones strong { color: #fff; display: block; font-size: clamp(36px, 5vw, 54px); font-weight: 900; letter-spacing: -.04em; line-height: 1; }
.wb-milestones span { color: #bfe0d3; display: block; font-size: 13px; font-weight: 700; margin-top: 10px; }

.wb-gallery { display: grid; gap: 14px; grid-auto-rows: 250px; grid-template-columns: repeat(12, 1fr); }
.wb-gallery figure { border-radius: 16px; grid-column: span 4; margin: 0; overflow: hidden; position: relative; }
.wb-gallery figure:nth-child(5n+1), .wb-gallery figure:nth-child(5n+4) { grid-column: span 8; }
.wb-gallery img { height: 100%; object-fit: cover; transition: transform .5s; width: 100%; }
.wb-gallery figure:hover img { transform: scale(1.04); }
.wb-gallery figcaption { background: linear-gradient(transparent, rgba(0,0,0,.75)); bottom: 0; color: #fff; font-size: 13px; font-weight: 700; left: 0; padding: 35px 17px 14px; position: absolute; right: 0; }

.wb-event-card { align-items: center; background: var(--paper); border-radius: 20px; display: grid; gap: 40px; grid-template-columns: 1fr auto; padding: 38px; }
.wb-event-card h2 { font-size: 36px; letter-spacing: -.04em; margin-bottom: 12px; }
.wb-event-card p { color: var(--muted); margin: 0; max-width: 750px; }
.wb-event-card aside { background: #fff; border: 1px solid var(--line); border-radius: 14px; min-width: 210px; padding: 20px; }
.wb-event-card aside strong, .wb-event-card aside span { display: block; }
.wb-event-card aside strong { color: var(--green); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }
.wb-event-card aside span { font-size: 18px; font-weight: 800; margin-top: 5px; }

.wb-event-slider { background: var(--ink); border-radius: 22px; min-height: 520px; overflow: hidden; position: relative; }
.wb-event-slide { display: none; grid-template-columns: 1.4fr 1fr; min-height: 520px; }
.wb-event-slide.is-active { animation: wbFade .6s ease; display: grid; }
.wb-event-slide > img { height: 100%; object-fit: cover; width: 100%; }
.wb-event-slide > div { align-self: center; color: #fff; padding: 48px; }
.wb-event-slide h2 { color: #fff; font-size: 36px; line-height: 1.1; }
.wb-event-slide p { color: #c7d8d1; }

.wb-story { align-items: center; display: grid; gap: 60px; grid-template-columns: 1fr 1fr; }
.wb-story img, .wb-story-placeholder { border-radius: 22px; height: 500px; object-fit: cover; width: 100%; }
.wb-story-placeholder { align-items: center; background: radial-gradient(circle, #4fbf92, #087655); display: flex; justify-content: center; }
.wb-story-placeholder span { color: rgba(255,255,255,.9); font-size: 110px; }
.wb-story h2 { font-size: clamp(36px, 5vw, 55px); letter-spacing: -.05em; line-height: 1.04; }
.wb-story p { color: var(--muted); font-size: 18px; }

.wb-purpose { display: grid; gap: 20px; grid-template-columns: repeat(2, 1fr); }
.wb-purpose article { background: var(--paper); border-radius: 18px; padding: 34px; }
.wb-purpose article > span { color: var(--green); font-size: 13px; font-weight: 900; }
.wb-purpose h2 { font-size: 30px; margin: 20px 0 12px; }
.wb-purpose p, .wb-values p { color: var(--muted); margin: 0; }
.wb-values { display: grid; gap: 18px; grid-template-columns: repeat(3, 1fr); }
.wb-values article { border-left: 3px solid var(--lime); padding: 8px 24px; }
.wb-values h3 { font-size: 21px; margin-bottom: 8px; }

.wb-contact-grid { display: grid; gap: 25px; grid-template-columns: .9fr 1.1fr; }
.wb-contact-card { background: var(--ink); border-radius: 22px; color: #fff; padding: 42px; }
.wb-contact-card h2 { color: #fff; font-size: 40px; letter-spacing: -.04em; line-height: 1.1; }
.wb-contact-card dl { margin: 32px 0; }
.wb-contact-card dl > div { border-top: 1px solid rgba(255,255,255,.14); padding: 16px 0; }
.wb-contact-card dt { color: #9cb5ab; font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.wb-contact-card dd { margin: 4px 0 0; }
.wb-contact-card a { color: #fff; }
.wb-socials { display: flex; flex-wrap: wrap; gap: 10px; }
.wb-socials a { border: 1px solid rgba(255,255,255,.25); border-radius: 999px; font-size: 13px; font-weight: 800; padding: 8px 13px; }
.wb-map { background: var(--paper); border: 1px solid var(--line); border-radius: 22px; min-height: 550px; overflow: hidden; }
.wb-map iframe { border: 0; height: 100%; min-height: 550px; width: 100%; }
.wb-map > div { align-items: center; color: var(--muted); display: flex; flex-direction: column; height: 100%; justify-content: center; min-height: 550px; text-align: center; }
.wb-map > div span { color: var(--green); font-size: 70px; line-height: 1; }
.wb-map > div strong { color: var(--ink); font-size: 25px; }

.wb-footer { background: #0d211b; color: #fff; padding: 58px 0 32px; }
.wb-footer .wb-container { display: grid; gap: 40px; grid-template-columns: 1fr auto; }
.wb-footer strong { color: #fff; font-size: 26px; }
.wb-footer p { color: #93aea3; margin: 8px 0 0; max-width: 500px; }
.wb-footer-brand > span, .wb-footer-brand > a { color: #b8cbc3; display: block; font-size: 13px; margin-top: 8px; }
.wb-footer-links { display: grid; gap: 22px; justify-items: end; }
.wb-footer nav { display: flex; flex-wrap: wrap; gap: 20px; justify-content: flex-end; }
.wb-footer nav a { color: #c8d8d2; font-size: 13px; font-weight: 700; }
.wb-footer-socials { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.wb-footer-socials a { border: 1px solid rgba(255,255,255,.16); border-radius: 999px; color: #fff; font-size: 12px; font-weight: 800; padding: 7px 11px; }
.wb-footer small { border-top: 1px solid rgba(255,255,255,.12); color: #799087; grid-column: 1 / -1; padding-top: 24px; }

@keyframes wbFade { from { opacity: .35; } to { opacity: 1; } }

@media (max-width: 980px) {
  .wb-service-grid { grid-template-columns: repeat(2, 1fr); }
  .wb-profile { grid-template-columns: 115px 1fr; }
  .wb-profile-photo { height: 155px; }
  .wb-story { gap: 35px; }
}

@media (max-width: 760px) {
  .wb-container { padding-left: 18px; padding-right: 18px; }
  .wb-logo-strip { min-height: 82px; }
  .wb-logo-strip > img { height: 50px; max-width: 40vw; }
  .wb-slider { height: 480px; }
  .wb-slide-content { left: 38px; max-width: calc(100% - 76px); }
  .wb-slide-content h2 { font-size: 42px; }
  .wb-slide-prev, .wb-slide-next { display: none; }
  .wb-menu-toggle { align-items: center; background: #fff; border: 0; color: var(--ink); display: flex; font-weight: 900; justify-content: space-between; padding: 15px 20px; width: 100%; }
  .wb-nav { display: none; flex-direction: column; padding: 0 18px 14px; }
  .wb-nav.is-open { display: flex; }
  .wb-nav a { border-bottom: 1px solid var(--line); padding: 12px 5px; }
  .wb-page-hero { padding: 55px 0; }
  .wb-sections { gap: 60px; padding-bottom: 65px; padding-top: 55px; }
  .wb-team-grid, .wb-service-grid, .wb-story, .wb-purpose, .wb-values, .wb-contact-grid { grid-template-columns: 1fr; }
  .wb-feature-grid, .wb-home-story > .wb-container { grid-template-columns: 1fr; }
  .wb-home-story-image { height: 380px; }
  .wb-home-cta .wb-container, .wb-social-strip .wb-container { align-items: flex-start; flex-direction: column; }
  .wb-profile { grid-template-columns: 95px 1fr; min-height: 0; }
  .wb-profile-photo { height: 130px; }
  .wb-milestones { grid-template-columns: 1fr; }
  .wb-milestones div { border-bottom: 1px solid rgba(255,255,255,.18); border-right: 0; }
  .wb-gallery { grid-auto-rows: 220px; grid-template-columns: 1fr; }
  .wb-gallery figure, .wb-gallery figure:nth-child(5n+1), .wb-gallery figure:nth-child(5n+4) { grid-column: auto; }
  .wb-event-card { align-items: stretch; grid-template-columns: 1fr; padding: 26px; }
  .wb-event-slide, .wb-event-slide.is-active { grid-template-columns: 1fr; }
  .wb-event-slide > img { height: 280px; }
  .wb-event-slide > div { padding: 28px; }
  .wb-story img, .wb-story-placeholder { height: 350px; }
  .wb-contact-card { padding: 30px; }
  .wb-footer .wb-container { grid-template-columns: 1fr; }
  .wb-footer nav { justify-content: flex-start; }
  .wb-footer-links { justify-items: start; }
  .wb-footer-socials { justify-content: flex-start; }
  .wb-footer small { grid-column: auto; }
}

@media (max-width: 480px) {
  .wb-profile { align-items: start; grid-template-columns: 1fr; }
  .wb-profile-photo { height: 260px; }
}
