/**
 * 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
 */
.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; }

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