/* line 1, _elements.shops.scss */
.shops {
  display: flex;
  flex-direction: column;
  gap: 20px; }
  /* line 6, _elements.shops.scss */
  .shops__tags {
    margin: -5px 0 0; }
  /* line 10, _elements.shops.scss */
  .shops__preview {
    display: flex;
    flex-direction: column;
    gap: 20px 0; }

/* line 17, _elements.shops.scss */
.shop-preview {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  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 17, _elements.shops.scss */
    .shop-preview {
      transition: box-shadow 0.4s ease; } }
  @media (hover: none) {
    /* line 17, _elements.shops.scss */
    .shop-preview {
      -webkit-tap-highlight-color: transparent; } }
  @media (hover: hover), all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    /* line 25, _mixins.scss */
    .shop-preview:hover {
      box-shadow: var(--shadow); } }
  @media (max-width: 1024px) {
    /* line 17, _elements.shops.scss */
    .shop-preview {
      grid-template-columns: 1fr; } }
  /* line 37, _elements.shops.scss */
  .shop-preview__map {
    position: relative;
    min-height: 480px;
    min-width: 0;
    background-color: var(--bg-grey);
    isolation: isolate; }
    @media (max-width: 767px) {
      /* line 37, _elements.shops.scss */
      .shop-preview__map {
        min-height: auto;
        height: 360px; } }
    /* line 49, _elements.shops.scss */
    .shop-preview__map .alert-icon {
      position: absolute;
      z-index: 1;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      justify-content: center; }
    /* line 60, _elements.shops.scss */
    .shop-preview__map.is-loaded .alert-icon {
      display: none; }
    /* line 67, _elements.shops.scss */
    .shop-preview__map.is-visible .shop-preview__image {
      opacity: 0;
      pointer-events: none; }
  /* line 75, _elements.shops.scss */
  .shop-preview__image {
    position: absolute;
    inset: 0;
    z-index: 4;
    background-color: var(--bg-grey);
    transition: opacity 0.2s ease; }
    /* line 82, _elements.shops.scss */
    .shop-preview__image .thumb {
      --radius: 0;
      height: 100%; }
  /* line 88, _elements.shops.scss */
  .shop-preview__info {
    padding: 40px;
    min-width: 0; }
    @media (max-width: 767px) {
      /* line 88, _elements.shops.scss */
      .shop-preview__info {
        padding: 20px; } }
    @media (min-width: 575px) {
      /* line 99, _elements.shops.scss */
      .shop-preview__info .shop-info__item .social_type_list .social__items {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 10px 20px; } }

/* line 112, _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 120, _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 120, _elements.shops.scss */
      .shop-page.has-form {
        grid-template-columns: 1fr; } }
    /* line 132, _elements.shops.scss */
    .shop-page.has-form .shop-page__info {
      padding: 0; }
  @media (max-width: 767px) {
    /* line 112, _elements.shops.scss */
    .shop-page {
      grid-template-columns: 1fr; } }
  /* line 142, _elements.shops.scss */
  .shop-page__info {
    padding: 20px;
    min-width: 0; }
  /* line 147, _elements.shops.scss */
  .shop-page__map {
    position: relative;
    min-height: 480px;
    min-width: 0; }
    @media (max-width: 767px) {
      /* line 147, _elements.shops.scss */
      .shop-page__map {
        min-height: auto;
        height: 360px; } }
    /* line 157, _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 168, _elements.shops.scss */
    .shop-page__map.is-loaded .alert-icon {
      display: none; }
  /* line 174, _elements.shops.scss */
  .shop-page__form {
    min-width: 0; }
  /* line 178, _elements.shops.scss */
  .shop-page__gallery {
    margin: -20px 0 0; }
  /* line 182, _elements.shops.scss */
  .shop-page__text {
    margin: -20px 0 0; }
  /* line 186, _elements.shops.scss */
  .shop-page__back {
    display: flex;
    gap: 10px 20px;
    flex-wrap: wrap;
    margin: -20px 0; }

/* line 194, _elements.shops.scss */
.shop-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
  font-size: 14px;
  line-height: 20px; }
  /* line 201, _elements.shops.scss */
  .shop-info__item-title {
    font-size: 12px;
    line-height: 16px;
    color: var(--color-grey-l);
    margin: 0 0 2px; }
  /* line 207, _elements.shops.scss */
  .shop-info__item-metro {
    display: flex;
    align-items: center;
    gap: 0 5px; }
    /* line 212, _elements.shops.scss */
    .shop-info__item-metro > svg {
      display: block;
      width: 20px;
      height: 12px; }
  /* line 219, _elements.shops.scss */
  .shop-info__item .is-description {
    color: var(--color-grey-l); }
  /* line 224, _elements.shops.scss */
  .shop-info .text {
    color: var(--color-black); }
  /* line 229, _elements.shops.scss */
  .shop-info .social_type_grid .social__item {
    background-color: var(--bg-grey-l); }
  /* line 234, _elements.shops.scss */
  .shop-info__buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px; }
  /* line 244, _elements.shops.scss */
  .shop-info__map-toggle:not(.is-image) > :nth-child(1),
  .shop-info__map-toggle:not(.is-image) > :nth-child(2) {
    display: none; }
  /* line 252, _elements.shops.scss */
  .shop-info__map-toggle.is-image > :nth-child(3),
  .shop-info__map-toggle.is-image > :nth-child(4) {
    display: none; }

/* line 260, _elements.shops.scss */
.shop-gallery {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr); }
  @media (max-width: 767px) {
    /* line 260, _elements.shops.scss */
    .shop-gallery {
      gap: 10px;
      grid-template-columns: repeat(3, 1fr); } }
  @media (max-width: 575px) {
    /* line 260, _elements.shops.scss */
    .shop-gallery {
      grid-template-columns: repeat(2, 1fr); } }
  /* line 274, _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 274, _elements.shops.scss */
      .shop-gallery__item {
        transition: box-shadow 0.2s ease; } }
    @media (hover: none) {
      /* line 274, _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 290, _elements.shops.scss */
        .shop-gallery__item:hover .thumb img {
          filter: brightness(80%);
          transform: scale(1.02); } }
    /* line 297, _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 301, _elements.shops.scss */
        .shop-gallery__item .thumb img {
          will-change: transform;
          transition: filter 0.6s ease, transform 0.6s ease; } }
    /* line 309, _elements.shops.scss */
    .shop-gallery__item .icon-new {
      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;
      transform: translate(-50%, -50%); }

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