.custom__edit--info {
  position: fixed;
  width: 40px;
  height: 40px;
  bottom: 1em;
  right: 1em;
  z-index: 3000;
  border-radius: 50%;
  padding: 0;
  text-align: center;
  margin: 1em;
  background: #745B99;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.35);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.35); }
  .custom__edit--info svg {
    line-height: 40px;
    height: 40px;
    width: 40px;
    cursor: pointer; }
  .custom__edit--info div {
    position: absolute;
    display: block;
    white-space: nowrap;
    bottom: 0;
    right: 100%;
    border-radius: 4px;
    padding: 0 2em;
    -webkit-box-shadow: inherit;
    box-shadow: inherit;
    background: inherit;
    opacity: 0;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    visibility: hidden;
    -webkit-transition: opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease;
    transition: opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease;
    -o-transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s;
    transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s;
    transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease; }
  .custom__edit--info p {
    white-space: nowrap;
    line-height: 1.8;
    text-align: left;
    text-transform: none; }
  .custom__edit--info small {
    margin-right: 5px;
    opacity: 0.75;
    text-transform: uppercase;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
  .custom__edit--info:hover div {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-1em);
    -ms-transform: translateX(-1em);
    transform: translateX(-1em);
    -webkit-transition-delay: 0s;
    -o-transition-delay: 0s;
    transition-delay: 0s; }

@-webkit-keyframes marquee {
  0% {
    -webkit-transform: translateX(100vw);
    transform: translateX(100vw); }
  100% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%); } }

@keyframes marquee {
  0% {
    -webkit-transform: translateX(100vw);
    transform: translateX(100vw); }
  100% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%); } }

@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

.custom__edit--info {
  position: fixed;
  width: 40px;
  height: 40px;
  bottom: 1em;
  right: 1em;
  z-index: 3000;
  border-radius: 50%;
  padding: 0;
  text-align: center;
  margin: 1em;
  background: #745B99;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.35);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.35); }
  .custom__edit--info svg {
    line-height: 40px;
    height: 40px;
    width: 40px;
    cursor: pointer; }
  .custom__edit--info div {
    position: absolute;
    display: block;
    white-space: nowrap;
    bottom: 0;
    right: 100%;
    border-radius: 4px;
    padding: 0 2em;
    -webkit-box-shadow: inherit;
    box-shadow: inherit;
    background: inherit;
    opacity: 0;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    visibility: hidden;
    -webkit-transition: opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease;
    transition: opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease;
    -o-transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s;
    transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s;
    transition: transform 0.2s ease, opacity 0.2s ease, visibility 0s ease 0.2s, -webkit-transform 0.2s ease; }
  .custom__edit--info p {
    white-space: nowrap;
    line-height: 1.8;
    text-align: left;
    text-transform: none; }
  .custom__edit--info small {
    margin-right: 5px;
    opacity: 0.75;
    text-transform: uppercase;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
  .custom__edit--info:hover div {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-1em);
    -ms-transform: translateX(-1em);
    transform: translateX(-1em);
    -webkit-transition-delay: 0s;
    -o-transition-delay: 0s;
    transition-delay: 0s; }

@keyframes marquee {
  0% {
    -webkit-transform: translateX(100vw);
    transform: translateX(100vw); }
  100% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%); } }

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

.section__title, #news__title, #events__title, #housepoints__title, #quicklinks__title {
  font-size: clamp(2.25rem, calc(0.75vw + 2vw), 2.375rem);
  font-family: var(--font-heading);
  margin: 0 auto;
  line-height: 1.33333em;
  font-weight: 400;
  width: 90%; }

.controls {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 18px;
  margin-top: 40px;
  visibility: hidden; }
  .controls button {
    visibility: visible;
    position: relative;
    height: 70px;
    width: 70px;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: var(--col-pri);
    color: var(--col-pritxt);
    font-size: 30px;
    -webkit-transition: background 0.4s, -webkit-transform 0.4s;
    transition: background 0.4s, -webkit-transform 0.4s;
    -o-transition: background 0.4s, transform 0.4s;
    transition: background 0.4s, transform 0.4s;
    transition: background 0.4s, transform 0.4s, -webkit-transform 0.4s; }
    .controls button::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 50%;
      border: 4px solid var(--col-pritxt);
      opacity: 0.2; }
    .controls button:not([disabled]):hover {
      background-color: var(--col-sec); }
    .controls button:nth-child(1):not([disabled]):hover {
      -webkit-transform: translateX(-5px);
      -ms-transform: translateX(-5px);
      transform: translateX(-5px); }
    .controls button:nth-child(2):not([disabled]):hover {
      -webkit-transform: translateX(5px);
      -ms-transform: translateX(5px);
      transform: translateX(5px); }

.pager {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin-top: 40px;
  visibility: hidden; }
  .pager button {
    visibility: visible;
    border: none;
    border-radius: 4px;
    width: 46px;
    height: 12px;
    background-color: #15110a;
    opacity: 0.5;
    -webkit-transition: opacity 0.4s;
    -o-transition: opacity 0.4s;
    transition: opacity 0.4s; }
    .pager button:hover, .pager button:focus-visible, .pager button.swiper-pagination-bullet-active {
      opacity: 1; }

@media all and (min-width: 1025px) {
  .inview__target {
    position: absolute;
    left: 0;
    width: 0;
    top: 25%;
    bottom: 25%; }
  .anim__in {
    opacity: 0;
    -webkit-transition: opacity 0.4s linear 0.4s, -webkit-transform 0.4s linear 0.4s;
    transition: opacity 0.4s linear 0.4s, -webkit-transform 0.4s linear 0.4s;
    -o-transition: opacity 0.4s linear 0.4s, transform 0.4s linear 0.4s;
    transition: opacity 0.4s linear 0.4s, transform 0.4s linear 0.4s;
    transition: opacity 0.4s linear 0.4s, transform 0.4s linear 0.4s, -webkit-transform 0.4s linear 0.4s; }
    .inview .anim__in, .anim__in.inview,
    .no-js .anim__in {
      opacity: 1;
      -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
      transform: translate(0, 0); }
    .anim__in--left {
      -webkit-transform: translateX(-50px);
      -ms-transform: translateX(-50px);
      transform: translateX(-50px); }
    .anim__in--right {
      -webkit-transform: translateX(50px);
      -ms-transform: translateX(50px);
      transform: translateX(50px); }
    .anim__in--up {
      -webkit-transform: translateY(20px);
      -ms-transform: translateY(20px);
      transform: translateY(20px); }
    .anim__in--two {
      -webkit-transition-delay: 0.8s;
      -o-transition-delay: 0.8s;
      transition-delay: 0.8s; }
    .anim__in--three {
      -webkit-transition-delay: 1.2s;
      -o-transition-delay: 1.2s;
      transition-delay: 1.2s; }
    .anim__in--four {
      -webkit-transition-delay: 1.6s;
      -o-transition-delay: 1.6s;
      transition-delay: 1.6s; }
    .anim__in--five {
      -webkit-transition-delay: 2s;
      -o-transition-delay: 2s;
      transition-delay: 2s; } }

.alert__banner__wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 99;
  visibility: hidden; }
  .mason--admin .alert__banner__wrapper {
    top: 110px; }
  .mason--preview .alert__banner__wrapper {
    top: 110px; }
  .mason--secure .alert__banner__wrapper {
    top: 40px; }

.alert__banner {
  visibility: visible;
  width: 100%;
  max-width: 810px;
  background-color: #e42021;
  border-radius: 0 0 10px 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 15px;
  padding: 8px clamp(20px, 1vw, 30px);
  color: #fff;
  -webkit-box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.3);
  -webkit-transition: -webkit-transform 0.4s linear, -webkit-box-shadow 0.2s;
  transition: -webkit-transform 0.4s linear, -webkit-box-shadow 0.2s;
  -o-transition: transform 0.4s linear, box-shadow 0.2s;
  transition: transform 0.4s linear, box-shadow 0.2s;
  transition: transform 0.4s linear, box-shadow 0.2s, -webkit-transform 0.4s linear, -webkit-box-shadow 0.2s; }
  .mason--alert__closed .alert__banner {
    -webkit-transform: translateY(-150%);
    -ms-transform: translateY(-150%);
    transform: translateY(-150%);
    -webkit-box-shadow: 0px 0px 30px transparent;
    box-shadow: 0px 0px 30px transparent; }
  .alert__banner .fa-exclamation-circle {
    font-size: 22px;
    -ms-flex-negative: 0;
    flex-shrink: 0; }

.alert__banner__text {
  font-size: 1rem;
  line-height: 1.625em;
  margin: 0; }

.alert__banner__close {
  height: 40px;
  width: 40px;
  position: relative;
  -ms-flex-negative: 0;
  flex-shrink: 0; }
  .alert__banner__close:hover, .alert__banner__close:focus-visible, .alert__banner__close:active {
    outline: none !important; }
    .alert__banner__close:hover div, .alert__banner__close:focus-visible div, .alert__banner__close:active div {
      -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      transform: rotate(90deg); }
    .alert__banner__close:hover span, .alert__banner__close:focus-visible span, .alert__banner__close:active span {
      opacity: 1;
      visibility: visible; }
  .alert__banner__close div {
    height: 100%;
    width: 100%;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 1.75rem;
    background-color: #fff;
    color: #1b1b1b;
    -webkit-transition: -webkit-transform 0.2s linear;
    transition: -webkit-transform 0.2s linear;
    -o-transition: transform 0.2s linear;
    transition: transform 0.2s linear;
    transition: transform 0.2s linear, -webkit-transform 0.2s linear; }
  .alert__banner__close span {
    position: absolute;
    top: 100%;
    margin-top: 5px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    font-size: 0.8125rem;
    font-weight: 500;
    line-height: 1.38462em;
    padding: 5px 10px;
    border-radius: 4px;
    background-color: #fff;
    color: #1b1b1b;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.2s, visibility 0.2s;
    -o-transition: opacity 0.2s, visibility 0.2s;
    transition: opacity 0.2s, visibility 0.2s; }

@media all and (min-width: 500px) {
  .alert__banner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row; } }

.content {
  width: 100%;
  float: none; }

.content__region {
  max-width: none; }

.content__attachments {
  display: none; }

.hero__block {
  min-height: 810px;
  margin-bottom: -130px;
  background: -webkit-gradient(linear, left top, left bottom, from(#75ccf6), to(#6ec32a));
  background: -webkit-linear-gradient(top, #75ccf6, #6ec32a);
  background: -o-linear-gradient(top, #75ccf6, #6ec32a);
  background: linear-gradient(to bottom, #75ccf6, #6ec32a); }
  .hero__block::after {
    content: "";
    position: absolute;
    top: calc(100% - 2px);
    left: 0;
    width: 100%;
    height: 100px;
    background-color: #6ec32a; }

.hero__block--bg {
  background-image: url("/_site/images/design/tile-mobile.svg");
  background-repeat: repeat-X;
  background-position: top center;
  background-size: auto 100%;
  opacity: 0;
  -webkit-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  transition: opacity 0.4s; }
  .hero__block--bg.loaded {
    opacity: 1; }
    .hero__block--bg.loaded .hero__block--bg--main.loaded {
      opacity: 1; }

.hero__block--bg--main {
  width: 100%;
  height: 100%;
  background-image: url("/_site/images/design/tile-mobile-center.svg");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: auto 100%;
  margin: 0 auto;
  opacity: 0;
  -webkit-transition: opacity 0.4s 0.4s;
  -o-transition: opacity 0.4s 0.4s;
  transition: opacity 0.4s 0.4s; }

.hero__wrapper {
  width: 100%;
  max-width: 390px;
  height: 325px;
  margin: 321px auto 0;
  padding: 15px;
  position: relative;
  z-index: 3; }
  .hero__wrapper::before {
    content: "";
    display: block;
    position: absolute;
    top: -55px;
    left: 50%;
    margin-left: -30px;
    width: 60px;
    height: 583px;
    background-image: url("/_site/images/design/post.svg");
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    z-index: 0; }
  .hero__wrapper::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("/_site/images/design/hero-board-mobile.svg");
    background-size: cover;
    z-index: 1;
    display: none; }
  .hero__wrapper .hero__wrapper__board {
    position: absolute;
    inset: 0;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    height: 100%; }

.hero {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 295px; }
  .hero::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 50%;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.8)));
    background: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    z-index: 2;
    opacity: 0;
    -webkit-transition: opacity 0.4s;
    -o-transition: opacity 0.4s;
    transition: opacity 0.4s; }
    .mason--loaded .hero::before {
      opacity: 1; }
  .hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 50%;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.8)));
    background: -webkit-linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    background: -o-linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
    z-index: 2;
    opacity: 0;
    -webkit-transition: opacity 0.4s;
    -o-transition: opacity 0.4s;
    transition: opacity 0.4s; }
    .mason--loaded .hero::after {
      opacity: 1; }

.hero__slideshow {
  -webkit-transform: translate(0, 0) !important;
  -ms-transform: translate(0, 0) !important;
  transform: translate(0, 0) !important; }

@media all and (min-width: 769px) {
  .hero__block {
    min-height: 500px;
    margin-bottom: -41px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end; }
  .hero__block--bg {
    background-image: url("/_site/images/design/tile-desktop.svg"); }
  .hero__block--bg--main {
    background-image: url("/_site/images/design/tile-desktop-center.svg");
    background-position: center; }
  .hero__wrapper {
    margin: 240px 0 60px clamp(30px, 8vw, 110px); }
    .hero__wrapper::before {
      top: -20px;
      height: 760px; } }

@media all and (min-width: 1025px) {
  .hero__block {
    min-height: 880px; }
  .hero__wrapper {
    max-width: 740px;
    width: 50%;
    height: auto;
    aspect-ratio: 740/617;
    padding: 30px; }
  .hero {
    width: 100%;
    height: 100%; } }

@media all and (min-width: 1480px) {
  .hero__wrapper {
    margin-left: calc(50vw - 633px); } }

.homepage {
  z-index: 5; }

.welcome {
  background-color: #1f600d;
  padding: 35px 0 0px;
  margin-top: 41px;
  z-index: 3; }

.welcome__border--top {
  position: absolute;
  bottom: 100%;
  margin-bottom: -1px;
  left: 0;
  width: 100%;
  height: 41px;
  width: 100%;
  background-image: url("/_site/images/design/bush-shape-1.svg");
  background-position: bottom center;
  background-size: 390px auto;
  background-repeat: repeat-x;
  z-index: -2;
  display: none; }

.welcome__border--top--mobile,
.welcome__border--top--desktop {
  position: absolute;
  bottom: 100%;
  margin-bottom: -1px;
  left: 0;
  width: 100%;
  height: 41px;
  z-index: -2; }

.welcome__border--top--desktop {
  display: none; }

.welcome__inner {
  background-color: #e9ffd6;
  border-radius: 50px;
  width: calc(100% - 40px);
  margin: 0 auto;
  padding: 57px 30px;
  max-width: 1220px;
  position: relative; }

.welcome__scroll__container {
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding-bottom: 43px;
  visibility: hidden; }

.welcome__scroll__down {
  width: 130px;
  height: 130px;
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 10px;
  visibility: visible; }
  .welcome__scroll__down .petals {
    position: absolute;
    inset: 0;
    -o-object-fit: contain;
    object-fit: contain;
    -webkit-transition: -webkit-transform 0.4s;
    transition: -webkit-transform 0.4s;
    -o-transition: transform 0.4s;
    transition: transform 0.4s;
    transition: transform 0.4s, -webkit-transform 0.4s; }
  .welcome__scroll__down:hover .petals,
  .welcome__scroll__down:hover .welcome__scroll__down__inner, .welcome__scroll__down:focus-visible .petals,
  .welcome__scroll__down:focus-visible .welcome__scroll__down__inner {
    -webkit-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px); }
  .welcome__scroll__down:hover .welcome__scroll__down__inner, .welcome__scroll__down:focus-visible .welcome__scroll__down__inner {
    color: var(--col-sectxt);
    background-color: var(--col-sec); }

.stem-mobile {
  position: absolute;
  bottom: 0;
  right: 16px;
  visibility: visible; }

.stem-desktop {
  display: none;
  visibility: visible;
  z-index: -1; }

.welcome__illustrations {
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%; }

.welcome__bush--one,
.welcome__bush--two,
.welcome__bush--three {
  display: none; }

.welcome__worm {
  position: absolute;
  left: clamp(45px, 5%, 340px);
  bottom: -21px;
  z-index: 2; }

.welcome__scroll__down__inner {
  height: 54px;
  width: 54px;
  border-radius: 50%;
  border: 5px solid #f8b600;
  background-color: #fff;
  color: #102c57;
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background 0.4s, color 0.4s, -webkit-transform 0.4s;
  transition: background 0.4s, color 0.4s, -webkit-transform 0.4s;
  -o-transition: transform 0.4s, background 0.4s, color 0.4s;
  transition: transform 0.4s, background 0.4s, color 0.4s;
  transition: transform 0.4s, background 0.4s, color 0.4s, -webkit-transform 0.4s; }

.welcome__title {
  font-size: clamp(1.75rem, calc(0.75vw + 2vw), 2.375rem);
  font-family: var(--font-heading);
  color: var(--col-pri);
  margin: 0 0 34px;
  line-height: 1.61111em;
  font-weight: 400; }
  .welcome__title span {
    font-family: var(--font-body);
    font-weight: 600;
    color: #1f600d;
    font-size: 1.25rem;
    line-height: 1.9em; }

.welcome__text {
  margin-bottom: 40px; }
  .welcome__text > * {
    line-height: 1.625em; }
    .welcome__text > *:first-child {
      margin-top: 0; }
    .welcome__text > *:last-child {
      margin-bottom: 0; }

.welcome__inner__right {
  position: relative;
  margin: 60px auto 0;
  width: 100%;
  max-width: 290px; }
  .welcome__inner__right::before {
    content: "";
    display: block;
    padding-bottom: 100%; }

.welcome__image {
  position: absolute !important;
  inset: 0;
  height: 100%;
  width: 100%;
  border-radius: 40px;
  overflow: hidden; }
  .welcome__image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover; }

@media all and (min-width: 769px) {
  .welcome {
    margin-top: 154px; }
  .welcome__border--top {
    height: 154px;
    background-image: url("/_site/images/design/bush-shape-1-desktop.svg");
    background-size: 1480px auto; }
  .welcome__border--top--mobile {
    display: none; }
  .welcome__border--top--desktop {
    display: block;
    height: 154px; }
  .welcome__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: clamp(30px, 5vw, 60px); }
  .welcome__worm {
    left: 340px; }
  .welcome__bush--one {
    display: block;
    position: absolute;
    width: 185px;
    left: 110px;
    bottom: -110px;
    z-index: -1; }
  .welcome__inner__left {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1; }
  .welcome__inner__right {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin: 0;
    width: 40.90909%;
    max-width: 450px; } }

@media all and (min-width: 1025px) {
  .welcome__inner {
    padding: 80px 60px; }
  .welcome__scroll__container {
    padding-bottom: 208px; }
  .stem-mobile {
    display: none; }
  .stem-desktop {
    display: block;
    position: absolute;
    bottom: -46px;
    right: -26px;
    width: 188px; }
  .welcome__bush--two {
    display: block;
    position: absolute;
    width: 155px;
    left: 532px;
    bottom: -28px;
    z-index: -1; } }

@media all and (min-width: 1400px) {
  .welcome__scroll__down {
    margin-right: -49px; }
  .stem-desktop {
    right: -75px; }
  .welcome__bush--three {
    display: block;
    position: absolute;
    width: 115px;
    left: 845px;
    bottom: -51px;
    z-index: -1; } }

.news {
  width: 100%;
  background-color: #1f600d;
  padding-top: 120px; }

.news__inner {
  z-index: 3;
  position: relative; }

.admin__news__type {
  position: absolute;
  top: 0;
  right: 0;
  display: inline-block;
  background-color: #745B99;
  color: #fff;
  padding: 10px 20px;
  z-index: 10; }
  .admin__news__type p {
    margin-top: 0;
    margin-bottom: 0.5em; }
  .admin__news__type select {
    width: 100%; }

.news__border__top__wrapper {
  background-color: #1f600d;
  margin-bottom: -1px;
  width: 100%; }
  .news__border__top__wrapper svg {
    width: 100%;
    max-height: 86px;
    display: block;
    position: relative;
    z-index: 2; }

.news__illustrations {
  position: relative; }
  .news__illustrations img {
    -o-object-fit: contain;
    object-fit: contain; }

.news__bush--one,
.news__bush--two,
.news__bush--three {
  display: none; }

.news__ladybird {
  width: 85px;
  height: 53px;
  position: absolute;
  bottom: 0;
  left: 20px;
  z-index: 3; }

.news__snail {
  width: 110px;
  height: 89px;
  position: absolute;
  right: 20px;
  bottom: -11px;
  z-index: 3; }

.news__inner__wrapper {
  background-color: #9a6b47;
  padding: 60px 0 52px;
  position: relative;
  z-index: 4; }

.news__board__pins {
  display: none; }

#news__title {
  margin-bottom: 80px; }

.news__list__wrapper {
  width: calc(100% - 40px);
  max-width: 1100px;
  margin: 0 auto;
  z-index: 2; }

.news__list {
  overflow: visible; }

.news__item {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.4s, visibility 0.4s;
  -o-transition: opacity 0.4s, visibility 0.4s;
  transition: opacity 0.4s, visibility 0.4s; }
  .news__item.swiper-slide-visible {
    opacity: 1;
    visibility: visible; }
  .news__item.newsletter a, .news__item.facebook a, .news__item.instagram a {
    min-height: 410px; }
  .news__item.facebook a {
    background-color: #e6f1ff; }
    .news__item.facebook a .news__item__date {
      color: #0d69d9; }
  .news__item.instagram a {
    background-color: #ffecf5; }
    .news__item.instagram a .news__item__date {
      color: #c92670; }

.news__item a {
  position: relative;
  background-color: #faf2d8;
  min-height: 480px;
  -webkit-box-shadow: 0px 0px 50px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 0px 50px rgba(0, 0, 0, 0.3);
  padding: 20px; }
  .news__item a:hover .news__item__image img, .news__item a:focus-visible .news__item__image img {
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1); }
  .news__item a:hover .news__item__date, .news__item a:focus-visible .news__item__date {
    -webkit-text-decoration-color: currentColor;
    text-decoration-color: currentColor; }

.news__item__pin {
  position: absolute;
  bottom: 100%;
  left: 50%;
  margin-left: -15px;
  margin-bottom: -11px;
  z-index: -1;
  width: 30px;
  height: 44px;
  -webkit-filter: drop-shadow(0px 2px 4px rgba(0, 0, 0, 0.2));
  filter: drop-shadow(0px 2px 4px rgba(0, 0, 0, 0.2)); }

.news__item__image {
  width: 100%;
  height: 200px;
  margin-bottom: 20px;
  overflow: hidden;
  position: relative; }
  .facebook .news__item__image,
  .instagram .news__item__image {
    border-bottom-right-radius: 24px; }

.news__item__icon {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 2;
  height: 48px;
  width: 48px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-radius: 50%;
  -webkit-box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.15);
  color: #fff;
  font-size: 18px; }
  .facebook .news__item__icon {
    background-color: #1778f2; }
  .instagram .news__item__icon {
    background-color: #dd2a7b; }

.news__item__date {
  color: #9c3626;
  text-transform: uppercase;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  margin: 0 0 2px;
  text-decoration: underline;
  -webkit-text-decoration-color: transparent;
  text-decoration-color: transparent;
  -webkit-transition: -webkit-text-decoration 0.4s;
  transition: -webkit-text-decoration 0.4s;
  -o-transition: text-decoration 0.4s;
  transition: text-decoration 0.4s;
  transition: text-decoration 0.4s, -webkit-text-decoration 0.4s; }

.news__item__title {
  margin: 0 0 14px;
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.7em;
  color: var(--col-pri); }

.news__item__intro {
  line-height: 1.625em;
  overflow: hidden;
  max-height: 6.5em;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical; }
  .news__item__intro > * {
    margin: 0;
    overflow: hidden;
    max-height: 6.5em;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical; }

.news__footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 40px; }

.news__border__bottom__wrapper {
  margin-top: -1px;
  width: 100%; }
  .news__border__bottom__wrapper svg {
    width: 100%;
    max-height: 86px;
    position: relative;
    z-index: 2;
    -webkit-filter: drop-shadow(0px 3px 50px rgba(0, 0, 0, 0.3));
    filter: drop-shadow(0px 3px 50px rgba(0, 0, 0, 0.3));
    display: block; }

@media all and (min-width: 769px) {
  .news {
    padding-top: 200px; }
  .news__ladybird {
    width: 155px;
    height: 95px;
    left: 100px; }
  .news__snail {
    width: 180px;
    height: 146px;
    right: 31px; }
  .news__list__wrapper {
    position: relative;
    width: calc(100% - 100px); }
  .news__controls {
    z-index: 2;
    position: absolute;
    inset: 0 -60px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between; }
  .news__board__pins {
    display: block;
    position: absolute;
    inset: 0px 50px;
    z-index: 0;
    -webkit-filter: drop-shadow(0px 0px 30px rgba(0, 0, 0, 0.3));
    filter: drop-shadow(0px 0px 30px rgba(0, 0, 0, 0.3)); }
  .news__board__pin {
    position: absolute; }
    .news__board__pin:nth-child(1) {
      top: 0;
      left: 0; }
    .news__board__pin:nth-child(2) {
      top: 0;
      right: 0; }
    .news__board__pin:nth-child(3) {
      bottom: 0;
      left: 0;
      -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      transform: rotate(90deg); }
    .news__board__pin:nth-child(4) {
      bottom: 0;
      right: 0;
      -webkit-transform: rotate(75deg);
      -ms-transform: rotate(75deg);
      transform: rotate(75deg); } }

@media all and (min-width: 1025px) {
  .news__ladybird {
    left: 280px; }
  .news__snail {
    right: 11.5vw; }
  .news__bush--one {
    display: block;
    position: absolute;
    bottom: 24px;
    left: 112px; } }

@media all and (min-width: 1301px) {
  .news__inner__wrapper {
    padding-top: 0;
    padding-bottom: 0; }
  .news__controls {
    inset: 0 -110px;
    margin-top: 60px; }
  .news__ladybird {
    bottom: 45px; }
  .news__snail {
    bottom: 43px; }
  .news__bush--two {
    display: block;
    position: absolute;
    bottom: 30px;
    left: 466px; }
  .news__bush--three {
    display: block;
    position: absolute;
    bottom: -25px;
    right: 377px; } }

.events {
  padding: 0 0 60px;
  background-color: #1f600d; }

.events__illustrations--top {
  position: relative;
  z-index: 2;
  background-color: #1f600d;
  height: 222px; }

.events__spider--mobile {
  position: absolute;
  top: -24px;
  left: 50px;
  width: 290px; }

.events__spider--desktop {
  display: none; }

.events__bush--one {
  display: none; }

.events__boy,
.events__girl {
  display: none; }

.events__bg {
  z-index: 0; }

.events__bg__grass {
  background-color: #1f600d;
  position: absolute;
  inset: 505px 0 0; }

.events__bush--two--mobile {
  position: absolute;
  bottom: calc(100% - 370px);
  left: 0;
  width: 100%;
  max-height: 194px; }

.events__bush--two--desktop {
  display: none; }

.events__grass {
  display: none; }

#events__title {
  margin-bottom: clamp(84px, 1vw, 91px);
  position: relative;
  z-index: 2; }

.events__list__wrapper {
  width: calc(100% - 40px);
  margin: 0 auto;
  max-width: 1100px; }

.events__list {
  overflow: visible;
  min-height: 400px; }

.events__item {
  text-align: center;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.4s, visibility 0.4s;
  -o-transition: opacity 0.4s, visibility 0.4s;
  transition: opacity 0.4s, visibility 0.4s; }
  .events__item.swiper-slide-visible {
    opacity: 1;
    visibility: visible; }
  .events__item a:hover .events__item__date span:nth-child(2)::after {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    opacity: 1; }

.events__item__date--wrapper {
  position: relative;
  width: 270px;
  height: 325px;
  margin: 0 auto; }
  .events__item__date--wrapper img {
    position: absolute;
    inset: 0;
    -o-object-fit: contain;
    object-fit: contain; }

.events__item__date {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin: 0;
  inset: 0; }
  .events__item__date span:first-child {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 100%;
    height: 160px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #9c3626;
    font-family: var(--font-heading);
    font-weight: 400;
    line-height: 1.34483em;
    font-size: 3.625rem; }
  .events__item__date span:nth-child(2) {
    width: auto;
    padding-top: 37px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #faf2d8;
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: 1.75rem;
    position: relative; }
    .events__item__date span:nth-child(2)::after {
      content: "";
      position: absolute;
      top: 100%;
      margin-top: 13px;
      left: 0;
      width: 100%;
      height: 6px;
      border-radius: 3px;
      background-color: #694121;
      -webkit-transform: scaleX(0);
      -ms-transform: scaleX(0);
      transform: scaleX(0);
      -webkit-transform-origin: center;
      -ms-transform-origin: center;
      transform-origin: center;
      opacity: 0;
      -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
      transition: opacity 0.4s, -webkit-transform 0.4s;
      -o-transition: opacity 0.4s, transform 0.4s;
      transition: opacity 0.4s, transform 0.4s;
      transition: opacity 0.4s, transform 0.4s, -webkit-transform 0.4s; }

.events__item__info__title {
  font-size: 1.25rem;
  font-weight: 400;
  font-family: var(--font-heading);
  margin: 0 0 22px;
  color: #ffffff; }

.events__item__time {
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin: 0;
  line-height: 1.42857em;
  color: #bbff84;
  opacity: 0.8;
  text-transform: uppercase; }

.events__footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 40px;
  position: relative;
  z-index: 2; }

.events__pager button {
  background-color: #bbff84;
  opacity: 0.5; }
  .events__pager button.swiper-pagination-bullet-active, .events__pager button:hover, .events__pager button:focus-visible {
    opacity: 1; }

@media all and (min-width: 769px) {
  .events__spider--mobile {
    display: none; }
  .events__spider--desktop {
    display: block;
    position: absolute;
    top: -26px;
    left: 72px;
    height: 209px;
    width: 528px; }
  .events__bg__grass {
    inset: 576px 0 0; }
  .events__bush--two--mobile {
    display: none; }
  .events__bush--two--desktop {
    display: block;
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%;
    min-width: 1480px;
    max-height: 200px;
    bottom: calc(100% - 576px); }
  .events__grass {
    display: block;
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    bottom: calc(100% - 576px); }
  .events__list__wrapper {
    position: relative;
    width: calc(100% - 100px); }
  .events__controls {
    z-index: 2;
    position: absolute;
    inset: 0 -60px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding-top: 170px;
    margin: 0; } }

@media all and (min-width: 1150px) {
  .events__boy,
  .events__girl {
    display: block;
    position: absolute; }
  .events__boy {
    top: 65px;
    left: 100px; }
  .events__girl {
    top: 0px;
    right: 28px; }
  #events__title {
    margin-top: 209px; } }

@media all and (min-width: 1200px) {
  .events__spider--desktop {
    left: 3vw; } }

@media all and (min-width: 1301px) {
  .events__bush--one {
    display: block;
    position: absolute;
    right: 150px;
    top: -36px; }
  .events__controls {
    inset: 0 -110px; }
  .events__spider--desktop {
    left: 4vw; } }

@media all and (min-width: 1800px) {
  .events__spider--desktop {
    left: 8vw; } }

.illustrated__row {
  height: 330px;
  background-color: #1f600d;
  z-index: 3; }

.illustrated__row--bush-one {
  display: none; }

.illustrated__row--bush--mobile {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 150px; }

.illustrated__row--bush--desktop {
  display: none; }

.illustrated__row__boy {
  position: absolute;
  bottom: 53px;
  right: 20px;
  width: 259px;
  height: 275px;
  -o-object-fit: contain;
  object-fit: contain; }

.illustrated__row__butterfly {
  position: absolute;
  bottom: 132px;
  left: 21px;
  width: 109px;
  height: 99px; }

@media all and (min-width: 769px) {
  .illustrated__row {
    height: 466px; }
  .illustrated__row__boy {
    bottom: 40px; }
  .illustrated__row--bush--mobile {
    display: none; }
  .illustrated__row--bush--desktop {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 154px; } }

@media all and (min-width: 1301px) {
  .illustrated__row--bush-one {
    display: block;
    position: absolute;
    left: 124px;
    bottom: 54px; }
  .illustrated__row__boy {
    width: 414px;
    height: 441px;
    bottom: 30px;
    right: 130px; }
  .illustrated__row__butterfly {
    width: 213px;
    height: 194px;
    left: 320px; } }

.housepoints {
  background-color: #19510a;
  padding-top: 50px;
  padding-bottom: 120px; }
  .housepoints::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 66%;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(11, 37, 4, 0)), to(#0b2504));
    background: -webkit-linear-gradient(rgba(11, 37, 4, 0) 0%, #0b2504 100%);
    background: -o-linear-gradient(rgba(11, 37, 4, 0) 0%, #0b2504 100%);
    background: linear-gradient(rgba(11, 37, 4, 0) 0%, #0b2504 100%);
    opacity: 0.3;
    z-index: 0; }

.housepoints__bee {
  display: block;
  margin: 10px auto 33px;
  width: 110px;
  height: 120px; }

#housepoints__title {
  margin-bottom: 50px; }

.housepoints__list {
  width: calc(100% - 30px);
  max-width: 1251px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px 0; }

.housepoints__item {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column; }
  .housepoints__item .housepoints__item__points__wrapper img {
    -webkit-transform: translate(-50%, -50%) rotate(-6deg);
    -ms-transform: translate(-50%, -50%) rotate(-6deg);
    transform: translate(-50%, -50%) rotate(-6deg); }

.housepoints__item__points__wrapper {
  position: relative;
  width: 310px;
  height: 310px;
  margin: 0 auto 52px; }
  .housepoints__item__points__wrapper img {
    position: absolute;
    top: 50%;
    left: 50%; }

.housepoints__item__points {
  position: absolute;
  top: 53.5%;
  left: 50.4%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  margin: 0;
  height: 132px;
  width: 132px;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  background-color: var(--hp-color);
  font-family: var(--font-heading);
  font-size: 1.5rem;
  line-height: 1.16667em;
  color: #1b1b1b; }
  .housepoints__item__points::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 6px solid rgba(0, 0, 0, 0.1); }

.housepoints__item__name {
  margin: 0 0 17px;
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 400;
  line-height: 1.32143em;
  position: relative;
  color: #fff;
  display: inline-block; }
  .housepoints__item__name::after {
    content: "";
    position: absolute;
    top: 100%;
    margin-top: 13px;
    left: -16px;
    right: -16px;
    height: 4px;
    border-radius: 2px;
    background-color: var(--hp-color); }

@media all and (min-width: 670px) {
  .housepoints__list {
    margin-bottom: 85px; }
  .housepoints__item {
    width: calc(50% - 20px);
    position: relative; }
    .housepoints__item:nth-child(4n - 2), .housepoints__item:nth-child(4n) {
      top: 85px;
      margin-left: -11px;
      margin-right: -11px; } }

@media all and (min-width: 1025px) {
  .housepoints {
    padding-bottom: 80px; }
  #housepoints__title {
    max-width: calc(100% - 500px); }
  .housepoints__bee {
    position: absolute;
    top: 33px;
    right: 130px;
    z-index: 2; }
  .housepoints__item {
    width: calc(33.333% - 10px); }
    .housepoints__item:nth-child(3n - 2), .housepoints__item:nth-child(3n) {
      top: 0;
      margin: 0; }
    .housepoints__item:nth-child(3n - 1) {
      margin-top: 85px; } }

@media all and (min-width: 1300px) {
  .housepoints__item {
    max-width: 310px; }
    .housepoints__item:nth-child(4n - 3) {
      top: 0; }
      .housepoints__item:nth-child(4n - 3) .housepoints__item__points__wrapper img {
        -webkit-transform: translate(-50%, -50%) rotate(-6deg);
        -ms-transform: translate(-50%, -50%) rotate(-6deg);
        transform: translate(-50%, -50%) rotate(-6deg); }
    .housepoints__item:nth-child(4n - 2) {
      top: 85px; }
      .housepoints__item:nth-child(4n - 2) .housepoints__item__points__wrapper img {
        -webkit-transform: translate(-50%, -50%) rotate(6deg);
        -ms-transform: translate(-50%, -50%) rotate(6deg);
        transform: translate(-50%, -50%) rotate(6deg); }
      .housepoints__item:nth-child(4n - 2) .housepoints__item__points {
        left: 49.6%; }
    .housepoints__item:nth-child(4n - 1) {
      top: 0; }
      .housepoints__item:nth-child(4n - 1) .housepoints__item__points__wrapper img {
        -webkit-transform: translate(-50%, -50%) rotate(-6deg);
        -ms-transform: translate(-50%, -50%) rotate(-6deg);
        transform: translate(-50%, -50%) rotate(-6deg); }
    .housepoints__item:nth-child(4n) {
      top: 85px; }
      .housepoints__item:nth-child(4n) .housepoints__item__points__wrapper img {
        -webkit-transform: translate(-50%, -50%) rotate(6deg);
        -ms-transform: translate(-50%, -50%) rotate(6deg);
        transform: translate(-50%, -50%) rotate(6deg); }
      .housepoints__item:nth-child(4n) .housepoints__item__points {
        left: 49.6%; } }

.illustrated__row__two {
  height: 240px;
  position: relative;
  background-color: #154408; }

.illustrated__row__two__grass__stems--mobile,
.illustrated__row__two__grass__stems--desktop {
  position: absolute;
  bottom: 50px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%); }

.illustrated__row__two__grass__stems--desktop {
  display: none;
  bottom: 0; }

.illustrated__row__two__grass {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100px;
  background-color: #1f600d; }

.illustrated__row__two__hedgehog {
  position: absolute;
  bottom: 35px;
  left: 53px;
  width: 273px;
  height: 193px;
  -o-object-fit: contain;
  object-fit: contain; }

@media all and (min-width: 769px) {
  .illustrated__row__two {
    height: 200px; }
  .illustrated__row__two__grass__stems--mobile {
    display: none; }
  .illustrated__row__two__grass__stems--desktop {
    display: block; }
  .illustrated__row__two__grass {
    height: 50px; }
  .illustrated__row__two__hedgehog {
    bottom: 5px; } }

@media all and (min-width: 1025px) {
  .illustrated__row__two__hedgehog {
    left: 46%; } }

.quicklinks {
  padding-top: 45px;
  padding-bottom: 115px;
  z-index: 6; }
  .quicklinks::before {
    content: "";
    position: absolute;
    background-color: #1f600d;
    inset: 0;
    z-index: 1; }

.quicklinks__inner {
  position: relative;
  z-index: 2; }

#quicklinks__title {
  margin-bottom: 40px; }

.quicklinks__border__bottom {
  position: absolute;
  top: 100%;
  margin-top: -1px;
  left: 0;
  width: 100%;
  max-height: 42px;
  -webkit-filter: drop-shadow(0px 0px 50px rgba(0, 0, 0, 0.3));
  filter: drop-shadow(0px 0px 50px rgba(0, 0, 0, 0.3));
  z-index: 0; }

.quicklinks__list {
  width: calc(100% - 80px);
  margin: 0 auto;
  max-width: 1300px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px 20px; }

.quicklinks__item {
  width: 100%;
  padding: 30px 0 35px; }
  .quicklinks__item:nth-child(1) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(1) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(3) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(3) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(6) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(6) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(8) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(8) a:focus-visible .quicklinks__item__image {
    -webkit-transform: rotate(4deg);
    -ms-transform: rotate(4deg);
    transform: rotate(4deg); }
  .quicklinks__item:nth-child(2) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(2) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(4) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(4) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(5) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(5) a:focus-visible .quicklinks__item__image, .quicklinks__item:nth-child(7) a:hover .quicklinks__item__image, .quicklinks__item:nth-child(7) a:focus-visible .quicklinks__item__image {
    -webkit-transform: rotate(-4deg);
    -ms-transform: rotate(-4deg);
    transform: rotate(-4deg); }
  .quicklinks__item a {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column; }
    .quicklinks__item a:hover .quicklinks__item__title::after, .quicklinks__item a:focus-visible .quicklinks__item__title::after {
      opacity: 1;
      -webkit-transform: scale(1);
      -ms-transform: scale(1);
      transform: scale(1); }

.quicklinks__item__image {
  height: 315px;
  width: 100%;
  margin-bottom: 30px;
  -webkit-filter: drop-shadow(0px 0px 50px rgba(0, 0, 0, 0.2));
  filter: drop-shadow(0px 0px 50px rgba(0, 0, 0, 0.2));
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  -o-transition: transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s; }
  .quicklinks__item__image img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain; }

.quicklinks__item__title {
  display: inline-block;
  position: relative;
  color: #fff;
  font-size: 1.75rem;
  font-weight: 400;
  font-family: var(--font-heading);
  line-height: 1.32143em;
  margin: 0; }
  .quicklinks__item__title::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 8px;
    right: 8px;
    height: 6px;
    border-radius: 3px;
    background-color: #2b8013;
    margin-top: 13px;
    opacity: 0;
    -webkit-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
    transition: opacity 0.4s, -webkit-transform 0.4s;
    -o-transition: opacity 0.4s, transform 0.4s;
    transition: opacity 0.4s, transform 0.4s;
    transition: opacity 0.4s, transform 0.4s, -webkit-transform 0.4s; }

@media all and (min-width: 600px) {
  .quicklinks__item {
    width: calc(50% - 10px); } }

@media all and (min-width: 769px) {
  .quicklinks {
    padding-top: 65px; } }

@media all and (min-width: 1025px) {
  .quicklinks__item {
    width: calc(25% - 15px);
    max-width: 305px; } }

.contact {
  min-height: 100px; }

#map_canvas.map__container {
  height: 450px;
  width: 100%; }
  @media all and (min-width: 768px) and (max-width: 1400px) {
    #map_canvas.map__container {
      background-position: center left 35%; } }

.contact__details {
  text-align: center;
  padding: 87px 15px;
  position: relative;
  background: #fff;
  -webkit-box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2); }
  .contact__details::before {
    content: "";
    position: absolute;
    inset: 15px 0;
    border-top: 6px solid var(--col-pri);
    border-bottom: 6px solid var(--col-pri);
    z-index: 0; }

.contact__title {
  color: var(--col-pri);
  margin-bottom: 26px; }

.contact__details {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column; }

.contact__details__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 12px;
  position: relative;
  z-index: 3;
  max-width: 360px;
  margin: 0 auto; }

.contact__item__text {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.55556em;
  color: #1b1b1b;
  margin: 5px 0 0; }
  .contact__item__text--address::before {
    content: "\f3c5";
    font-weight: 700;
    font-family: fontAwesome;
    font-size: 20px;
    color: var(--col-pri); }
  .contact__item__text--phone::before {
    content: "\f095";
    -webkit-transform: scaleY(-1);
    -ms-transform: scaleY(-1);
    transform: scaleY(-1);
    font-weight: 700;
    font-family: fontAwesome;
    font-size: 20px;
    color: var(--col-pri); }
  .contact__item__text--email::before {
    content: "\f0e0";
    font-weight: 700;
    font-family: fontAwesome;
    font-size: 20px;
    color: var(--col-pri); }
  .contact__item__text--email a {
    text-decoration: underline; }
  .contact__item__text a {
    -webkit-transition: color 0.4s;
    -o-transition: color 0.4s;
    transition: color 0.4s; }
    .contact__item__text a:hover, .contact__item__text a:focus-visible {
      color: var(--col-pri); }

@media all and (min-width: 769px) {
  #map_canvas.map__container {
    height: 726px; }
  .contact__inner {
    position: absolute;
    top: 0;
    left: 50%;
    bottom: 0;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 97%;
    max-width: 1220px;
    visibility: hidden;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start; }
  .contact__details {
    visibility: visible;
    height: 480px;
    width: 480px;
    border-radius: 50%; }
    .contact__details::before {
      border-radius: 50%;
      inset: 15px;
      border: 6px solid var(--col-pri); } }

.footer__awards__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  overflow: visible;
  width: 90%;
  margin: auto;
  padding: 20px 0; }

.footer__awards__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: auto; }
  .footer__awards__item > a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .footer__awards__item img[loading="lazy"].footer__awards__item__image {
    width: unset !important;
    -o-object-fit: unset !important;
    object-fit: unset !important;
    -o-object-position: unset !important;
    object-position: unset !important;
    max-height: 100px;
    max-width: 90vw; }
