:root {
  --color-grey-border: #fbfbfb;
}

.o-reservation-a {

  padding-top: 3rem;
  /*padding-bottom: 2.75rem;*/

  @media (width >=1024px) {
    padding-top: 3.5625rem;
    padding-bottom: 3.25rem;
  }
}

@media only screen and (width >=1024px) {
  .o-reservation-a__columns {
    grid-template-columns: 3fr 2.4fr;
    grid-column-gap: 2rem;
  }
}


/* column1 */

.o-reservation-a__leading {
  font-size: 2.125rem;

  @media (width >=1024px) {
    font-size: var(--title-xl);
  }
}

.o-reservation-a__title {
  line-height: 1;
}

.o-reservation-a__location-name {
  line-height: 1;
  margin-bottom: .875rem;
}


@media only screen and (width >=1024px) {
  .o-reservation-a__column1 {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
  }

  .o-reservation-a__column1-headings {
    text-align: left;
  }

  .o-reservation-a__title {
    font-size: 3.75rem;
  }

  .o-reservation-a__location-name {
    margin-bottom: 0;
    font-size: 3.75rem;
    text-align: left;
  }
}

/* column2 */

@media only screen and (width >=1024px) {
  .o-reservation-a__column2 {
    grid-column: 2 / 3;
    grid-row: 1 / 3;
    border-left: 1px solid #c0bcbc;
    padding-left: 9%;
  }
}

.o-reservation-a__address {
  margin-bottom: 1.75rem;

  @media (width >=1024px) {
    margin-bottom: 1rem;
  }

  & h1,
  & h2,
  & h3,
  & h4,
  & h5,
  & h6 {
    margin-top: .1em;
    line-height: 1em;
    margin-bottom: 0;
  }

  & h6 {
    font-size: 1.375rem;
    line-height: 1.3;

    @media (width >=1024px) {
      font-size: 1.75rem;
      line-height: 1;
    }
  }
}

.o-reservation-a__address> :last-child {
  margin-bottom: 0;
}

.o-reservation-a__contacts-wrapper {
  gap: 1rem;
  background-color: var(--color-grey-lighter);
  padding: 1.5rem 5%;
  margin: 0.1rem -5% 1.75rem;

  @media (width >=1024px) {
    margin-bottom: 1rem;
  }
}

.o-reservation-a__phone,
.o-reservation-a__working-hours {
  gap: .7rem;
}

.o-reservation-a__tabs-title {
  margin-bottom: 2rem;

  @media (width >=1024px) {
    margin-bottom: 1rem;
  }
}

.o-reservation-a__tab-heading {
  margin-bottom: 2rem;
  gap: .5rem;
}

.js--o-reservation-a__tab-link {
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  position: relative;
  background-color: var(--color-white);
  border: 1px solid var(--color-grey-light);
  border-radius: 50%;
  cursor: pointer;
  transition-property: color, background-color, border;
  transition-duration: .3s;
  font-size: .8em;
}

.js--o-reservation-a__tab-link span {
  position: relative;
  bottom: -2px;
  ;
}

.js--o-reservation-a__tab-link:hover,
.js--o-reservation-a__tab-link.active {
  color: var(--color-white);
  background-color: #c1ab94;
  border-color: #c1ab94;
}

.js--o-reservation-a__tab-link.today:after {
  content: 'Today';
  font-size: .75rem;
  color: var(--color-red);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.o-reservation-a__tab-content {
  margin-bottom: 2.5rem;
}

.js--o-reservation-a__tab-content-item {
  display: none;
}

.o-reservation-a__tab-content-working-time {
  border-bottom: 1px solid #c0bcbc;
  padding-bottom: .75rem;
  margin-bottom: 1.5rem;
  gap: .5rem;
}

.o-reservation-a__tab-content-activity p:last-child {
  margin-bottom: 0;
}

.o-reservation-a__tab-content-activity {
  gap: .5rem;
}

.o-reservation-a__amenities-title {
  margin-bottom: 1.4rem;

  @media (width >=1024px) {
    margin-bottom: 1rem;
  }
}

.o-reservation-a__amenities-columns {
  grid-column-gap: 2.5rem;
  grid-row-gap: .625rem;
}

.o-reservation-a__amenities-item-text> :last-child {
  margin-bottom: 0;
}

.o-reservation-a__buttons {
  grid-template-columns: repeat(2, 1fr);
  margin-top: 2rem;
  grid-gap: 5%;

  @media (width >=1024px) {
    grid-gap: 7%;
  }

  & .a-button {
    padding-top: .8em;
    padding-bottom: .8em;
    justify-content: center;
    
    @media (width >=1024px) {}
  }

  & .a-button.a-button--secondary{
      &:hover {
          background-color: var(--color-red-hover);
          color: var(--color-white);
          border-color: var(--color-red-hover);
      }
  }
}

@media (width >=1024px) {
  .o-reservation-a__address {
    font-size: 1em;
    text-align: left;
  }

  .o-reservation-a__contacts-wrapper {
    background-color: transparent;
    padding: 0;
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 2rem;
  }

  .o-reservation-a__phone,
  .o-reservation-a__working-hours {
    gap: 1rem;
  }
}

@media (width >=575px) {
  .o-reservation-a__amenities-columns {
    grid-template-columns: repeat(2, 1fr);
  }
}


@media (max-width: 1024px) and (width >=575px) {
  .o-reservation-a__tab-heading {
    justify-content: flex-start;
  }
}

.o-reservation-a__amenities-item-title {
  font-size: 1.125rem;
}

.o-reservation-a__content {
  background-color: var(--color-grey-lighter);
  padding: 1.5rem 5%;
  margin-top: 2.5rem;
  margin-left: -5%;
  margin-right: -5%;

  hr{
    display: none;
  }

  @media (width >=768px) {
    hr{
      display: block;
    }
  }
  
  @media (width >=1024px) {
    margin-top: 3.9rem;
  }
}

.o-reservation-a__content>*:last-child {
  margin-bottom: 0;
}

.o-reservation-a__column3 {
  & .o-reservation-a__content {
    /* padding-bottom: 5rem; */
  }
}

.o-reservation-a__phone a {
    text-decoration: none;
    border-bottom: 1px solid;

    &:hover {
      color: var(--color-red);
    }
}

@media only screen and (width >=1024px) {
  .o-reservation-a__column3 {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
  }

  .o-reservation-a__content {
    background-color: transparent;
    padding: 0;
    margin-left: 0;
    margin-right: 0;

    hr {
      margin: 3.75rem 0;
      border-color: var(--color-grey-border);
    }
  }
}