/* line 1, _elements.shops.scss */
.shops {
  display: flex;
  flex-direction: column;
  gap: 20px; }
  /* line 5, _elements.shops.scss */
  .shops-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20px; }
    /* line 15, _elements.shops.scss */
    .shops-grid__item {
      border-radius: var(--radius);
      box-shadow: var(--shadow-s);
      overflow: hidden; }
      @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
        /* line 15, _elements.shops.scss */
        .shops-grid__item {
          transition: box-shadow 0.4s ease; } }
      @media (hover: none) {
        /* line 15, _elements.shops.scss */
        .shops-grid__item {
          -webkit-tap-highlight-color: transparent; } }
      @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
        /* line 25, _mixins.scss */
        .shops-grid__item:hover {
          box-shadow: var(--shadow); } }
  /* line 27, _elements.shops.scss */
  .shops__tags {
    margin: -5px 0 0; }

/* line 32, _elements.shops.scss */
.shop-card {
  display: grid;
  grid-template-columns: 645px 1fr; }
  @media (max-width: 1024px) {
    /* line 32, _elements.shops.scss */
    .shop-card {
      grid-template-columns: 1fr; } }
  /* line 40, _elements.shops.scss */
  .shop-card__image .thumb {
    background-color: var(--bg-grey);
    height: 480px; }
    @media (max-width: 767px) {
      /* line 40, _elements.shops.scss */
      .shop-card__image .thumb {
        min-height: auto;
        height: 360px; } }
  /* line 51, _elements.shops.scss */
  .shop-card__data {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 15px 20px; }
    @media (min-width: 1025px) {
      /* line 51, _elements.shops.scss */
      .shop-card__data {
        margin: 40px; } }
    @media (max-width: 575px) {
      /* line 51, _elements.shops.scss */
      .shop-card__data {
        padding: 10px 15px; } }
  /* line 63, _elements.shops.scss */
  .shop-card__title {
    font-size: 22px;
    line-height: 26px; }
    @media (max-width: 1023px) {
      /* line 63, _elements.shops.scss */
      .shop-card__title {
        font-size: 18px;
        line-height: 22px; } }
  /* line 69, _elements.shops.scss */
  .shop-card__hours {
    font-size: 14px;
    line-height: 18px;
    color: var(--color-grey-l); }
  /* line 73, _elements.shops.scss */
  .shop-card__subway {
    display: flex;
    flex-direction: column;
    gap: 5px; }
    /* line 77, _elements.shops.scss */
    .shop-card__subway p:last-child {
      display: none; }
    /* line 83, _elements.shops.scss */
    .shop-card__subway br {
      display: none; }
  /* line 87, _elements.shops.scss */
  .shop-card__controls {
    display: flex;
    gap: 10px; }
    @media (min-width: 1025px) {
      /* line 87, _elements.shops.scss */
      .shop-card__controls {
        flex-direction: column; } }
    @media (min-width: 1150px) {
      /* line 87, _elements.shops.scss */
      .shop-card__controls {
        flex-direction: row; } }

/* line 99, _elements.shops.scss */
.shop-page {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 0;
  background-color: var(--bg-grey);
  border-radius: var(--radius);
  overflow: hidden; }
  /* line 106, _elements.shops.scss */
  .shop-page.has-form {
    grid-template-columns: 1fr 300px;
    gap: 40px;
    background-color: transparent;
    border-radius: 0;
    overflow: visible; }
    @media (max-width: 1024px) {
      /* line 106, _elements.shops.scss */
      .shop-page.has-form {
        grid-template-columns: 1fr; } }
    /* line 116, _elements.shops.scss */
    .shop-page.has-form .shop-page__info {
      padding: 0; }
  @media (max-width: 767px) {
    /* line 99, _elements.shops.scss */
    .shop-page {
      grid-template-columns: 1fr; } }
  /* line 124, _elements.shops.scss */
  .shop-page__info {
    padding: 20px;
    min-width: 0; }
  /* line 128, _elements.shops.scss */
  .shop-page__map {
    position: relative;
    min-height: 480px;
    min-width: 0; }
    @media (max-width: 767px) {
      /* line 128, _elements.shops.scss */
      .shop-page__map {
        min-height: auto;
        height: 360px; } }
    /* line 136, _elements.shops.scss */
    .shop-page__map .alert-icon {
      position: absolute;
      z-index: 1;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      justify-content: center; }
    /* line 146, _elements.shops.scss */
    .shop-page__map.is-loaded .alert-icon {
      display: none; }
  /* line 151, _elements.shops.scss */
  .shop-page__form {
    min-width: 0; }
  /* line 154, _elements.shops.scss */
  .shop-page__gallery {
    margin: -20px 0 0; }
  /* line 157, _elements.shops.scss */
  .shop-page__text {
    margin: -20px 0 0; }
  /* line 160, _elements.shops.scss */
  .shop-page__back {
    display: flex;
    gap: 10px 20px;
    flex-wrap: wrap;
    margin: -20px 0; }

/* line 168, _elements.shops.scss */
.shop-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
  font-size: 14px;
  line-height: 20px; }
  /* line 174, _elements.shops.scss */
  .shop-info__item-title {
    font-size: 12px;
    line-height: 16px;
    color: var(--color-grey-l);
    margin: 0 0 2px; }
  /* line 179, _elements.shops.scss */
  .shop-info__item .is-description {
    color: var(--color-grey-l); }
  /* line 183, _elements.shops.scss */
  .shop-info .text {
    color: var(--color-black); }
  /* line 187, _elements.shops.scss */
  .shop-info .social_type_grid .social__item {
    background-color: var(--bg-grey-l); }

/* line 193, _elements.shops.scss */
.shop-gallery {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr); }
  @media (max-width: 767px) {
    /* line 193, _elements.shops.scss */
    .shop-gallery {
      gap: 10px;
      grid-template-columns: repeat(3, 1fr); } }
  @media (max-width: 575px) {
    /* line 193, _elements.shops.scss */
    .shop-gallery {
      grid-template-columns: repeat(2, 1fr); } }
  /* line 204, _elements.shops.scss */
  .shop-gallery__item {
    box-shadow: var(--shadow-s);
    border-radius: var(--radius);
    overflow: hidden;
    color: var(--color-black);
    background-color: var(--bg-grey); }
    @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
      /* line 204, _elements.shops.scss */
      .shop-gallery__item {
        transition: box-shadow 0.2s ease; } }
    @media (hover: none) {
      /* line 204, _elements.shops.scss */
      .shop-gallery__item {
        -webkit-tap-highlight-color: transparent; } }
    @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
      /* line 25, _mixins.scss */
      .shop-gallery__item:hover {
        color: var(--color-secondary);
        box-shadow: var(--shadow); }
        /* line 217, _elements.shops.scss */
        .shop-gallery__item:hover .thumb img {
          filter: brightness(80%);
          transform: scale(1.02); } }
    /* line 223, _elements.shops.scss */
    .shop-gallery__item .thumb {
      color: currentColor !important;
      --radius: 0; }
      @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
        /* line 226, _elements.shops.scss */
        .shop-gallery__item .thumb img {
          will-change: transform;
          transition: filter 0.6s ease, transform 0.6s ease; } }
    /* line 233, _elements.shops.scss */
    .shop-gallery__item .svg-icon {
      position: absolute;
      z-index: 5;
      left: 50%;
      top: 50%;
      padding: 2px;
      background-color: var(--bg-white);
      border-radius: 50%;
      box-shadow: var(--shadow-m);
      object-fit: none;
      width: 38px;
      height: 38px;
      transform: translate(-50%, -50%); }

/* line 250, _elements.shops.scss */
.shop-form {
  padding: 20px;
  border-radius: var(--radius);
  box-shadow: var(--shadow-s);
  display: flex;
  gap: 20px;
  flex-direction: column; }
  /* line 257, _elements.shops.scss */
  .shop-form__title {
    font-size: 24px;
    line-height: 28px;
    font-weight: var(--font-normal); }
  /* line 261, _elements.shops.scss */
  .shop-form__description {
    font-size: 14px;
    line-height: 20px;
    color: var(--color-grey-d); }
  /* line 265, _elements.shops.scss */
  .shop-form__button {
    white-space: nowrap; }
    @media (min-width: 1025px) {
      /* line 267, _elements.shops.scss */
      .shop-form__button .button {
        width: 100%; } }
    @media (max-width: 575px) {
      /* line 267, _elements.shops.scss */
      .shop-form__button .button {
        width: 100%; } }

@media (min-width: 1025px) {
  /* line 278, _elements.shops.scss */
  .shop-card__hours,
  .shop-card__phones,
  .shop-card__social,
  .shop-card__subway {
    margin-bottom: 13px; } }
