@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
*,
*:before,
*:after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 107px;
}

body {
  -webkit-font-smoothing: antialiased;
  isolation: isolate;
  line-height: 1.5;
}
body.stop-scrolling {
  overflow: hidden;
}

ol,
ul,
li {
  list-style: none;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  object-fit: cover;
  object-position: center;
  width: inherit;
  height: inherit;
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
  font-size: inherit;
  letter-spacing: inherit;
  color: inherit;
}

a {
  text-decoration: none;
}

.sr-only {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}

.field__label {
  display: none;
}

body {
  font-family: "Poppins", Helvetica, sans-serif !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Poppins", Helvetica, sans-serif;
  font-weight: inherit;
  line-height: 1.25;
}

p {
  line-height: 1.75;
}

.field--name-field-heading h2 {
  font-size: 2rem;
  font-weight: 400;
}

.field--name-field-eyebrow {
  font-weight: 400;
}
.field--name-field-eyebrow strong {
  font-weight: 700;
}

.field--name-field-headline:has(.inline) h2 {
  display: inline;
}

.field--name-body h3 {
  font-size: 2rem;
  font-weight: 500;
  color: #505050;
  margin-bottom: 1rem;
}
.field--name-body p {
  font-size: 18px;
  font-weight: 400;
}

.bg-white,
.bg-none,
.col-bg-white {
  background-color: #fff;
}

.bg-gray {
  background-color: #F2f2f2;
}

.bg-light_green {
  background-color: rgba(0, 161, 118, 0.04);
}

.block-local-tasks-block {
  position: relative;
  width: 100%;
  background-color: #28282b;
  backdrop-filter: blur(5px);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
  color: white !important;
}
.block-local-tasks-block .tabs--primary {
  padding: 0;
  margin: auto;
}
.block-local-tasks-block .tabs--primary .tabs__link {
  color: white;
  font-family: Arial, Helvetica, sans-serif;
}
.block-local-tasks-block .tabs--primary .tabs__link.is-active {
  background-color: #D2451E;
  color: #fff;
}
.block-local-tasks-block .tabs--primary .tabs__link:hover, .block-local-tasks-block .tabs--primary .tabs__link:focus {
  background-color: rgba(210, 69, 30, 0.5);
}

.messages {
  color: #fff;
  padding: 1rem;
}
.messages .messages__header {
  padding-left: 2rem;
}
.messages .messages__content {
  padding-left: 2rem;
}

.contextual-region button.visually-hidden {
  clip: unset;
}

.form-type-textfield,
.form-type-email,
.form-type-tel {
  position: relative;
  width: 100%;
}
.form-type-textfield label,
.form-type-email label,
.form-type-tel label {
  font-weight: 400;
  margin-bottom: 1rem;
}
.form-type-textfield input,
.form-type-email input,
.form-type-tel input {
  width: 100%;
  font-size: 18px;
  padding: 0.25rem;
  border: 1px solid #D2451E;
}
.form-type-textfield input[placeholder],
.form-type-email input[placeholder],
.form-type-tel input[placeholder] {
  color: #505050 !important;
  font-size: 18px;
  font-weight: 400;
}

.form-type-textarea {
  position: relative;
  width: 100%;
}
.form-type-textarea label {
  font-weight: 400;
  margin-bottom: 1rem;
}
.form-type-textarea textarea {
  width: 100%;
  font-size: 18px;
  padding: 0.25rem;
  border: 1px solid #D2451E;
}
.form-type-textarea textarea[placeholder] {
  color: rgba(0, 0, 0, 0.5);
}

input[type=submit] {
  display: block !important;
  padding: 0.75rem 2rem;
  font-size: 16px;
  border-radius: 5px;
  text-decoration: none;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.59px;
  background-color: #D2451E;
}
input[type=submit]:hover, input[type=submit]:focus, input[type=submit]:active {
  box-shadow: none;
  color: #fff;
  background-color: #C41230;
}

.webform-submission-form {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
  padding: 2rem;
  background-color: #F2f2f2;
  border-radius: 1rem;
}
.webform-submission-form .form-type-textfield label,
.webform-submission-form .form-type-email label,
.webform-submission-form .form-type-tel label {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.webform-submission-form .form-type-textfield input,
.webform-submission-form .form-type-email input,
.webform-submission-form .form-type-tel input {
  width: 100%;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  border: 1px solid #C8C8C8;
  background-color: #fff;
}
.webform-submission-form .form-type-textarea label {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.webform-submission-form .form-type-textarea textarea {
  width: 100%;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  border: 1px solid #C8C8C8;
  background-color: #fff;
}
.webform-submission-form input[type=submit] {
  font-size: 18px;
  font-weight: 700;
  padding: 1.25rem 1.75rem;
  border-radius: 6px;
  background-color: #D2451E;
  color: #fff;
}
.webform-submission-form input[type=submit]:hover, .webform-submission-form input[type=submit]:focus, .webform-submission-form input[type=submit]:active {
  background-color: #C41230;
  color: #fff;
}

.search-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  background-color: #F2f2f2;
  padding: 2rem;
}
.search-form .container-inline {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  place-items: center;
  gap: 1rem;
  padding: 2rem;
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
}
.search-form .container-inline .js-form-type-search {
  width: 100%;
}
.search-form .container-inline .js-form-type-search label {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.search-form .container-inline .js-form-type-search .form-search {
  width: 100%;
  border: 1px solid #C8C8C8;
  background-color: #fff;
  border-radius: 6px;
  font-size: 1.2rem;
  width: 100%;
  color: #505050;
  padding: 0.5rem;
}
.search-form .search-help-link {
  display: none;
}
.search-form .search-advanced {
  display: none;
}
.search-form + h2 {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding-top: 2rem;
  padding-inline: 2rem;
  font-size: 2rem;
  font-weight: 400;
}

.item-list {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  margin-bottom: 2rem;
  padding: 2rem;
}
.item-list ol {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
}
.item-list ol li {
  width: 100%;
  margin: 0;
}
.item-list ol li .search-result__title {
  font-size: 2rem;
  font-weight: 700;
}
.item-list ol li .search-result__title a {
  display: block;
  color: #505050;
  padding: 2rem 1rem;
  border: 1px solid #505050;
  border-radius: 20px;
}
.item-list ol li .search-result__title a:hover, .item-list ol li .search-result__title a:active, .item-list ol li .search-result__title a:focus {
  color: #D2451E;
  border: 1px solid #D2451E;
  box-shadow: 0 0 0 3px #D2451E;
}
.item-list ol li .search-result__snippet-info {
  display: none;
}
.item-list ol li .search-result__snippet-info .search-result__info {
  display: none;
}

.block-system-main-block > .tfa-entry-form {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding: 2rem;
}
.block-system-main-block > .tfa-entry-form .form-item {
  margin-bottom: 1rem;
}
.block-system-main-block > .tfa-entry-form .form-item input[type=text] {
  border-radius: 6px;
  border: 1px solid #C8C8C8;
  padding: 0.5rem;
}
.block-system-main-block > .tfa-entry-form .form-actions {
  gap: 1rem;
}

.menu-icon {
  display: block;
  position: relative;
  width: 1rem;
  height: 1rem;
}

.icon--phone::after {
  content: "";
  position: absolute;
  inset: 0;
  mask: url("../img/icons/telephone-fill.svg") no-repeat center/100%;
  background-color: #D2451E;
}

.icon--arrow-repeat::after {
  content: "";
  position: absolute;
  inset: 0;
  mask: url("../img/icons/arrow-repeat.svg") no-repeat center/100%;
  background-color: #D2451E;
}

.icon--search::after {
  content: "";
  position: absolute;
  inset: 0;
  mask: url("../img/icons/search.svg") no-repeat center/100%;
  background-color: #D2451E;
}

.field--name-field-body h2,
.field--name-body h2,
.provider-details h2 {
  font-size: 2rem;
  font-weight: 400;
  margin-bottom: 1rem;
}
.field--name-field-body p,
.field--name-body p,
.provider-details p {
  color: #505050;
  font-size: clamp(1rem, 0.9648rem + 0.1127vw, 1.1rem);
  margin-bottom: 1rem;
}
.field--name-field-body p strong,
.field--name-body p strong,
.provider-details p strong {
  font-weight: 700;
}
.field--name-field-body ul,
.field--name-body ul,
.provider-details ul {
  padding-left: 0;
  margin-block: 1rem;
  padding-left: 1rem;
}
.field--name-field-body ul li,
.field--name-body ul li,
.provider-details ul li {
  list-style: disc;
  gap: 1rem;
  font-size: 1.1rem;
  color: #505050;
}
.field--name-field-body ul ul,
.field--name-body ul ul,
.provider-details ul ul {
  margin-left: 1rem;
  margin-block: 0;
}
.field--name-field-body ol,
.field--name-body ol,
.provider-details ol {
  padding-left: 0;
  margin-block: 1rem;
  padding-left: 1rem;
}
.field--name-field-body ol li,
.field--name-body ol li,
.provider-details ol li {
  list-style: decimal;
  font-size: 1.1rem;
}
.field--name-field-body ol ol,
.field--name-body ol ol,
.provider-details ol ol {
  margin-left: 1rem;
  margin-block: 0;
}
.field--name-field-body a,
.field--name-body a,
.provider-details a {
  color: #D2451E;
}
.field--name-field-body a:hover, .field--name-field-body a:focus, .field--name-field-body a:active,
.field--name-body a:hover,
.field--name-body a:focus,
.field--name-body a:active,
.provider-details a:hover,
.provider-details a:focus,
.provider-details a:active {
  text-decoration: underline;
}
.field--name-field-body a.button,
.field--name-body a.button,
.provider-details a.button {
  display: block;
  width: fit-content;
  padding: 0.75rem 1.25rem;
  font-size: 18px;
  font-weight: 700;
  border-radius: 6px;
  background-color: #D2451E;
  color: #fff;
}
.field--name-field-body a.button:hover, .field--name-field-body a.button:focus, .field--name-field-body a.button:active,
.field--name-body a.button:hover,
.field--name-body a.button:focus,
.field--name-body a.button:active,
.provider-details a.button:hover,
.provider-details a.button:focus,
.provider-details a.button:active {
  text-decoration: none;
  background-color: #C41230;
}

.media--type-image img,
.field--name-field-media-image-1 img {
  border-radius: 1rem;
}

.grid-style-simple .media--type-image {
  width: 100%;
  height: 100%;
}
.grid-style-simple img {
  border-radius: 0;
}

.field--name-field-background img {
  border-radius: 0;
}

.block-sitewide-alert-block {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows 200ms ease;
}
.block-sitewide-alert-block > * {
  overflow: hidden;
}

.sitewide-alert {
  background-color: #505050;
  padding: 1rem;
  text-align: center;
}
.sitewide-alert .field--name-message {
  margin-inline: auto;
  color: #fff;
}
.sitewide-alert .field--name-message a {
  color: #fff;
  text-decoration: underline;
}

body:has(.region-primary-navigation.show) .block-sitewide-alert-block {
  grid-template-rows: 0fr;
}

body:has(.content-header.sticky) .block-sitewide-alert-block {
  grid-template-rows: 0fr;
}

.hamburger {
  display: none;
  background-color: transparent;
  padding: 5px;
  border: 0;
  width: 50px;
  height: 50px;
}
.hamburger span {
  display: block;
  width: 30px;
  height: 3px;
  border-radius: 10px;
  margin: 5px auto;
  background-color: #D2451E;
  transform-origin: center;
  transition: margin 150ms, rotate 200ms, width 300ms;
}
.hamburger:hover, .hamburger:active {
  cursor: pointer;
}
.hamburger:hover span, .hamburger:active span {
  background-color: #000;
}
.hamburger:hover span:nth-of-type(1), .hamburger:active span:nth-of-type(1) {
  width: 60%;
}
.hamburger:hover span:nth-of-type(2), .hamburger:active span:nth-of-type(2) {
  width: 80%;
}
.hamburger:hover span:nth-of-type(3), .hamburger:active span:nth-of-type(3) {
  width: 100%;
}
.hamburger:focus span {
  background-color: #000;
}
.hamburger.show:hover span:nth-of-type(1) {
  width: 30px;
}
.hamburger.show:hover span:nth-of-type(3) {
  width: 30px;
}
.hamburger.show span {
  margin: -2.5px auto;
  transform-origin: center;
  transition: margin 200ms, rotate 150ms 150ms, width 300ms;
}
.hamburger.show span:nth-of-type(1) {
  rotate: 45deg;
}
.hamburger.show span:nth-of-type(2) {
  opacity: 0;
  height: 0;
}
.hamburger.show span:nth-of-type(3) {
  rotate: -45deg;
}

@media screen and (max-width: 768px) {
  .hamburger {
    z-index: 2;
    display: block;
  }
  footer .hamburger {
    display: none;
  }
}
.top-bar-wrapper {
  border-bottom: 1px solid #C8C8C8;
  background-color: #fff;
}

.region-top-bar {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  z-index: 2;
  grid-column: span 2;
  grid-row: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  pointer-events: all;
  padding-inline: min(2rem, 2vw);
  z-index: 1;
}
.region-top-bar .menu {
  display: flex;
}
.region-top-bar .menu li {
  list-style: none;
}
.region-top-bar .menu--top-bar-links .menu {
  gap: 2rem;
}
.region-top-bar .menu--top-bar-links .menu li {
  padding-top: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
}
.region-top-bar .menu--top-bar-links .menu li a {
  color: #505050;
  font-weight: 400;
  font-size: 18px;
  border-bottom: 2px solid transparent;
}
.region-top-bar .menu--top-bar-links .menu li a:hover, .region-top-bar .menu--top-bar-links .menu li a:focus, .region-top-bar .menu--top-bar-links .menu li a:active {
  border-bottom: 2px solid #D2451E;
}
.region-top-bar .menu--top-bar-buttons .menu li {
  padding-top: 0;
}
.region-top-bar .menu--top-bar-buttons .menu li a {
  display: block;
  color: #505050;
  font-weight: 700;
  font-size: 18px;
  padding: 0.75rem 1.75rem;
}
.region-top-bar .menu--top-bar-buttons .menu li a:hover, .region-top-bar .menu--top-bar-buttons .menu li a:focus, .region-top-bar .menu--top-bar-buttons .menu li a:active {
  background-color: #C41230;
  color: #fff;
}
.region-top-bar .menu--top-bar-buttons .menu li a[button_style="1"] {
  background-color: #D2451E;
  color: #fff;
}
.region-top-bar .menu--top-bar-buttons .menu li a[button_style="1"]:hover, .region-top-bar .menu--top-bar-buttons .menu li a[button_style="1"]:focus, .region-top-bar .menu--top-bar-buttons .menu li a[button_style="1"]:active {
  background-color: #C41230;
}

@media screen and (max-width: 768px) {
  .content-header:has(.region-primary-navigation.show) .top-bar-wrapper {
    grid-template-rows: 0fr;
  }
  body:has(.content-header.sticky) .top-bar-wrapper {
    grid-template-rows: 0fr;
  }
  .top-bar-wrapper {
    display: grid;
    grid-template-rows: 1fr;
    transition: grid-template-rows 200ms ease;
  }
  .region-top-bar {
    flex-direction: column-reverse;
    overflow: hidden;
    padding-inline: 0;
  }
  .region-top-bar .menu--top-bar-buttons {
    width: 100%;
  }
  .region-top-bar .menu--top-bar-buttons .menu {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    margin-left: 0;
  }
  .region-top-bar .menu--top-bar-buttons .menu .menu-item a {
    font-size: calc(1rem - 0.5vw);
    text-align: center;
  }
  .region-top-bar .menu--top-bar-buttons .menu .menu-item:has(a[button_style="1"]) {
    grid-row: 1;
    grid-column: span 3;
  }
  .region-top-bar .menu--top-bar-links {
    width: 100%;
    border-top: 1px solid #F2f2f2;
  }
  .region-top-bar .menu--top-bar-links .menu {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    justify-content: center;
    margin-left: 0;
    padding: 0.5rem;
    gap: calc(1rem - 2vw);
  }
  .region-top-bar .menu--top-bar-links .menu .menu-item {
    justify-content: center;
  }
  .region-top-bar .menu--top-bar-links .menu .menu-item a {
    font-size: calc(1rem - 0.5vw);
    text-align: center;
  }
}
.region-site-branding {
  position: relative;
  height: 100%;
  z-index: 1;
}

.block-system-branding-block {
  position: relative;
  display: block;
  width: min(20vw, 300px);
  height: 100%;
  padding-block: 1rem;
}
.block-system-branding-block .site-logo {
  display: block;
  position: relative;
  max-width: 300px;
  aspect-ratio: 9/2;
  width: 100%;
  height: 100%;
}
.block-system-branding-block .site-logo::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background: url("../img/logo.png") no-repeat left center/contain;
}
.block-system-branding-block .site-name {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}

@media screen and (max-width: 768px) {
  .block-system-branding-block {
    width: 100%;
  }
}
.content-header {
  --admin-offset-top: 0;
  position: absolute;
  overflow: visible;
  top: var(--admin-offset-top);
  left: 0;
  z-index: 10;
  width: 100%;
  height: fit-content;
  border-bottom: 1px solid #F2f2f2;
}
.content-header.sticky {
  position: fixed;
}

.navigation-wrapper {
  background-color: #fff;
}

.main-navigation {
  --main-nav-height: max(124px, 3rem);
  display: grid;
  grid-template-columns: max-content auto;
  grid-template-rows: var(--main-nav-height);
  padding-inline: min(2rem, 2vw);
  align-items: center;
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  isolation: isolate;
  transition: grid-template-rows 100ms ease;
}
.main-navigation .region-primary-navigation .menu--main > .menu {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: clamp(0.2rem, 0.2rem + 0.5vw, 2rem);
}
.main-navigation .region-primary-navigation .menu--main > .menu > .menu-item {
  position: relative;
  list-style: none;
}
.main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a {
  display: block;
  color: #505050;
  font-size: clamp(0.8rem, 0.7283rem + 0.4348vw, 1.25rem);
  font-weight: 400;
  padding: 3rem clamp(0.2rem, 0.2rem + 0.5vw, 1.25rem);
  overflow: hidden;
}
.main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: #D2451E;
  transition: height 0.2s ease;
}
.main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a:hover::before, .main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a:active::before, .main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a:focus::before {
  height: 5px;
}
.main-navigation .region-primary-navigation .menu--main > .menu > .menu-item > a.is-active {
  color: #D2451E;
  font-weight: 600;
}
.main-navigation .region-primary-navigation .menu--main .menu-item {
  padding-top: 0;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded {
  position: relative;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] {
  display: grid;
  grid-template-columns: auto 1rem;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown]::after {
  content: "";
  display: block;
  width: 1rem;
  height: 1rem;
  margin-left: auto;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #505050;
  transform: rotate(90deg);
  transition: transform 100ms ease;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown]:has(+ .menu-wrapper.show)::after {
  transform: rotate(0deg);
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] + .menu-wrapper {
  display: grid;
  grid-template-rows: 0fr;
  position: absolute;
  left: 0;
  width: min(400px, 20vw);
  margin-left: 0;
  background-color: #fff;
  transition: grid-template-rows 200ms ease;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] + .menu-wrapper .menu {
  display: grid;
  grid-template-columns: 1fr;
  margin-left: 0;
  overflow: hidden;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] + .menu-wrapper .menu .menu-item {
  margin-left: 0;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] + .menu-wrapper .menu .menu-item a {
  display: flex;
  padding: 1rem;
  color: #505050;
  font-size: 20px;
  font-weight: 400;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [dropdown] + .menu-wrapper.show {
  grid-template-rows: 1fr;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [data-menu-level="0"] + .menu-wrapper {
  --top-level-menu-height: auto;
  top: 100%;
  max-height: var(--top-level-menu-height);
  overflow-y: hidden;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [data-menu-level="0"] + .menu-wrapper > .menu {
  overflow-y: auto;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [data-menu-level="1"] + .menu-wrapper {
  position: relative;
  top: 0;
  background-color: #F2f2f2;
}
.main-navigation .region-primary-navigation .menu--main li.menu-item--expanded [data-menu-level="1"] + .menu-wrapper .menu-item a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

body:has(.region-primary-navigation.show) {
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .main-navigation {
    justify-content: space-between;
  }
  .main-navigation .region-primary-navigation {
    position: absolute;
    right: 0;
    top: 100%;
    height: calc(100dvh - var(--main-nav-height));
    overflow-y: auto;
    width: 100vw;
    background-color: #fff;
    transform: translateX(100%);
    z-index: 0;
    transition: transform 200ms ease;
  }
  .main-navigation .region-primary-navigation.show {
    transform: translateX(0);
  }
  .main-navigation .region-primary-navigation .menu--main > .menu {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1rem;
    margin-left: 0;
  }
  .main-navigation .region-primary-navigation .menu--main > .menu .menu-item {
    display: block;
    width: 100%;
    height: fit-content;
  }
  .main-navigation .region-primary-navigation .menu--main > .menu .menu-item a {
    font-size: 20px;
    padding: 1rem;
  }
  .main-navigation .region-primary-navigation .menu--main > .menu .menu-item--expanded [dropdown] + .menu-wrapper {
    position: relative;
    width: 100%;
  }
  .main-navigation .region-primary-navigation .menu--main > .menu .menu-item--expanded [data-menu-level="0"] + .menu-wrapper {
    max-height: fit-content;
    top: 0;
    box-shadow: none;
    background-color: #F2f2f2;
  }
}
.path-frontpage .region-page-title {
  display: none;
}
.path-frontpage .block-page-title-block {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}

.region-page-title {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  background-color: #D2451E;
  height: auto;
  padding-block: 4rem;
  isolation: isolate;
}
.region-page-title::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/mark-red.png") no-repeat center/auto 100%;
}
.region-page-title .block-system-breadcrumb-block {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-inline: 2rem;
  z-index: 1;
}
.region-page-title .block-system-breadcrumb-block .breadcrumb__list {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
}
.region-page-title .block-system-breadcrumb-block .breadcrumb__item .breadcrumb__link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
  color: #fff;
  font-size: 20px;
  font-weight: 400;
}
.region-page-title .block-system-breadcrumb-block .breadcrumb__item .breadcrumb__link::after {
  content: "" !important;
  display: block;
  width: 1rem;
  height: 1rem;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #fff;
}
.region-page-title .block-page-title-block {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  z-index: 1;
}
.region-page-title .block-page-title-block .page-title {
  font-size: 2.6rem;
  padding-inline: 2rem;
  color: #fff;
  font-weight: 700;
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .region-page-title .block-page-title-block .page-title {
    overflow: hidden;
    font-size: clamp(3rem, 3rem - 1vw, 4rem);
    word-wrap: break-word;
  }
}
.paragraph--type--hero-slide {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  height: 100%;
}
.paragraph--type--hero-slide .field--name-field-background {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.paragraph--type--hero-slide .field--name-field-background * {
  width: 100%;
  height: 100%;
}
.paragraph--type--hero-slide .field--name-field-background::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, white, transparent) no-repeat center/cover;
}
.paragraph--type--hero-slide .hero-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  position: relative;
  max-width: 1400px;
  width: 100%;
  height: fit-content;
  margin-inline: auto;
  padding-inline: 2rem;
  padding-block: 3rem;
}
.paragraph--type--hero-slide .hero-content > * {
  width: min(560px, 100%);
}
.paragraph--type--hero-slide .hero-content .field--name-field-eyebrow {
  color: #D2451E;
  font-size: clamp(1.3rem, 1.0535rem + 0.7887vw, 2rem);
  font-weight: 500;
  margin-bottom: 1rem;
}
.paragraph--type--hero-slide .hero-content .field--name-field-heading h2 {
  color: #505050;
  font-size: clamp(2.5rem, 1.9718rem + 1.6901vw, 4rem);
  font-weight: 700;
  margin-bottom: 1.5rem;
}
.paragraph--type--hero-slide .hero-content .field--name-field-body {
  font-size: clamp(1rem, 0.9648rem + 0.1127vw, 1.1rem);
  font-weight: 400;
  margin-bottom: 2rem;
}
.paragraph--type--hero-slide .hero-content .field--name-field-cta a {
  display: block;
  width: fit-content;
  padding: 0.75rem 1.25rem;
  font-size: 18px;
  font-weight: 700;
  border-radius: 6px;
  background-color: #D2451E;
  color: #fff;
}
.paragraph--type--hero-slide .hero-content .field--name-field-cta a:hover, .paragraph--type--hero-slide .hero-content .field--name-field-cta a:focus, .paragraph--type--hero-slide .hero-content .field--name-field-cta a:active {
  background-color: #C41230;
}

.hero {
  height: calc(100vh - var(--header-offset));
}
.hero .paragraph--type--hero,
.hero .slick,
.hero .slick-slider,
.hero .slick-list,
.hero .slick-track,
.hero .slick-slide {
  height: 100%;
}
.hero .slick-track {
  display: grid;
  grid-template-rows: 1fr;
}
.hero .slick-track .slick__slide {
  grid-row: 1;
}
.hero .slick-dots {
  display: flex;
  gap: 1rem;
  max-width: 1400px;
  width: 100%;
  padding: 2rem;
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  margin-inline: auto;
}
.hero .slick-dots button {
  color: transparent;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 3rem;
  background-color: rgba(210, 69, 30, 0.5);
}
.hero .slick-dots button:hover, .hero .slick-dots button:active, .hero .slick-dots button:focus {
  cursor: pointer;
  background-color: #D2451E;
}
.hero .slick-dots .slick-active button {
  background-color: #D2451E;
}

@media screen and (max-width: 768px) {
  .paragraph--type--hero-slide .hero-content {
    padding-bottom: 4rem;
  }
  .paragraph--type--hero-slide .field--name-field-background img {
    opacity: 0.7;
  }
  .paragraph--type--hero-slide .field--name-field-background::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, white, transparent) no-repeat center/cover;
  }
  .hero {
    height: auto;
  }
  .hero .slick-dots {
    bottom: 0;
    padding-block: 1rem;
  }
}
.card {
  box-shadow: none;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}

.main-services .view-content {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  row-gap: 2rem;
}
.main-services .view-content .service-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
.main-services .view-content .service-card:has(.media-image) {
  justify-content: flex-start;
}
.main-services .view-content .service-card .media--image {
  margin-inline: auto;
  border-radius: 1rem;
  overflow: hidden;
  transform: scale(1);
  transition: transform 100ms ease;
}
.main-services .view-content .service-card h3 {
  width: 100%;
  font-size: 2rem;
  font-weight: 700;
  margin-block: 2rem;
  color: #505050;
}
.main-services .view-content .service-card p {
  font-size: 18px;
  color: #505050;
  margin-bottom: 2rem;
}
.main-services .view-content .service-card a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1rem;
  margin-inline: auto;
  color: #D2451E;
}
.main-services .view-content .service-card a::after {
  content: "";
  width: 1rem;
  height: 1rem;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #D2451E;
}
.main-services .view-content .service-card a:hover, .main-services .view-content .service-card a:focus, .main-services .view-content .service-card a:active {
  color: #505050;
}
.main-services .view-content .service-card a:hover::after, .main-services .view-content .service-card a:focus::after, .main-services .view-content .service-card a:active::after {
  background-color: #505050;
}

.full-services .view-content {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 350px;
  gap: 1rem;
}
.full-services .view-content .service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  overflow: hidden;
  padding: 2rem;
  border-radius: 20px;
  border: 1px solid #C8C8C8;
  transition: box-shadow 200ms ease;
}
.full-services .view-content .service-card:has(.media--image) {
  justify-content: flex-start;
}
.full-services .view-content .service-card .media--image {
  margin-inline: auto;
  border-radius: 1rem;
  overflow: hidden;
  transition: transform 100ms ease;
}
.full-services .view-content .service-card h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-block: 1rem;
  color: #505050;
}
.full-services .view-content .service-card a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-inline: auto;
  color: #D2451E;
}
.full-services .view-content .service-card a::after {
  content: "";
  width: 1rem;
  height: 1rem;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #D2451E;
}
.full-services .view-content .service-card a:hover, .full-services .view-content .service-card a:focus, .full-services .view-content .service-card a:active {
  color: #505050;
}
.full-services .view-content .service-card a:hover::after, .full-services .view-content .service-card a:focus::after, .full-services .view-content .service-card a:active::after {
  background-color: #505050;
}
.full-services .view-content .service-card .card-link {
  position: absolute;
  inset: 0;
  display: block;
}
.full-services .view-content .service-card .card-link a {
  display: block;
  position: absolute;
  inset: 0;
  color: transparent;
}
.full-services .view-content .service-card:has(.card-link:hover) {
  box-shadow: 0 0 0 5px #D2451E;
}
.full-services .view-content .service-card:has(.card-link:hover) .media--image {
  transform: scale(1.2);
}

.view-news {
  --grid-max-col-count: 3;
  --grid-min-col-size: 200px;
  --grid-max-col-size: 250px;
  --grid-gap: 1rem;
  --grid-col-size-calc: calc((100% - var(--grid-gap) * var(--grid-max-col-count)) / var(--grid-max-col-count));
  --grid-col-min-size-calc: min(max(var(--grid-min-col-size), var(--grid-col-size-calc)),
      100%);
}
.view-news .view-content {
  display: grid !important;
  gap: var(--grid-gap);
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-col-min-size-calc), var(--grid-max-col-size)));
  justify-content: center;
  row-gap: 3rem;
  padding-inline: 2rem;
}
.view-news .view-content .news-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
}
.view-news .view-content .news-card .media--type-image {
  width: 100%;
  margin-inline: auto;
  overflow: hidden;
  transition: transform 100ms ease;
}
.view-news .view-content .news-card .media--type-image img {
  aspect-ratio: 4/3;
  border-radius: 1rem;
}
.view-news .view-content .news-card h3 {
  font-size: 24px;
  font-weight: 400;
  margin-block: 2rem;
  color: #505050;
}
.view-news .view-content .news-card .news-date {
  width: 100%;
  margin-bottom: 1rem;
  text-align: left;
  font-weight: 700;
}
.view-news .view-content .news-card p {
  font-size: 18px;
  color: #505050;
  margin-bottom: 2rem;
}
.view-news .view-content .news-card a {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  margin-top: 1rem;
  color: #D2451E;
}
.view-news .view-content .news-card a::after {
  content: "";
  width: 1rem;
  height: 1rem;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #D2451E;
}
.view-news .view-content .news-card a:hover, .view-news .view-content .news-card a:focus, .view-news .view-content .news-card a:active {
  color: #505050;
}
.view-news .view-content .news-card a:hover::after, .view-news .view-content .news-card a:focus::after, .view-news .view-content .news-card a:active::after {
  background-color: #505050;
}
.view-news.full-news .view-filters {
  background-color: #F2f2f2;
}
.view-news.full-news .view-filters form {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  padding-inline: 2rem;
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
}
.view-news.full-news .view-filters form .form-type--textfield {
  max-width: 700px;
  width: 100%;
}
.view-news.full-news .view-filters form .form-type--textfield label {
  display: none;
}
.view-news.full-news .view-filters form .form-type--textfield input {
  width: 100%;
  background-color: #fff;
  border: 1px solid #C8C8C8;
  padding: 0.5rem;
}
.view-news.full-news .view-filters form .form-type--textfield input[placeholder] {
  color: #505050 !important;
  font-size: 18px;
  font-weight: 400;
}
.view-news.full-news .view-content {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding-block: 3rem;
}

.paragraph--type--modal-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.paragraph--type--modal-cards .paragraph--type--modal-card {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: [icon] 100px [title] auto-fit [link] 4rem;
  place-items: center;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border: 1px solid #C8C8C8;
  border-radius: 20px;
  padding: 2rem;
  height: 350px;
  transition: 200ms ease;
}
.paragraph--type--modal-cards .paragraph--type--modal-card .field--name-field-icon {
  width: 100px;
  height: 100px;
}
.paragraph--type--modal-cards .paragraph--type--modal-card .field--name-field-title h3 {
  font-size: 1.6rem;
  font-weight: 700;
  color: #505050;
}
.paragraph--type--modal-cards .paragraph--type--modal-card a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  color: #D2451E;
}
.paragraph--type--modal-cards .paragraph--type--modal-card a::after {
  content: "";
  display: block;
  width: 1rem;
  height: 1rem;
  background-color: #D2451E;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
}
.paragraph--type--modal-cards .paragraph--type--modal-card:hover, .paragraph--type--modal-cards .paragraph--type--modal-card:focus, .paragraph--type--modal-cards .paragraph--type--modal-card:active {
  cursor: pointer;
  outline: 5px solid #D2451E;
}

.cards .field--name-field-card-list {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.cards .field--name-field-card-list > .field__item {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  text-align: center;
  padding: 2rem;
  border-radius: 20px;
  border: 1px solid #C8C8C8;
  background-color: #fff;
}
.cards .field--name-field-card-list > .field__item .field--name-field-media-single {
  width: 100%;
}
.cards .field--name-field-card-list > .field__item .field--name-field-media-single .image-style-service-category-image {
  aspect-ratio: 4/3;
  width: min(100px, 100%);
  height: 100px;
  margin-inline: auto;
  object-fit: contain;
}
.cards .field--name-field-card-list > .field__item .field--name-field-title {
  position: relative;
  width: 100%;
  font-size: 2rem;
  font-weight: 500;
  padding-block: 1rem;
  margin-block: 1rem;
  color: #505050;
}
.cards .field--name-field-card-list > .field__item .field--name-field-title::after {
  content: "";
  display: block;
  position: absolute;
  max-width: 102px;
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background-color: #D2451E;
}
.cards .field--name-field-card-list > .field__item p {
  font-size: 18px;
  color: #505050;
  margin-bottom: 0.5rem;
}
.cards .field--name-field-card-list > .field__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-inline: auto;
  color: #D2451E;
}
.cards .field--name-field-card-list > .field__item a::after {
  content: "";
  width: 1rem;
  height: 1rem;
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
  background-color: #D2451E;
}
.cards .field--name-field-card-list > .field__item a:hover, .cards .field--name-field-card-list > .field__item a:focus, .cards .field--name-field-card-list > .field__item a:active {
  color: #505050;
}
.cards .field--name-field-card-list > .field__item a:hover::after, .cards .field--name-field-card-list > .field__item a:focus::after, .cards .field--name-field-card-list > .field__item a:active::after {
  background-color: #505050;
}

@media screen and (max-width: 768px) {
  .main-services {
    margin-block: 2rem;
  }
  .main-services .view-content {
    grid-template-columns: 1fr;
  }
  .view-news .view-content {
    grid-template-columns: 1fr;
  }
  .view-news .view-content .news-card {
    text-align: center;
  }
  .view-news .view-content .news-card h3 {
    margin-block: 1rem;
  }
  .view-news .view-content .news-card .news-date {
    text-align: center;
  }
  .paragraph--type--modal-cards {
    grid-template-columns: 1fr;
  }
  .cards .field--name-field-card-list {
    grid-template-columns: 1fr;
  }
}
.slick--view--locations {
  position: relative;
}
.slick--view--locations .slick__arrow {
  position: absolute;
  inset: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  pointer-events: none;
}
.slick--view--locations .slick__arrow .slick-arrow {
  position: relative;
  width: 2rem;
  height: 2rem;
  pointer-events: all;
  border-radius: 10rem;
  background-color: transparent;
  color: transparent;
}
.slick--view--locations .slick__arrow .slick-arrow::before {
  content: "";
  position: absolute;
  inset: 10%;
  background-color: #D2451E;
}
.slick--view--locations .slick__arrow .slick-arrow:hover, .slick--view--locations .slick__arrow .slick-arrow:focus, .slick--view--locations .slick__arrow .slick-arrow:active {
  cursor: pointer;
  outline: 2px solid #D2451E;
}
.slick--view--locations .slick__arrow .slick-arrow.slick-prev::before {
  mask: url("../img/icons/chevron-left.svg") no-repeat center/100%;
}
.slick--view--locations .slick__arrow .slick-arrow.slick-next::before {
  mask: url("../img/icons/chevron-right.svg") no-repeat center/100%;
}
.slick--view--locations .slick-slider {
  margin-inline: auto;
  width: calc(100% - 5rem);
}
.slick--view--locations .slick-track {
  isolation: isolate;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 500px;
}
.slick--view--locations .slick__slide {
  float: none;
  transition: scale 100ms linear;
}
.slick--view--locations .slick__slide .slide__media {
  display: none;
}
.slick--view--locations .slick__slide .slide__caption {
  padding: 0;
}
.slick--view--locations .slick__slide .slide__description {
  position: relative;
  isolation: isolate;
}
.slick--view--locations .slick__slide .slide__description .location-heading {
  position: absolute;
  inset: 0;
  text-align: center;
  align-content: center;
  background: rgba(210, 69, 30, 0.7);
  color: #fff;
  z-index: 1;
  opacity: 0;
  transition: opacity 200ms linear;
}
.slick--view--locations .slick__slide .slide__description .location-heading .location-name {
  font-size: 1.8rem;
}
.slick--view--locations .slick__slide .slide__description .location-heading .location-subhead {
  font-size: 0.8rem;
  font-weight: 300;
}
.slick--view--locations .slick__slide.slick-current {
  scale: 1.5;
  z-index: 1;
}
.slick--view--locations .slick__slide.slick-current:hover .slide__description .location-heading, .slick--view--locations .slick__slide.slick-current:focus .slide__description .location-heading, .slick--view--locations .slick__slide.slick-current:active .slide__description .location-heading {
  opacity: 1;
}
@media screen and (max-width: 768px) {
  .slick--view--locations .slick-track {
    min-height: 300px;
    align-items: flex-start;
  }
  .slick--view--locations .slick__slide {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    height: 100%;
  }
  .slick--view--locations .slick__slide .slide__description .location-heading {
    position: relative;
    display: block;
    opacity: 1;
    background-color: transparent;
    color: #D2451E;
  }
  .slick--view--locations .slick__slide.slick-current {
    scale: 1;
  }
}

.pager {
  padding: 1rem;
  margin-bottom: 2rem;
}
.pager .pager__item--current {
  color: #D2451E;
  background-color: rgba(210, 69, 30, 0.1);
  border-radius: 1rem;
}

.side-card {
  border-radius: 20px;
  height: fit-content;
  overflow: hidden;
  margin-bottom: 2rem;
}
.side-card .field--name-field-side-card-heading {
  padding: 1rem;
  color: #fff;
  background-color: #D2451E;
  font-size: 24px;
  font-weight: 400;
  text-align: center;
}
.side-card .field--name-field-side-card-body {
  background-color: #F2f2f2;
  padding: 1rem;
}
.side-card .field--name-field-side-card-body p {
  margin-bottom: 1rem;
}
.side-card .field--name-field-side-card-body a {
  color: #D2451E;
}
.side-card .field--name-field-side-card-body a:hover, .side-card .field--name-field-side-card-body a:focus, .side-card .field--name-field-side-card-body a:active {
  text-decoration: underline;
}
.side-card .field--name-field-side-card-body a.button {
  display: block;
  width: fit-content;
  padding: 0.75rem 1.25rem;
  font-size: 18px;
  font-weight: 700;
  border-radius: 6px;
  margin-inline: auto;
  background-color: #D2451E;
  color: #fff;
}
.side-card .field--name-field-side-card-body a.button:hover, .side-card .field--name-field-side-card-body a.button:focus, .side-card .field--name-field-side-card-body a.button:active {
  text-decoration: none;
  background-color: #C41230;
}

.page-node-type-news .region-content {
  display: grid;
  grid-template-columns: 73% 28%;
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  gap: 1rem;
  padding-right: 2rem;
}
.page-node-type-news .region-content .node--type-news > .node__content {
  grid-template-columns: 100% !important;
}
.page-node-type-news .region-content .view-news.side-card {
  margin: 2rem;
  margin-block: 3rem;
  border-radius: 20px;
  height: fit-content;
  overflow: hidden;
}
.page-node-type-news .region-content .view-news.side-card .view-header {
  padding: 1rem;
  color: #fff;
  background-color: #D2451E;
  font-size: 24px;
  font-weight: 400;
  text-align: center;
}
.page-node-type-news .region-content .view-news.side-card .view-content {
  grid-template-columns: 1fr;
  background-color: #F2f2f2;
}
.page-node-type-news .region-content .view-news.side-card .view-content .news-card {
  padding: 1rem;
  align-items: flex-start;
  text-align: left;
}
.page-node-type-news .region-content .view-news.side-card .view-content .news-card h3 {
  margin-top: 0;
  margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
  .page-node-type-news .region-content {
    grid-template-columns: 1fr;
  }
}
.provider-list .item-list {
  position: relative;
  max-width: unset;
  margin-inline: 0;
  margin-block: 0;
  padding-block: 2rem;
}
.provider-list .item-list > h3 {
  grid-column: span 4;
  max-width: 1400px;
  width: 100%;
  text-align: center;
  margin-inline: auto;
  font-size: 2rem;
  font-weight: 500;
  padding: 2rem 3rem;
  color: #505050;
}
.provider-list .item-list > ul {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  margin-block: 0;
  padding-inline: 2rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.provider-list .item-list > ul li.provider-card {
  position: relative;
  list-style: none;
  border-bottom: none;
  text-align: left;
  border-radius: 20px;
  padding: 0.5rem !important;
  width: 100%;
  margin: 0;
  height: fit-content;
  transition: outline 100ms linear;
}
.provider-list .item-list > ul li.provider-card img {
  width: 100%;
  height: 330px;
  border-radius: 1rem;
}
.provider-list .item-list > ul li.provider-card h3 {
  padding: 1rem;
  padding-bottom: 0.5rem;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
  color: #505050;
}
.provider-list .item-list > ul li.provider-card p {
  font-size: 18px;
  font-weight: 400;
  color: #505050;
  padding: 0.5rem 1rem;
  line-height: 1.25;
  text-align: left;
}
.provider-list .item-list > ul li.provider-card .card-link {
  position: absolute;
  inset: 0;
  color: transparent;
}
.provider-list .item-list > ul li.provider-card:hover, .provider-list .item-list > ul li.provider-card:focus, .provider-list .item-list > ul li.provider-card:active {
  outline: 5px solid #D2451E;
}
.provider-list .item-list:nth-of-type(even) {
  background-color: #F2f2f2;
}
.provider-list .view-empty h3 {
  font-size: 2rem;
  font-weight: 400;
  text-align: center;
  padding-block: 3rem;
}

.field__item.listing .provider-list .item-list:nth-of-type(even) {
  background-color: none;
}

.service-providers {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding-block: 4rem;
  padding-inline: 2rem;
  border-top: 4px solid #D2451E;
}
.service-providers .view-header h2 {
  font-size: 2rem;
  font-weight: 500;
  margin-block: 2rem;
  color: #505050;
}
.service-providers .view-content {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.service-providers .provider-card {
  position: relative;
  list-style: none;
  border-bottom: none;
  text-align: left;
  border-radius: 20px;
  padding: 0.5rem !important;
  width: 100%;
  height: fit-content;
  transition: outline 100ms linear;
}
.service-providers .provider-card img {
  width: 100%;
  height: 100%;
  max-height: 330px;
}
.service-providers .provider-card h3 {
  padding: 1rem;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
  color: #505050;
}
.service-providers .provider-card p {
  font-size: 18px;
  font-weight: 400;
  color: #505050;
  padding: 0.5rem 1rem;
  line-height: 1.25;
  text-align: left;
}
.service-providers .provider-card .card-link {
  position: absolute;
  inset: 0;
  color: transparent;
}
.service-providers .provider-card:hover, .service-providers .provider-card:focus, .service-providers .provider-card:active {
  outline: 5px solid #D2451E;
}

.event-list .event-card {
  position: relative;
  width: 100%;
  padding: 2rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  border-bottom: 1px solid #F2f2f2;
}
.event-list .event-card .event-day {
  width: 10%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.event-list .event-card .event-day .event-day-number {
  font-size: 1.25rem;
  font-weight: 700;
}
.event-list .event-card .event-title {
  width: 90%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.event-list .event-card h3 {
  width: 75%;
  font-size: 2rem;
  font-weight: 700;
  text-align: left;
  color: #505050;
}
.event-list .event-card > a {
  position: absolute;
  color: transparent;
  inset: 0;
}
.event-list .event-card:hover, .event-list .event-card:focus, .event-list .event-card:active {
  background-color: #D2451E;
  color: #fff;
}
.event-list .event-card:hover h3, .event-list .event-card:focus h3, .event-list .event-card:active h3 {
  color: #fff;
}
.event-list.partial .view-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  width: 100%;
  border: 1px solid #C8C8C8;
  border-radius: 20px;
  overflow: hidden;
}
.event-list.full {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding-block: 3rem;
  padding-inline: 2rem;
}
.event-list.full .view-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  width: 100%;
  border: 1px solid #C8C8C8;
  border-radius: 20px;
  overflow: hidden;
}
.event-list .view-footer {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
}
.event-list .view-footer .views-display-link {
  display: block;
  padding: 1rem 1.75rem;
  border-radius: 10rem;
  border: none;
  background-color: #D2451E;
  color: #fff;
  font-size: 1.3rem;
}
.event-list .view-footer .views-display-link:hover, .event-list .view-footer .views-display-link:focus, .event-list .view-footer .views-display-link:active {
  background-color: #C41230;
  color: #fff;
}

@media screen and (max-width: 992px) {
  .provider-list .item-list ul {
    grid-template-columns: repeat(3, 1fr);
  }
  .service-providers .view-content {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .provider-list .item-list ul {
    grid-template-columns: repeat(2, 1fr);
  }
  .service-providers .view-content {
    grid-template-columns: repeat(2, 1fr);
  }
  .event-list .view-content .event-card {
    flex-direction: column;
  }
  .event-list .view-content .event-card .event-day {
    width: 100%;
    margin-bottom: 1rem;
  }
  .event-list .view-content .event-card .event-title {
    width: 100%;
    align-items: center;
  }
  .event-list .view-content .event-card .event-title h3 {
    font-size: calc(2rem - 1vw);
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 576px) {
  .provider-list .item-list ul {
    grid-template-columns: 1fr;
    place-items: center;
  }
  .provider-list .item-list ul li.provider-card {
    max-width: 350px;
  }
  .service-providers .view-content {
    grid-template-columns: 1fr;
  }
  .service-providers .provider-card {
    max-width: 350px;
  }
}
.provider_search > .paragraph,
.banner > .paragraph {
  background-color: #D2451E;
  border-radius: 20px;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form,
.banner > .paragraph > .field--name-field-search > .views-exposed-form {
  padding: 0;
  background: none;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  width: 100%;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form .form-item,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form .form-item {
  position: relative;
  width: calc(25% - 1rem);
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form label,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form label {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input,
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form select,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form input,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form select {
  width: 100%;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  background-color: #fff;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit],
.banner > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit] {
  margin-block: 1.5rem;
  padding: 0.75rem 1.25rem;
  border-radius: 6px;
  border: 2px solid #fff;
  background-color: #D2451E;
  color: #fff;
}
.provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:hover, .provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:focus, .provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:active,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:hover,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:focus,
.banner > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit]:active {
  background-color: #fff;
  color: #D2451E;
}
.provider_search > .paragraph .field--name-field-body,
.banner > .paragraph .field--name-field-body {
  text-align: center;
}
.provider_search > .paragraph .field--name-field-body p,
.banner > .paragraph .field--name-field-body p {
  color: #fff !important;
}
.provider_search > .paragraph .field--name-field-cta a,
.banner > .paragraph .field--name-field-cta a {
  display: block;
  margin-inline: auto;
  width: fit-content;
  padding: 0.75rem 1.25rem;
  font-size: 18px;
  border-radius: 6px;
  color: #fff;
  border: 2px solid #fff;
}
.provider_search > .paragraph .field--name-field-cta a:hover, .provider_search > .paragraph .field--name-field-cta a:active, .provider_search > .paragraph .field--name-field-cta a:focus,
.banner > .paragraph .field--name-field-cta a:hover,
.banner > .paragraph .field--name-field-cta a:active,
.banner > .paragraph .field--name-field-cta a:focus {
  background-color: #fff;
  color: #D2451E;
}
.provider_search .field--name-field-heading h2,
.banner .field--name-field-heading h2 {
  padding-block: 1rem;
  margin-bottom: 2rem;
  text-align: center;
  color: #fff;
  font-size: 2rem;
  font-weight: 500;
}

.award_banner .paragraph--type--award-banner {
  position: relative;
  background-color: #505050;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  margin-block: 2rem;
  padding: 0 !important;
  max-width: 100% !important;
  height: 200px;
}
.award_banner .paragraph--type--award-banner .field--name-field-shield-logo {
  position: relative;
  max-width: 314px;
  width: 100%;
  height: 120%;
  top: -10%;
}
.award_banner .paragraph--type--award-banner .field--name-field-shield-logo img {
  height: 290px;
}
.award_banner .paragraph--type--award-banner .field--name-field-places-to-work {
  height: 90px;
}

.above-banner {
  padding-bottom: 13rem;
}

.below-banner {
  padding-top: 13rem;
}

@media screen and (max-width: 768px) {
  .provider_search > .paragraph > .field--name-field-search > .views-exposed-form form {
    flex-direction: column;
    padding-inline: 0;
  }
  .provider_search > .paragraph > .field--name-field-search > .views-exposed-form form .form-item {
    width: 100%;
  }
  .provider_search > .paragraph > .field--name-field-search > .views-exposed-form form input[type=submit] {
    margin-top: 2rem !important;
  }
  .above-banner {
    padding-bottom: 16rem;
  }
  .below-banner {
    padding-top: 16rem;
  }
}
.paragraph--type--image-gallery {
  border-top: 4px solid #D2451E;
}
.paragraph--type--image-gallery .field--name-field-media-multiple {
  --grid-max-col-count: 3;
  --grid-min-col-size: 300px;
  --grid-gap: 1rem;
  --grid-col-size-calc: calc((100% - var(--grid-gap) * var(--grid-max-col-count)) / var(--grid-max-col-count));
  --grid-col-min-size-calc: min(max(var(--grid-min-col-size), var(--grid-col-size-calc)),
          100%);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-col-min-size-calc), 1fr));
  grid-auto-rows: minmax(min-content, auto);
  gap: 1rem;
}
.paragraph--type--image-gallery .field--name-field-media-multiple .field__item {
  width: 100%;
  aspect-ratio: 600/500;
  overflow: hidden;
  border-radius: 20px;
}
.paragraph--type--image-gallery .field--name-field-media-multiple .field__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.paragraph--type--image-gallery.col-4 .field--name-field-media-multiple {
  --grid-max-col-count: 4;
}
.paragraph--type--image-gallery.remove-gap.col-4 {
  --grid-max-col-count: 4;
}
.paragraph--type--image-gallery.remove-gap .field--name-field-media-multiple {
  --grid-min-col-size: 500px;
  --grid-col-size-calc: calc((100% - var(--grid-gap) * var(--grid-max-col-count)) / var(--grid-max-col-count));
  --grid-col-min-size-calc: min(max(var(--grid-min-col-size), var(--grid-col-size-calc)),
          100%);
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-col-min-size-calc), 1fr));
  gap: 0;
}
.paragraph--type--image-gallery.remove-gap .field--name-field-media-multiple .field__item {
  border-radius: 0;
  aspect-ratio: 850/500;
}

.dialog-video-button {
  width: 100%;
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}
.dialog-video-button::after {
  content: "";
  display: block;
  pointer-events: none;
  position: absolute;
  width: 200px;
  height: 200px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  mask: url("../img/icons/play-fill.svg") no-repeat center/100%;
  background-color: rgba(255, 255, 255, 0.8);
  transition: background-color 200ms ease;
}
.dialog-video-button .field--name-thumbnail {
  width: 100%;
}
.dialog-video-button .field--name-thumbnail img {
  transition: filter 200ms ease;
}
.dialog-video-button:hover, .dialog-video-button:focus, .dialog-video-button:active {
  cursor: pointer;
}
.dialog-video-button:hover .field--name-thumbnail img, .dialog-video-button:focus .field--name-thumbnail img, .dialog-video-button:active .field--name-thumbnail img {
  filter: blur(3px);
}
.dialog-video-button:hover .dialog-video-button::after, .dialog-video-button:focus .dialog-video-button::after, .dialog-video-button:active .dialog-video-button::after {
  background-color: #fff;
}

dialog {
  display: none;
  visibility: hidden;
  justify-content: center;
  align-items: center;
  position: fixed;
  max-width: 100%;
  width: min(1000px, 100%);
  max-height: 100%;
  height: fit-content;
  margin: auto;
  padding: 1rem;
  padding-bottom: 5rem;
  overflow: visible;
  background-color: transparent;
  isolation: isolate;
  transition: opacity 500ms ease, display 100ms allow-discrete, overlay 100ms allow-discrete;
}
dialog[open] {
  display: flex;
  visibility: visible;
}
dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(3px);
}
dialog .dialog-close {
  display: block;
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  width: 3rem;
  height: 3rem;
  border-radius: 3rem;
  border: 2px solid transparent !important;
  color: transparent;
  background-color: transparent;
}
dialog .dialog-close::after {
  content: "";
  display: block;
  position: absolute;
  inset: 10%;
  background-color: #fff;
  mask: url("../img/icons/x.svg") no-repeat center/100%;
}
dialog .dialog-close:hover, dialog .dialog-close:active, dialog .dialog-close:focus {
  cursor: pointer;
  background-color: #D2451E;
}
dialog.modal-card .dialog-content {
  width: min(700px, 100%);
  height: 100%;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 100px max-content max-content;
  justify-content: center;
  align-items: flex-start;
  overflow-y: auto;
  padding: 2rem;
  border-radius: 20px;
  background-color: #fff;
}
dialog.modal-card .dialog-content .field--name-field-icon {
  height: 100%;
}
dialog.modal-card .dialog-content .field--name-field-icon > * {
  height: 100%;
}
dialog.modal-card .dialog-content .field--name-field-icon img {
  margin-inline: auto;
}
dialog.modal-card .dialog-content .field--name-field-title {
  position: relative;
  height: 100%;
  align-content: center;
}
dialog.modal-card .dialog-content .field--name-field-title h3 {
  position: relative;
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  padding-block: 2rem;
  margin-bottom: 1rem;
  color: #505050;
}
dialog.modal-card .dialog-content .field--name-field-title h3::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 4px;
  width: 100px;
  background-color: #D2451E;
}
dialog.modal-card .dialog-content .field--name-field-body {
  margin-top: 1rem;
}
dialog.video-dialog .field--name-field-media-oembed-video {
  width: min(1000px, 100%);
  height: fit-content;
  aspect-ratio: 16/9;
}
dialog.video-dialog .field--name-field-media-oembed-video iframe {
  width: 100%;
  height: 100%;
  border-radius: 1rem;
}
@media screen and (max-width: 576px) {
  dialog {
    align-items: flex-start;
    width: 100%;
    height: 100%;
    margin-top: 0;
    margin-inline: 0;
  }
  dialog.video-dialog {
    align-items: center;
  }
}

dialog[open] {
  opacity: 1;
}
@starting-style {
  dialog[open] {
    opacity: 0;
  }
}

body:has(dialog[open]) {
  overflow: hidden;
}

main:has(.user-login-form) {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.user-login-form {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 2rem;
  padding: 3rem;
  margin-inline: auto;
  width: 100%;
  max-width: 75ch;
  background-color: #F2f2f2;
}
.user-login-form::before {
  content: "";
  position: relative;
  width: 100%;
  height: 10rem;
  background: url("../img/logo.png") no-repeat center/auto;
}
.user-login-form .form-item__label {
  font-size: 1.3rem;
  margin-bottom: 0.5rem;
}
.user-login-form .form-item {
  width: 100%;
}
.user-login-form input[type=text],
.user-login-form input[type=password] {
  position: relative;
  padding: 0.5rem;
  font-weight: 500;
  border: 2px solid #D2451E;
  border-radius: 6px;
  font-size: 1.3rem;
}
.user-login-form input[type=submit] {
  display: block;
  padding: 1rem 1.75rem;
  border-radius: 10rem;
  border: none;
  background-color: #D2451E;
  color: #fff;
  font-size: 1.3rem;
}
.user-login-form input[type=submit]:hover, .user-login-form input[type=submit]:focus, .user-login-form input[type=submit]:active {
  background-color: #C41230;
  color: #fff;
}

.views-exposed-form {
  padding-block: 5rem;
  padding-inline: 2rem;
  background-color: #F2f2f2;
}
.views-exposed-form form {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
}
.views-exposed-form form .form-item {
  position: relative;
  width: calc(25% - 1rem);
}
.views-exposed-form form label {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.views-exposed-form form input,
.views-exposed-form form select {
  width: 100%;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  background-color: #fff;
}
.views-exposed-form form input[type=submit] {
  font-size: 18px;
  font-weight: 700;
  margin-top: 3rem !important;
  padding: 1.25rem 1.75rem;
  border-radius: 6px;
  background-color: #D2451E;
  color: #fff;
}
.views-exposed-form form input[type=submit]:hover, .views-exposed-form form input[type=submit]:focus, .views-exposed-form form input[type=submit]:active {
  background-color: #C41230;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .views-exposed-form {
    padding-inline: 0;
  }
  .views-exposed-form form {
    flex-direction: column;
    padding-inline: 2rem;
  }
  .views-exposed-form form .form-item {
    width: 100%;
  }
}
.field--name-field-accordion-item {
  overflow: hidden;
  background-color: transparent;
  width: 100%;
  border-radius: 20px;
  border: 1px solid #C8C8C8;
}
.field--name-field-accordion-item .accordion-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 20px;
  font-weight: 400;
  padding: 1.5rem 1rem;
  color: #505050;
}
.field--name-field-accordion-item .accordion-button:hover, .field--name-field-accordion-item .accordion-button:focus, .field--name-field-accordion-item .accordion-button:active {
  cursor: pointer;
  background-color: #D2451E;
  color: #fff;
}
.field--name-field-accordion-item .accordion-button:hover:after, .field--name-field-accordion-item .accordion-button:focus:after, .field--name-field-accordion-item .accordion-button:active:after {
  background-color: #fff;
}
.field--name-field-accordion-item .accordion-button:after {
  content: "";
  display: inline-block;
  margin-right: 0;
  width: 1rem;
  height: 1rem;
  background-color: #C8C8C8;
  mask: url("../img/icons/chevron-right.svg") no-repeat center;
  mask-size: 100%;
  transition: rotate 500ms;
}
.field--name-field-accordion-item .accordion-body-wrapper {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 500ms;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body {
  overflow: hidden;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body > * {
  padding: 2rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body {
  background-color: #fff;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body img {
  margin-bottom: 2rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body h2,
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body h3 {
  font-size: 2rem;
  margin-block: 1.2rem;
  color: #D2451E;
  line-height: 2.5rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body p {
  font-size: 1.1rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body p strong {
  color: #D2451E;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body ul {
  margin-bottom: 1rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body ul li {
  list-style: disc;
  margin-left: 1rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body ol {
  margin-bottom: 1rem;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body ol li {
  list-style: decimal;
}
.field--name-field-accordion-item .accordion-body-wrapper .accordion-body .field--name-field-accordion-body a {
  color: #D2451E;
}
.field--name-field-accordion-item.expanded .accordion-button {
  background-color: #D2451E;
  color: #fff;
  border-bottom: 1px solid #C8C8C8;
}
.field--name-field-accordion-item.expanded .accordion-button:after {
  rotate: 90deg;
}
.field--name-field-accordion-item.expanded .accordion-body-wrapper {
  grid-template-rows: 1fr;
}

.paragraph--type--accordion .heading {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 2rem;
  gap: 1rem;
  text-align: center;
}
.paragraph--type--accordion .accordion {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
}

.block-copyright-block {
  width: 100%;
  margin-inline: auto;
  gap: 0.5ch;
  display: flex;
  justify-content: center;
  padding-block: 1rem;
  font-weight: 300;
  background-color: #C8C8C8;
  font-size: clamp(0.8rem, 0.5rem + 3vw, 15px);
  color: #505050;
}
.block-copyright-block a {
  color: #505050;
  text-decoration: none;
}
.block-copyright-block svg.ext {
  display: none;
}
.block-copyright-block .them {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 576px) {
  .block-copyright-block {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
  }
  .block-copyright-block .them {
    margin-right: 0;
  }
  .block-copyright-block .them::after {
    display: none;
  }
  .block-copyright-block .unanimo {
    margin-left: 0;
  }
  .block-copyright-block .unanimo::before {
    display: none;
  }
}

.page-wrapper {
  position: relative;
  width: 100%;
  min-height: 100vh;
  height: fit-content;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  isolation: isolate;
  overflow: hidden;
}
.page-wrapper main {
  --header-offset: 0;
  margin-top: var(--header-offset);
}
.page-wrapper main {
  z-index: 1;
}
.page-wrapper main .page-content {
  margin-top: 0;
  margin-bottom: 0;
}
.page-wrapper main .page-content .field--name-field-advanced-content > .field__item > .paragraph {
  max-width: 1400px;
  width: 100%;
  padding-block: 2rem;
  padding-inline: 2rem;
  margin-inline: auto;
}
.page-wrapper main .page-content .field--name-field-advanced-content > .field__item.hero > .paragraph {
  max-width: unset;
  padding: 0;
}
.page-wrapper main .page-content .field--name-field-advanced-content > .field__item.image_gallery > .paragraph.remove-gap {
  max-width: unset;
  padding: 0;
}
.page-wrapper main .page-content .field--name-field-advanced-content > .field__item.banner, .page-wrapper main .page-content .field--name-field-advanced-content > .field__item:has(.paragraph--type--provider-search) {
  height: 0;
  overflow: visible;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-inline: 2rem;
}
.page-wrapper main .page-content .body-wrapper:has(.field--name-field-advanced-content) .field--name-body {
  padding-top: 3rem;
  padding-bottom: 0;
}
.page-wrapper main .page-content .body-wrapper .field--name-field-banner-images {
  width: 100%;
}
.page-wrapper main .page-content .body-wrapper .field--name-field-banner-images img {
  border-radius: 20px;
}
.page-wrapper main .page-content .body-wrapper .field--name-body {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding: 2rem;
}
.page-wrapper main .page-content .body-wrapper .field--name-body p {
  margin-bottom: 1rem;
}
.page-wrapper main .page-content .node__content:has(.field--name-field-advanced-content) .node-body-wrapper {
  padding-bottom: 0;
}
.page-wrapper main .page-content .field--name-field-image .image-style-interior-main-image {
  width: 100%;
  height: 100%;
  max-height: 600px;
  border-radius: 2rem;
  margin-bottom: 2rem;
}
.page-wrapper main .page-content .field--name-field-date {
  padding-top: 2rem;
  font-weight: 700;
  font-size: 18px;
  max-width: 1400px;
  margin-bottom: 0.5rem;
  margin-inline: auto;
}
.page-wrapper main .page-content .node-body-wrapper {
  max-width: 1400px;
  margin-inline: auto;
  padding: 2rem;
  padding-block: 3rem;
}
.page-wrapper main .page-content .node-body-wrapper:has(.side-card) {
  display: grid;
  justify-content: flex-start;
  align-items: flex-start;
  grid-template-columns: 70% minmax(10rem, 1fr);
  gap: 2rem;
}
.page-wrapper main .page-content .node-body-wrapper .field--name-body {
  padding: 0;
  margin-bottom: 2rem;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper {
  max-width: 1400px;
  width: 100%;
  padding: 2rem;
  padding-block: 3rem;
  margin-inline: auto;
  display: grid;
  justify-content: flex-start;
  grid-template-columns: minmax(min-content, 500px) auto;
  gap: 4rem;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .field--name-field-image {
  width: 100%;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .field--name-field-image img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  border-radius: 1rem;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .provider-info {
  color: #505050;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .provider-info .field--name-field-full-name {
  font-size: 2rem;
  font-weight: 700;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .provider-info .field--name-field-job-title {
  font-size: 32px;
  font-weight: 500;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .provider-info .provider-details {
  max-width: 650px;
}
.page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper .provider-info .provider-details::before {
  content: "";
  position: relative;
  display: block;
  margin-block: 3rem;
  max-width: 102px;
  width: 100%;
  height: 4px;
  background-color: #D2451E;
}
.page-wrapper main .page-content .events-wrapper .event-location {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5ch;
  margin-block: 0.5rem 1rem;
  font-weight: 700;
}
.page-wrapper main .page-content .events-wrapper .event-location a {
  color: #D2451E;
}
.page-wrapper main .page-content .events-wrapper .event-location a:hover, .page-wrapper main .page-content .events-wrapper .event-location a:focus, .page-wrapper main .page-content .events-wrapper .event-location a:active {
  text-decoration: underline;
}

footer {
  margin-top: auto;
  z-index: 0;
}

.path-user .region-content:not(:has(.user-login-form)) {
  max-width: 1400px;
  width: 100%;
  margin-inline: auto;
  padding: 2rem;
}

@media screen and (max-width: 768px) {
  .page-wrapper header {
    width: 100%;
  }
  .page-wrapper main .page-content:has(.node--type-provider, .node--type-staff) .body-wrapper {
    grid-template-columns: 1fr;
  }
  .page-wrapper main .page-content .node-body-wrapper:has(.side-card) {
    grid-template-columns: 1fr;
  }
}
.paragraph--type--full-width {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.paragraph--type--full-width.body-full .field--name-field-body {
  width: 100%;
}
.paragraph--type--full-width.body-partial {
  align-items: flex-start;
}
.paragraph--type--full-width.body-partial .field--name-field-body {
  max-width: 930px;
}
.paragraph--type--full-width.body-partial:has(.field--name-field-body .text-align-center) {
  align-items: center;
}
.paragraph--type--full-width .field--name-field-heading {
  width: 100%;
  margin-bottom: 1.5rem;
  text-align: center;
}
.paragraph--type--full-width .field--name-field-body {
  margin-bottom: 2rem;
}
.paragraph--type--full-width .field--name-field-body p {
  color: #505050;
}
.paragraph--type--full-width .field--name-field-body a {
  color: #D2451E;
  text-decoration: underline;
}
.paragraph--type--full-width .field--name-field-body table {
  display: block;
  width: fit-content;
  margin-inline: auto;
}
.paragraph--type--full-width .field--name-field-body table tbody tr td {
  padding: 1rem;
}
.paragraph--type--full-width .field--name-field-body table tbody tr td p {
  margin-bottom: 0;
}
.paragraph--type--full-width .field--name-field-block {
  width: 100%;
  margin-bottom: 2rem;
}
.paragraph--type--full-width .field--name-field-cta {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.paragraph--type--full-width .field--name-field-cta a {
  display: block;
  width: fit-content;
  padding: 0.75rem 1.25rem;
  background-color: #D2451E;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  border-radius: 6px;
}
.paragraph--type--full-width .field--name-field-cta a:hover, .paragraph--type--full-width .field--name-field-cta a:focus, .paragraph--type--full-width .field--name-field-cta a:active {
  background-color: #C41230;
  color: #fff;
}

.field__item.full_width.banner .paragraph--type--full-width .field--name-field-body p {
  color: #fff;
}

.field--name-field-columns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  justify-content: center;
  gap: 4rem;
  padding-block: 2rem;
}
.field--name-field-columns .paragraph--type--image {
  width: 100%;
}
.field--name-field-columns .paragraph--type--image .field--name-field-media-single img {
  width: 100%;
}
.field--name-field-columns .paragraph--type--content.heading-large .field--name-field-heading h2 {
  font-size: 4rem;
  font-weight: 700;
  color: #505050;
}
.field--name-field-columns .paragraph--type--content .field--name-field-heading h2 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 2rem;
}
.field--name-field-columns .paragraph--type--content .field--name-field-body h3 {
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
.field--name-field-columns .paragraph--type--content .field--name-field-cta a {
  display: block;
  width: fit-content;
  font-size: 18px;
  font-weight: 700;
  margin-top: 3rem !important;
  padding: 1.25rem 1.75rem;
  border-radius: 6px;
  background-color: #D2451E;
  color: #fff;
}
.field--name-field-columns .paragraph--type--content .field--name-field-cta a:hover, .field--name-field-columns .paragraph--type--content .field--name-field-cta a:focus, .field--name-field-columns .paragraph--type--content .field--name-field-cta a:active {
  background-color: #C41230;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .field--name-field-columns {
    grid-template-columns: 1fr;
  }
  .field--name-field-columns .field__item:first-of-type:has(.paragraph--type--content) {
    order: 2;
  }
}
.region-footer {
  position: relative;
  background-color: #505050;
  isolation: isolate;
  border-top: 20px solid #D2451E;
}
.region-footer::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: -1;
  background: url("../img/mark-grayscale.png") no-repeat center/cover;
}

.block--type-main-footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2rem;
  max-width: 1400px;
  width: 100%;
  padding: 2rem;
  margin-inline: auto;
  z-index: 2;
}
.block--type-main-footer .field--name-field-logo img {
  max-width: 500px;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.block--type-main-footer .contact-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-start;
}
.block--type-main-footer .contact-info .field--name-field-contact-info p {
  text-align: right;
  color: #fff;
}
.block--type-main-footer .contact-info .field--name-field-social-list {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding-block: 1rem;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link {
  position: relative;
  border: 2px solid transparent;
  border-radius: 2rem;
  overflow: hidden;
  padding: 0.5rem;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link .field--name-field-icon {
  width: 2rem;
  height: 2rem;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link .field--name-field-icon * {
  width: 100%;
  height: 100%;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link .field--name-field-icon img {
  object-fit: contain;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link .field--name-field-social-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link .field--name-field-social-link a {
  position: absolute;
  inset: 0;
  color: transparent;
}
.block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link:hover, .block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link:focus, .block--type-main-footer .contact-info .field--name-field-social-list .paragraph--type--social-link:active {
  border-color: #fff;
}
.block--type-main-footer .menu--main .menu,
.block--type-main-footer .menu--top-bar-buttons .menu {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-start;
  gap: 1rem;
}
.block--type-main-footer .menu--main .menu li,
.block--type-main-footer .menu--top-bar-buttons .menu li {
  list-style: none;
}
.block--type-main-footer .menu--main .menu li a,
.block--type-main-footer .menu--top-bar-buttons .menu li a {
  color: #fff;
}

@media screen and (max-width: 768px) {
  .block--type-main-footer .contact-info {
    width: 100%;
    align-items: center;
  }
  .block--type-main-footer .contact-info .field--name-field-contact-info p {
    text-align: center;
  }
  .block--type-main-footer .contact-info .field--name-field-social-list {
    justify-content: center;
  }
  .block--type-main-footer .menu--main .menu,
  .block--type-main-footer .menu--top-bar-buttons .menu {
    align-items: center;
  }
  .block--type-main-footer .field--name-field-main-navigation,
  .block--type-main-footer .field--name-field-secondary-navigation {
    width: 100%;
  }
}

/*# sourceMappingURL=styles.css.map */
