/**
 * The base file that should be imported by every file.
 * There should be no CSS generation in this or from imported scss files at all!
 */
/**
 * Library
 */
/**
 * Variables and functions
 */
.pagination {
  margin-top: 60px;
  display: flex;
  justify-content: center; }
  .pagination .facetwp-facet {
    margin-bottom: 0; }
  .pagination .nav-links,
  .pagination .facetwp-pager {
    display: flex;
    align-items: center;
    gap: 10px; }
  .pagination .page-numbers,
  .pagination .facetwp-page {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 35px;
    height: 35px;
    text-align: center;
    border-radius: 100%;
    border: 1px solid var(--dark-blue);
    background-color: var(--background-color);
    margin: 0;
    padding: 1px 0 0 0;
    font-size: 14px;
    text-decoration: none;
    transition: ease-in-out 200ms background-color, ease-in-out 200ms border-color; }
    .pagination .page-numbers:hover, .pagination .page-numbers.active, .pagination .page-numbers.current,
    .pagination .facetwp-page:hover,
    .pagination .facetwp-page.active,
    .pagination .facetwp-page.current {
      background-color: var(--light-sand);
      border-color: var(--light-sand); }
    .pagination .page-numbers.prev, .pagination .page-numbers.next,
    .pagination .facetwp-page.prev,
    .pagination .facetwp-page.next {
      width: 20px;
      height: 20px;
      background-color: var(--dark-blue);
      color: var(--white);
      border: 0;
      font-size: 10px; }

.section-loop .container > h2 .facetwp-facet {
  display: inline-block;
  margin-bottom: 0; }

.section-loop .container > h2 span {
  font-weight: 400; }

.section-loop .maps-container {
  display: none; }

.section-loop .locations {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr; }
  @media (min-width: 768px) {
    .section-loop .locations {
      grid-template-columns: repeat(2, 1fr); } }
  @media (min-width: 981px) {
    .section-loop .locations {
      grid-template-columns: repeat(3, 1fr); } }

.section-loop .maps {
  height: 560px; }
  .section-loop .maps .facetwp-map-filtering {
    display: none; }
  .section-loop .maps .gm-style-iw {
    background-color: var(--white);
    border: 0;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    color: var(--text-color) !important;
    top: 15px !important;
    width: 340px !important;
    height: 130px !important; }
    .section-loop .maps .gm-style-iw .gm-style-iw-d {
      padding: 0 !important;
      max-height: none !important;
      overflow: auto !important;
      height: 100%; }
      .section-loop .maps .gm-style-iw .gm-style-iw-d > div {
        height: 100%; }
    .section-loop .maps .gm-style-iw .map-marker {
      font-size: 16px;
      line-height: 25px;
      color: var(--text-color);
      display: flex;
      align-items: center; }
      .section-loop .maps .gm-style-iw .map-marker .image {
        width: 130px;
        height: 130px;
        position: relative;
        flex-shrink: 0; }
        .section-loop .maps .gm-style-iw .map-marker .image img {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          -o-object-fit: cover;
          object-fit: cover; }
      .section-loop .maps .gm-style-iw .map-marker .content {
        padding: 27px 30px; }
      .section-loop .maps .gm-style-iw .map-marker .place-name {
        color: var(--light-blue);
        font-weight: 700;
        font-size: 14px; }
  .section-loop .maps .gm-ui-hover-effect {
    top: 0 !important;
    right: 0 !important; }
  .section-loop .maps .gm-style-iw-tc {
    display: none; }
  .section-loop .maps .gm-style-iw-chr {
    position: absolute;
    right: 0;
    z-index: 1; }
  .section-loop .maps .facetwp-type-map {
    height: 100%;
    width: 100%; }

.item-location {
  background-color: var(--white);
  border-radius: 5px 5px 0 0;
  overflow: hidden;
  position: relative; }
  .item-location a.item-in {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    height: 100%; }
  .item-location a.row {
    position: relative;
    z-index: 2; }
  .item-location .image-overlay {
    position: relative;
    padding-top: 60%;
    height: auto;
    min-height: auto;
    margin: 0; }
    .item-location .image-overlay > .img, .item-location .image-overlay img, .item-location .image-overlay video, .item-location .image-overlay iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
         object-fit: cover; }
    .item-location .image-overlay img {
      max-height: 240px; }
      @media (min-width: 480px) {
        .item-location .image-overlay img {
          max-height: none; } }
    .item-location .image-overlay .type-style {
      position: absolute;
      display: flex;
      padding: 8px 16px;
      flex-direction: row;
      gap: 5px;
      bottom: -1vh;
      left: 50%;
      transform: translateX(calc(-50% - 16px));
      border-radius: 24px;
      background: #FFF;
      box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.05);
      width: -moz-max-content;
      width: max-content;
      align-items: center; }
      @media (min-width: 1200px) {
        .item-location .image-overlay .type-style {
          bottom: -1.5vh; } }
      .item-location .image-overlay .type-style .item {
        color: var(--text-color);
        font-size: 12px; }
        .item-location .image-overlay .type-style .item-icon {
          display: flex;
          align-items: center;
          gap: 10px; }
          .item-location .image-overlay .type-style .item-icon span::before {
            font-size: 8px; }
          @media (min-width: 981px) {
            .item-location .image-overlay .type-style .item-icon {
              gap: 20px; } }
          .item-location .image-overlay .type-style .item-icon .text {
            color: var(--light-blue);
            width: 85px; }
  .item-location .content {
    padding: 20px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    padding: 20px;
    padding-bottom: 0;
    margin-bottom: 150px; }
    @media (min-width: 981px) {
      .item-location .content {
        padding: 30px 35px 0 40px; } }
    @media (min-width: 1200px) {
      .item-location .content {
        display: flex;
        padding: 32px;
        padding-block: 0;
        margin-bottom: 120px;
        gap: 24px;
        flex: 1 0 0;
        align-self: stretch; } }
    @media (min-width: 1500px) {
      .item-location .content {
        margin-bottom: 100px; } }
    .item-location .content .h4 {
      line-height: 20px;
      margin-bottom: 15px; }
      @media (min-width: 1200px) {
        .item-location .content .h4 {
          margin-top: 30px;
          margin-bottom: 0; } }
      .item-location .content .h4 a {
        text-decoration: none; }
    .item-location .content p {
      margin-top: 0;
      font-size: 18px;
      line-height: 27px;
      flex-grow: 1;
      white-space: normal; }
  .item-location .btn-location {
    margin-top: 20px;
    position: absolute;
    bottom: 0;
    width: 100%; }
    .item-location .btn-location .btn-wrapper {
      position: relative;
      z-index: 5;
      padding: 24px 32px;
      background: var(--light-purple);
      display: flex;
      justify-content: space-between;
      flex-direction: column;
      align-items: center;
      gap: 16px; }
      @media (min-width: 1500px) {
        .item-location .btn-location .btn-wrapper {
          flex-direction: row;
          gap: 0; } }
    .item-location .btn-location .btn-brochure {
      position: relative;
      z-index: 3; }
    .item-location .btn-location .contact {
      display: flex;
      gap: 8px; }
      .item-location .btn-location .contact .item-icon {
        align-content: center; }
        .item-location .btn-location .contact .item-icon span {
          font-size: 13px; }
      .item-location .btn-location .contact a {
        text-decoration: underline; }
  .item-location .btn {
    display: block; }
    @media (min-width: 768px) {
      .item-location .btn {
        display: inline-block; } }
  .item-location .location-info {
    font-size: 14px;
    line-height: 16px;
    margin-bottom: 25px;
    display: flex;
    flex-wrap: wrap;
    gap: 30px; }
    .item-location .location-info .row {
      display: flex;
      align-items: center;
      gap: 5px;
      margin-bottom: 20px; }
      .item-location .location-info .row-contact {
        position: relative;
        z-index: 4; }
      .item-location .location-info .row:last-child {
        margin-bottom: 0; }
      .item-location .location-info .row .item {
        color: var(--text-color); }
        .item-location .location-info .row .item-icon {
          display: flex;
          align-items: center;
          gap: 10px; }
          @media (min-width: 981px) {
            .item-location .location-info .row .item-icon {
              gap: 20px; } }
          .item-location .location-info .row .item-icon .text {
            color: var(--light-blue);
            width: 85px; }
        .item-location .location-info .row .item .dates {
          display: flex;
          flex-wrap: wrap;
          gap: 9px; }
          .item-location .location-info .row .item .dates .separator {
            width: 1px;
            background-color: var(--gray); }
    .item-location .location-info .right .row {
      gap: 20px; }

.section-loop .container-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 30px 50px;
  margin-bottom: 30px; }
  .section-loop .container-title h2 {
    margin: 0; }

.section-loop section.section-filter {
  padding: 0 !important;
  display: inline-block; }
  .section-loop section.section-filter .container {
    width: 100%; }
  .section-loop section.section-filter .column-title {
    display: none; }
  .section-loop section.section-filter .columns {
    margin-bottom: 0; }
  .section-loop section.section-filter .filters .filter-type {
    display: none; }

/*# sourceMappingURL=loop-contact.css.map */
