/* METRO i */
i.m_default {
    background-color: #ababab !important;
}
i.m_red {
    background-color: #d6083b !important;
}
i.m_purple {
    background-color: #702785 !important;
}
i.m_blue {
    background-color: #0078c9 !important;
}
i.m_green {
    background-color: #009a49 !important;
}
i.m_orange {
    background-color: #ea7125 !important;
}

a {
    color: #1392C6;
    text-decoration: none;
    -webkit-transition: color .3s;
    -moz-transition: color .3s;
    -o-transition: color .3s;
    transition: color .3s;
}
a:hover {
    color: #1B3285;
    text-decoration: none;
}
a:active {
    color: #1B3285;
    text-decoration: none;
}
a.no-decoration {
    text-decoration: none;
}
.list-filter-container {
    box-shadow: 0px 0.625em 0.625em rgba(0, 0, 0, 0.02);
}
.list-filter-container.sticky {
    position: sticky;
    top: -7em;
    z-index: 5;
    -webkit-transition: all .5s;
    -moz-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s;
}
.list-filter-container.sticky.top {
    top: 3.75em;
}
h4.ui-h4 {
    font-size: 1.5em;
    font-weight: 600;
    color: #333;
    line-height: 140%;
    display: inline-block;
    margin: 0;
    padding: 0 0 1.5em 0;
}
.ta-right {
    text-align: right;
}
.ui-nowrap {
    white-space: nowrap;
}

/* BUTTONS */
.ui-button {
    font-family: Roboto;
    font-style: normal;
    font-weight: 400;
    font-size: 1em;
    line-height: 2.5em;
    min-width: 2.5em;
    border-radius: 0.9375em;
    position: relative;
    display: inline-block;
    text-align: center;
    cursor: pointer;
    color: #333;
    border: 1px solid #D7D7D7;
    text-decoration: none;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.ui-button:hover {
    color: #333;
}
.ui-button.disabled {
    color: #aaa !important;
    font-weight: normal;
    background-color: #f9f9f9 !important;
    border: 1px solid #ccc !important;
    cursor: default;
}
.ui-button.size_24_14 {
    font-size: 0.875em;
    border-radius: 0.9333em;
    line-height: 1.714em;
    min-width: 1.714em;
}
.ui-button.size_24_15 {
    font-size: 0.9375em;
    border-radius: 1em;
    line-height: 1.625em;
    min-width: 1.625em;
}
.ui-button.size_28_14 {
    font-size: 0.875em;
    border-radius: 0.9333em;
    line-height: 2em;
    min-width: 2em;
}
.ui-button.size_30_14 {
    font-size: 0.875em;
    border-radius: 0.9333em;
    line-height: 2.1428em;
    min-width: 2.1428em;
}
.ui-button.size_30_15 {
    font-size: 0.9375em;
    border-radius: 1em;
    line-height: 2em;
    min-width: 2em;
}
.ui-button.size_30_15 .v3-icons-ruble {
    font-size: 0.75em;
}
.ui-button.size_36_15 {
    font-size: 0.9375em;
    border-radius: 1.15em;
    line-height: 2.25em;
    min-width: 2.25em;
}
.ui-button.size_40_15 {
    font-size: 0.9375em;
    border-radius: 1em;
    line-height: 2.5333em;
    min-width: 2.5333em;
}
.ui-button.size_40_16 {
    font-size: 1em;
    line-height: 2.375em;
    min-width: 2.375em;
}
.ui-button.size_50_15 {
    font-size: 0.9375em;
    border-radius: 1em;
    line-height: 3.2em;
    min-width: 3.2em;
}
.ui-button.size_50_16 {
    font-size: 1em;
    line-height: 3em;
    min-width: 3em;
}
.ui-button.size_60_16 {
    font-size: 1em;
    line-height: 3.625em;
    min-width: 3.625em;
}
.ui-button.size_60_18 {
    font-size: 1.125em;
    line-height: 3.2222em;
    min-width: 3.2222em;
}
.ui-button.white {
    background: #fff;
}
.ui-button.black {
    background: #444;
    border: 1px solid #444;
    color: #fff;
}
.ui-button.black:hover {
    background: #555;
    border: 1px solid #555;
}
.ui-button.black:active {
    background: #555;
    border: 1px solid #555;
}
.ui-button.gray {
    background: #f4f4f4;
    border: 1px solid #f4f4f4;
    color: #8a8a8a;
}
.ui-button.gray:hover {
    background: #fafafa;
    border: 1px solid #f4f4f4;
}
.ui-button.gray:active {
    background: #f4f4f4;
    border: 1px solid #f4f4f4;
}
.ui-button.gray.no_hover {
    background: #f4f4f4 !important;
    border: 1px solid #f4f4f4 !important;
}
.ui-button.light-blue {
    background-color: #e7f0ff;
    border: 1px solid #e7f0ff;
}
.ui-button.light-blue:hover {
    background-color: #eef4fd;
    border: 1px solid #e7f0ff;
}
.ui-button.light-blue:active {
    background-color: #eef4fd;
    border: 1px solid #e7f0ff;
}
.ui-button.border-blue {
    border: 1px solid #83B2FF;
}
.ui-button.border-blue:hover {
    border: 1px solid #83B2FF;
}
.ui-button.border-blue:active {
    border: 1px solid #83B2FF;
}
.ui-button.border-light-blue {
    background-color: #F1F7FF;
    border: 1px solid #83B2FF;
}
.ui-button.border-light-blue:hover {
    border: 1px solid #5092E3;
}
.ui-button.border-light-blue:active {
    background-color: #F1F7FF;
    border: 1px solid #83B2FF;
}
.ui-button.border-blue-white {
    background-color: #fff;
    border: 1px solid #d5e5ff;
}
.ui-button.border-blue-white:hover {
    background-color: #ebf3ff;
}
.ui-button.border-blue-white:active {
    background-color: #F1F7FF;
}
.ui-button.blue {
    color: #fff;
    background-color: #518cec;
    border: 1px solid #518cec;
}
.ui-button.blue:hover {
    background-color: #519eec;
    border: 1px solid #519eec;
}
.ui-button.blue:active {
    background-color: #519eec;
    border: 1px solid #519eec;
}
.ui-button.orange {
    color: #fff;
    background-color: #fc7418;
    border: 1px solid #fc7418;
}
.ui-button.orange:hover {
    background-color: #fd9c1f;
    border: 1px solid #fd9c1f;
}
.ui-button.orange.nohover:hover {
    background-color: #fc7418;
    border: 1px solid #fc7418;
}
.ui-button.orange:active {
    background-color: #fd9c1f;
    border: 1px solid #fd9c1f;
}
.ui-button.bronze {
    color: #fff;
    background-color: #E1A872;
    border: 1px solid #E1A872;
}
.ui-button.bronze:hover {
    background-color: #F8A960;
    border: 1px solid #F8A960;
}
.ui-button.bronze.nohover:hover {
    background-color: #E1A872;
    border: 1px solid #E1A872;
}
.ui-button.bronze:active {
    background-color: #E1A872;
    border: 1px solid #E1A872;
}
.ui-button.purple {
    color: #fff;
    background-color: #6EA1F5;
    border: 1px solid #6EA1F5;
}
.ui-button.purple:hover {
    background-color: #6EA1F5;
    border: 1px solid #6EA1F5;
}
.ui-button.purple.nohover:hover {
    background-color: #6EA1F5;
    border: 1px solid #6EA1F5;
}
.ui-button.purple:active {
    background-color: #6EA1F5;
    border: 1px solid #6EA1F5;
}
.ui-button.info {
    color: #B78C65;
    background-color: #FCF7EF;
    border: 1px solid #EFE9DF;
}
.ui-button.reset {
    color: #333;
    background-color: #fff;
    border: 1px solid #FF5A5A;
}
.ui-button.reset:hover {
    background-color: #fff1f1;
    border: 1px solid #FF5A5A;
}
.ui-button.reset.nohover:hover {
    background-color: #6EA1F5;
    border: 1px solid #FF5A5A;
}
.ui-button.reset:active {
    background-color: #fff1f1;
    border: 1px solid #FF5A5A;
}
.ui-button.black_font {
    color: #333 !important;
}
.ui-button.bold {
    font-weight: 600;
}
.ui-button.semibold {
    font-weight: 500;
}
.ui-button.padding_0_25 {
    padding: 0 0.25em;
}
.ui-button.padding_0_375 {
    padding: 0 0.375em;
}
.ui-button.size_30_15.padding_0_375 {
    padding: 0 0.4em;
}
.ui-button.padding_0_5 {
    padding: 0 0.5em;
}
.ui-button.padding_0_75 {
    padding: 0 0.75em;
}
.ui-button.padding_1 {
    padding: 0 1em;
}
.ui-button.padding_1_5 {
    padding: 0 1.5em;
}
.ui-button.padding_2 {
    padding: 0 2em;
}
.ui-button.full-width {
    width: 100%;
}
.ui-button.def_cursor {
    cursor: initial;
}
.ui-button.tr-line {
    background: transparent;
    border: none;
    color: #999;
    line-height: 120%;
}
.ui-button.tr-line > span {
    border-bottom: 1px dashed #999;
}

/* ui-content */
.ui-content-h1 {
    font-weight: 600;
    font-size: 1.75em;
    line-height: 140%;
    color: #333333;
    padding: 0 0 1em 0;
    margin: 0;
}
.ui-content-wrap {
    margin: 1.5em 0 2em 0;
    padding: 2em 1.5em;
}
.ui-content-wrap h3 {
    font-weight: bold;
    font-size: 1.5em;
    line-height: 160%;
    color: #333333;
    padding: 1em 0;
    margin: 0;
}
.ui-content-wrap .numbers {
    font-weight: bold;
    font-size: 1.125em;
    color: #0985CA;
}

/* ui-block */
.ui-block {
    background: #FFFFFF;
    border-radius: 1.25em;
    position: relative;
    -webkit-transition: box-shadow .3s;
    -moz-transition: box-shadow .3s;
    -o-transition: box-shadow .3s;
    transition: box-shadow .3s;
}
.ui-block.ovr-hidden {
    overflow: hidden;
}
.ui-block.margin-bottom-05 {
    margin-bottom: 0.5em;
}
.ui-block.margin-bottom-0625 {
    margin-bottom: 0.625em;
}
.ui-block.margin-bottom-075 {
    margin-bottom: 0.75em;
}
.ui-block.margin-bottom-1 {
    margin-bottom: 1em;
}
.ui-block.margin-bottom-1_5 {
    margin-bottom: 1.5em;
}
.ui-block.margin-bottom-2 {
    margin-bottom: 2em;
}
.ui-block.margin-bottom-3 {
    margin-bottom: 3em;
}
.ui-block.margin-top-1 {
    margin-top: 1em;
}
.ui-block.margin-top-2 {
    margin-top: 2em;
}
.ui-block.margin-top-3 {
    margin-top: 3em;
}
.ui-block.padding-1 {
    padding: 1em;
}
.ui-block.padding-2 {
    padding: 2em;
}
.ui-block.padding-1_25 {
    padding: 1.25em;
}
.ui-block.padding-1_5 {
    padding: 1.5em;
}
.ui-block.padding-2-2_5 {
    padding: 2em 2.5em;
}
.ui-block.padding-1_5-2 {
    padding: 1.5em 2em;
}
.bronze {
    background: #FCF7EF;
    border: 1px solid #F0E9DF;
}

.ui-column-2 {
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
    -webkit-column-gap: 1em;
    -moz-column-gap: 1em;
    column-gap: 1em;
}
.ui-column-3 {
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 1em;
    -moz-column-gap: 1em;
    column-gap: 1em;
}

/* ui-search-wrap */
.ui-search-wrap {
    padding: 1.25em;
    border: 1px solid #D7D7D7;
    background: #FFFFFF;
    border-radius: 1.25em;
    position: relative;
    margin-right: 10em;
}
.ui-search-wrap .sw_wrap {
    display: flex;
}
.ui-search-wrap .sw_wrap .sw_buttons_wrap {
    display: flex;
}
.ui-search-wrap .sw_wrap .th-item {
    padding: 0 0 0.75em 0;
    display: inline-block;
}
.ui-search-wrap .sw_wrap .sw_sizes_wrap,
.ui-search-wrap .sw_wrap .sw_price_wrap,
.ui-search-wrap .sw_wrap .sw_buttons_wrap .ui-button {
    margin-left: 0.75em;
}
.ui-search-wrap .sw_wrap .sw_buttons_wrap {
    padding: 2.25em 0 0 0;
}
.ui-search-wrap .sw_wrap .ui-filter_double_input input {
    font-size: 1em;
    padding: 0.75em;
}
.ui-search-wrap .sw_wrap .ui-filter_double_input input:nth-child(2n) {
    padding-right: 2em;
}
.ui-search-wrap .sw_wrap .ui-filter_double_input .unit {
    line-height: 3.333em;
}
.ui-search-help .search_help {
    padding-top: 1.1875em;
    display: flex;
    overflow: hidden;
}
.ui-search-help .search_help .link-carousel-title {
    line-height: 2.5em;
    font-weight: 500;
}
.ui-search-help .search_help .link-carousel {
    display: flex;
}
.ui-search-help .search_help .link-carousel .item {
    margin-left: 1.5em;
    margin-right: 100em;
}
.ui-search-help .search_help .link-carousel .item a {
    text-decoration: underline !important;
}


/* ui-mapcard */
.ui-mapcard {
    position: relative;
    padding: 0;
    background: #f1f1f1;
    overflow-x: hidden;
    overflow-y: scroll;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    /*overscroll-behavior: contain;*/
}
.ui-mapcard::-webkit-scrollbar {
    display: none;
}
.ui-mapcard .header {
    position: fixed;
    width: 23.75em;
    left: 0;
    top: 0;
    z-index: 15;
    display: flex;
    padding: 1.25em;
    background: #fff;
    cursor: grab;
    user-select: none;
    touch-action: none;
    border-radius: 1.25em;
    -webkit-transition: box-shadow .3s;
    -moz-transition: box-shadow .3s;
    -o-transition: box-shadow .3s;
    transition: box-shadow .3s;
}
.ui-mapcard .header.shadow {
    box-shadow: 0 0.25em 0.25em rgba(0,0,0,.075);
}
.ui-mapcard h3 {
    font-size: 1.125em;
    padding: 0 1.75em 0 0;
    margin: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.ui-mapcard h3 a {
    text-decoration: none;
    color: #333;
}
.ui-mapcard .obj-card {
    background: #fff;
    border-radius: 1.25em;
    padding: 3.875em 0 1.25em 0;
}
.ui-mapcard .image {
    position: relative;
    width: 100%;
}
.ui-mapcard .image .swiper {
    height: 14em;
    cursor: pointer;
}
.ui-mapcard .image .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 1.25em;
    cursor: pointer;
}
.ui-mapcard .image .swiper-slide:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 1.25em;
    background: linear-gradient(
            to bottom,
            rgba(0, 0, 0, 0.075) 0%,
            rgba(0, 0, 0, 0) 25%,
            rgba(0, 0, 0, 0) 75%,
            rgba(0, 0, 0, 0.05) 100%
    );
}
.ui-mapcard .image .img {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    overflow: hidden;
}
.ui-mapcard .image .img img {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    align-self: center;
}
.ui-mapcard .image .ui-class-bl {
    margin: 0 auto;
    position: absolute;
    bottom: -1em;
    left: 1.5625em;
}
.ui-mapcard .image .bottom_hide_block {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3em;
    background: -moz-linear-gradient(bottom, rgba(200,200,200,0.1) 0%,rgba(200,200,200,0) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(bottom, rgba(200,200,200,0.1) 0%,rgba(200,200,200,0) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to top, rgba(200,200,200,0.1) 0%,rgba(200,200,200,0) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0 );
}
.ui-mapcard .desc {
    padding: 1em 1.25em 0 1.25em;
}
.ui-mapcard .desc .address {
    font-size: 0.9375em;
    color: #999999;
}
.ui-mapcard .desc .address span {
    white-space: nowrap;
    overflow: hidden;
}
.ui-mapcard .desc .metro {
    padding: 0.125em 0 0 0;
    margin: 0;
}
.ui-mapcard .desc .metro ul {
    padding: 0;
    margin: 0;
    list-style: none;
    white-space: nowrap;
}
.ui-mapcard .desc .metro ul li {
    display: block;
    padding: 0 0.625em 0 0;
    color: #333333;
}
.ui-mapcard .desc .metro ul li i {
    margin: 0 0.5em 0 0;
    border-radius: 50%;
    width: 0.5em;
    height: 0.5em;
    display: inline-block;
}
.ui-mapcard .desc .metro ul li > span {
    font-size: 0.9375em;
}
.ui-mapcard .desc .metro .time {
    display: inline-block;
    padding: 0 0 0 0.75em;
    margin: 0;
    color: #999;
    font-size: 0.9375em;
}
.ui-mapcard .desc .metro .time span.walk {
    padding: 0 0 0 0.25em;
}
.ui-mapcard .desc .metro .time span.bus {
    padding: 0 0 0 0.5em;
}
.ui-mapcard .price_line {
    white-space: nowrap;
    padding: 1em 0 0 0;
}
.ui-mapcard .price_line > .ui-button,
.ui-mapcard .admin_line > .ui-button,
.ui-mapcard .admin_line .ui-dropdown-filter.inline {
    margin-right: 0.25em;
}
.ui-mapcard .ui-dropdown-filter.inline {
    margin-right: 0;
}
.ui-mapcard .scard_back_block {
    position: absolute !important;
    top: 0.9375em;
    right: 0.9375em;
}
.ui-mapcard .scard_back_block i {
    cursor: pointer;
    font-size: 1.25em;
}
.ui-mapcard .admin_line {
    position: absolute;
    z-index: 10;
    left: 2em;
    top: 0.5em;
    max-width: 20.375em;
}
.ui-mapcard .admin_line .ui-button span {
    padding: 0 0 0 0.25em;
    float: initial;
}
.ui-mapcard .admin_line .ui-dropdown-filter > .ui-button.show i {
    transform: initial;
}
.ui-mapcard .admin_line .ui-dropdown-filter .dropdown-menu {
    padding: 0.5em;
}
.ui-mapcard .button_line {
    padding: 1.25em 1.25em 0 1.25em;
}
.ui-mapcard .button_line .col-6:first-child {
    padding-right: 0.3125em;
}
.ui-mapcard .button_line .col-6:last-child {
    padding-left: 0.3125em;
}
.ui-mapcard .button_line i {
    margin-right: 0.5em;
}
.ui-mapcard .admin_line .ui-dropdown-filter > .ui-button i,
.ui-mapcard .right_buttons .ui-dropdown-filter > .ui-button i {
    margin-left: 0;
}
.ui-mapcard .size_filter_line {
    padding: 0.75em 1em;
    border-radius: 1.25em;
    margin: 0.75em 0.5em 0 0.5em;
    background: #fff;
}
.ui-mapcard .size_filter_line h5 {
    font-size: 0.9375em;
    line-height: 1em;
    font-weight: 400;
    margin: 0;
    padding: 0;
    color: #999;
    white-space: nowrap;
}
.ui-mapcard .size_filter_line h5 span {
    font-weight: 500;
    font-size: 1.125em;
    line-height: 1em;
    color: #333;
    padding-right: 0.25em;
    padding-top: 0.125em;
    padding-bottom: 0.375em;
    display: block;
}
.ui-mapcard .size_filter_line h5 span.one_offer {
    padding-top: 0.5625em;
}
.ui-mapcard .size_filter_line .right_buttons .ui-button {
    margin-left: 0.25em;
}
.ui-mapcard .size_filter_line .right_buttons .ui-button i {
    font-size: 1.3333em;
}
.ui-mapcard .size_filter_line .right_buttons .switch-hide-photo i {
    font-size: 1.466em;
    line-height: 1.5em;
    position: relative;
    top: 0.125em;
}
.ui-mapcard .size_filter_line .right_buttons .switch-hide-photo span {
    padding-left: 0.5em;
}
.ui-mapcard .sizes_table {
    padding: 0.75em 0 0 0;
}
.ui-mapcard.preloader h3,
.ui-mapcard.preloader .image,
.ui-mapcard.preloader .address,
.ui-mapcard.preloader .metro,
.ui-mapcard.preloader .ui-button {
    position: relative;
}
.ui-mapcard.preloader h3 {
    display: block;
    height: 1.5em;
    width: 14em;
    margin-bottom: 0.625em;
}
.ui-mapcard.preloader .image {
    width: calc(100% - 2.5em);
    height: 14em;
    left: 1.25em;
}
.ui-mapcard.preloader .image .card-preloader {
    border-radius: 0.9375em !important;
}
.ui-mapcard.preloader .address {
    display: block;
    height: 1.125em;
    max-width: 14em;
    margin-bottom: 0.5em;
    margin-top: 0.25em;
}
.ui-mapcard.preloader .metro {
    display: block;
    height: 1em;
    max-width: 10em;
    margin-bottom: 0.25em;
}
.ui-mapcard.preloader .price_line {
    margin-top: 0.25em;
}
.ui-mapcard.preloader .price_line .ui-button {
    width: 6em;
    height: 2.125em;
    border: none;
}
.ui-mapcard.preloader  .button_line {
    padding: 0.875em 1.25em 0 1.25em;
    height: 4em;
}
.ui-mapcard.preloader .button_line .ui-button {
    width: 100%;
    height: 3.125em;
    border: none;
}
.card-preloader {
    position: absolute;
    inset: 0;
    border-radius: 0.9375em;
    background: linear-gradient(
            90deg,
            #eee 25%,
            #f5f5f5 50%,
            #eee 75%
    );
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    z-index: 100;
}
@keyframes shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
.ui-gallary-btn {
    height: 2.25em !important;
    width: 2.25em !important;
    top: calc(50% + 0.25em) !important;
}
.ui-gallary-btn:after {
    font-size: 0.875em !important;
    color: #333;
}
.ui-gallary-btn.ui-similiar-btn {
    top: calc(50% - 1.125em) !important;
}
.ui-gallary-btn.ui-similiar-btn.swiper-button-prev {
    left: -3.5em;
}
.ui-gallary-btn.ui-similiar-btn.swiper-button-next {
    right: -3.5em;
}
.swiper-button-next {
    position: absolute !important;
    right: 0.5em;
}
.swiper-button-prev {
    position: absolute !important;
    left: 0.5em;
}
.swiper-button-lock {
    display: none !important;
}
.swiper-button-next.ui-gallary-btn:after {
    left: 1px;
}
.swiper-button-prev.ui-gallary-btn:after {
    left: -1px;
}
.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
    pointer-events: initial;
}

/* ui-filter */
.ui-dropdown-filter.inline {
    display: inline-block;
    margin-right: 0.375em;
}
.ui-dropdown-filter.half-width {
    width: 50%;
    display: inline-block;
}
.ui-dropdown-filter > .ui-button.padding_1 {
    padding-right: 1em !important;
}
.ui-dropdown-filter > .ui-button i {
    display: inline-block;
    position: relative;
    top: 0.0625em;
    font-size: 1em;
    line-height: 100%;
    margin-left: 0.5em;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.ui-dropdown-filter > .ui-button i.v3-icons-ruble {
    height: 0.875em;
    margin-left: 0.25em !important;
}
.ui-dropdown-filter > .ui-button.full-width i {
    display: inline-block;
    position: absolute;
    top: 0.0625em;
    right: 0.75em;
    font-size: 1em;
    line-height: 2.5em;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.ui-dropdown-filter > .ui-button.show > i {
    transform: rotate(180deg);
}
.ui-dropdown-filter > .ui-button span {
    /*float: left;*/
}
.ui-dropdown-filter .dropdown-menu,
.dropdown-menu.filter-dropdown-onbody {
    border-radius: 0.9375em;
    background: #fff;
    padding: 0;
    width: min-content;
    box-shadow: 0 0.025em 0.25em rgba(0, 0, 0, .2);
    border: none;
}
.ui-dropdown-filter .dropdown-menu ul.f-drop-menu,
.dropdown-menu.filter-dropdown-onbody ul.f-drop-menu {
    padding: 0;
    margin: 0;
    list-style: none;
    overflow: hidden;
    white-space: normal;
}
.ui-dropdown-filter .dropdown-menu ul.f-drop-menu li,
.dropdown-menu.filter-dropdown-onbody ul.f-drop-menu li {
    display: inline-block;
    padding: 0;
    width: 100%;
}
.ui-dropdown-filter .dropdown-menu ul.f-drop-menu li a,
.dropdown-menu.filter-dropdown-onbody ul.f-drop-menu li a {
    cursor: pointer;
    padding: 0.5em 1em;
    color: #333;
}
.ui-dropdown-filter .dropdown-menu ul.f-drop-menu li a:hover,
.ui-dropdown-filter .dropdown-menu ul.f-drop-menu li a:active,
.dropdown-menu.filter-dropdown-onbody ul.f-drop-menu li a:hover,
.dropdown-menu.filter-dropdown-onbody ul.f-drop-menu li a:active {
    background: #f7f8fa !important;
}
.ui-filter_double_input {
    position: relative;
    width: 100%;
    display: block;
    min-height: 2.5em;
}
.ui-filter_double_input input {
    width: 50%;
    float: left;
    border-radius: 0.9375em 0 0 0.9375em;
    background: #fff;
    border: 1px solid #d7d7d7;
    font-weight: normal;
    box-shadow: none !important;
    font-size: 0.9375em;
    padding: 0.5125em 0.75em;
}
#allfiltersModal .ui-filter_double_input input,
#allfiltersModal .dropdown > .ui-button {
    background: #fff;
    border: 1px solid #d7d7d7;
    text-align: left;
}
.ui-filter_double_input input:nth-child(2n) {
    border-radius: 0 0.9375em 0.9375em 0;
    margin-left: -1px;
    padding-right: 2em;
}
.ui-filter_double_input input.no-unit {
    padding-right: 0.75em !important;
}
.ui-filter_double_input.s_35_65 input {
    width: 35%;
}
.ui-filter_double_input.s_35_65 input:nth-child(2n) {
    width: 65%;
    padding-right: 7.25em;
}
.ui-filter_double_input.s_40_60 input {
    width: 40%;
}
.ui-filter_double_input.s_40_60 input:nth-child(2n) {
    width: 60%;
    padding-right: 6em;
}
.ui-filter_double_input input::-webkit-input-placeholder {
    font-size: 0.9375em;
}
.ui-filter_double_input .unit {
    position: absolute;
    top: 0;
    right: 0.75em;
    color: #333;
    line-height: 2.625em;
    font-size: 0.9375em;
}
.ui-rent-switcher {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    gap: 0.75em;
}
.ui-rent-switcher .switch {
    display: flex;
    background: #fff;
    border: 1px solid #d7d7d7;
    border-radius: 0.9375em;
    overflow: hidden;
}
.ui-rent-switcher .switch input {
    display: none;
}
.ui-rent-switcher .switch label {
    flex: 1;
    color: #333;
    text-align: center;
    font-size: 0.9375em;
    line-height: 2em;
    padding: 0 1em;
    cursor: pointer;
    white-space: nowrap;
    user-select: none;
    transition: all 0.2s ease;
    border-right: 1px solid #d7d7d7;
}
.ui-rent-switcher.big .switch label {
    line-height: 2.5333em;
}
.ui-rent-switcher .switch:hover input:checked + label,
.ui-rent-switcher .switch:hover label.checked {
    background: #fff;
}
.ui-rent-switcher .switch label:hover {
    background: #FCF7EF !important;
}
.ui-rent-switcher .switch label:last-child {
    border-right: none;
}
.ui-rent-switcher .switch input:checked + label,
.ui-rent-switcher .switch label.checked
{
    background: #FCF7EF;
}
.ui-rent-switcher.big .switch label i {
    font-size: 1.25em !important;
    margin-left: 0;
    margin-right: 0.5em;
    top: 0.125em;
    position: relative;
}
.ui-filter_double_input .unit .valute {
    display: inline-block;
    color: #999;
    border-bottom: 1px dashed #999;
    line-height: 1em;
    text-decoration: none;
    cursor: pointer;
}
.ui-filter_double_input .unit .v3-icons-ruble {
    position: relative;
    font-size: 0.875em;
    top: 0.125em;
    margin-right: 0.25em;
}
ul.ui-filter_modal_list {
    list-style: none;
    padding: 0;
    margin: 0;
}
ul.ui-filter_modal_list.column-2 {
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
    -webkit-column-gap: 2em;
    -moz-column-gap: 2em;
    column-gap: 2em;
}
ul.ui-filter_modal_list.column-3 {
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 3.125em;
    -moz-column-gap: 3.125em;
    column-gap: 3.125em;
}
ul.ui-filter_modal_list.column-4 {
    -webkit-column-count: 4;
    -moz-column-count: 4;
    column-count: 4;
    -webkit-column-gap: 2em;
    -moz-column-gap: 2em;
    column-gap: 2em;
}
ul.ui-filter_modal_list.column-6 {
    -webkit-column-count: 6;
    -moz-column-count: 6;
    column-count: 6;
    -webkit-column-gap: 1.75em;
    -moz-column-gap: 1.75em;
    column-gap: 1.75em;
}
ul.ui-filter_modal_list li {
    position: relative;
    padding: 0.125em 0;
}
ul.ui-filter_modal_list.filter_modal_list-allfilters {
    margin: 0;
}
ul.ui-filter_modal_list.filter_modal_list-allfilters li {
    padding: 0.625em 0;
    border-top: 1px solid #ededed;
}
ul.ui-filter_modal_list.filter_modal_list-allfilters li:first-child {
    border-top: none !important;
}
.ui-checkbox input[type="checkbox"] {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}
.ui-checkbox label {
    position: relative;
    display: inline-block;
    padding-left: 1.875em;
    font-size: 0.9375em;
    line-height: 180%;
}
.ui-checkbox label::before,
.ui-checkbox label::after {
    position: absolute;
    display: inline-block;
}
.ui-checkbox label::before{
    content: "";
    height: 1.25em;
    width: 1.25em;
    border: 1px solid #d7d7d7;
    background: #f9f9f9;
    left: 0;
    top: 0.1875em;
    border-radius: 0.4375em;
}
.ui-checkbox input[type="checkbox"]:checked + label::before {
    background: #518cec;
    border: 1px solid #518cec !important;
}
.ui-checkbox label.error::before{
    border: 1px solid red;
}
.ui-checkbox label::after {
    content: "\e919";
    opacity: 0;
    left: 0.2857em;
    top: 0.5714em;
    font-size: 0.8125em;
    color: #fff;
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.ui-checkbox input[type="checkbox"]:checked + label::after {
    opacity: 1;
}

/* ui-size-item */
.ui-size-item {
    background: #fff;
    margin: 0 0.5em 0.75em 0.5em;
}
.ui-size-item.adminonly:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    border: 3px solid #d0bdf4;
    border-radius: 1.25em;
    pointer-events: none;
}
.ui-size-item a {
    text-decoration: none;
}
.ui-size-item .image_container {
    width: 100%;
    height: 9.75em;
    border-radius: 0.9375em 0.9375em 0 0;
    overflow: hidden;
    padding: 0.75em 0 0 0;
    position: relative;
}
.ui-size-item .image_container .swiper {
    height: 9em;
    cursor: pointer;
}
.ui-size-item .image_container .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 1em;
    cursor: pointer;
}
.ui-size-item .image_container .swiper-slide:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 1em;
    background: linear-gradient(
            to bottom,
            rgba(0, 0, 0, 0.075) 0%,
            rgba(0, 0, 0, 0) 25%,
            rgba(0, 0, 0, 0) 75%,
            rgba(0, 0, 0, 0.05) 100%
    );
}
.ui-size-item .desc {
    position: relative;
    padding: 1.25em 1em 1em 1em;
}
.ui-size-item .desc .size_header_line {
    display: flex;
    align-items: center;
    overflow: hidden;
    gap: 0;
    white-space: nowrap;
    text-overflow: ellipsis;
    width: 100%;
    padding: 0 0 0.25em 0;
}
.ui-size-item .desc h4 {
    display: inline-block;
    font-size: 1em;
    font-weight: 500;
    color: #333;
    margin: 0;
    padding: 0;
}
.ui-size-item .desc .floor,
.ui-size-item .desc .layout {
    position: relative;
    display: inline-block;
    font-size: 1em;
    font-weight: 500;
    color: #333;
    padding: 0 0 0 1.5em;
}
.ui-size-item .desc .layout {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ui-size-item .desc .floor:before,
.ui-size-item .desc .layout:before {
    content: "";
    position: absolute;
    left: 0.5625em;
    top: 0.5625em;
    background: #c3d0e6;
    border-radius: 0.375em;
    width: 0.375em;
    height: 0.375em;
}
.ui-size-item .desc .price {
    padding: 0.25em 0.5em 0 0;
    display: inline-block;
}
.ui-size-item .desc .price .cost {
    font-size: 1.125em;
    font-weight: 500;
    color: #333;
    padding: 0 0.25em 0 0;
}
.ui-size-item .desc .price i.v3-icons-ruble {
    font-size: 0.875em;
    font-weight: 600;
}
.ui-size-item .desc .price .cw-unit {
    color: #999;
    line-height: 120%;
    font-size: 0.9375em;
    margin-left: 0.25em;
    margin-right: -0.25em;
}
.ui-size-item .desc .price .dropdown {
    margin-left: 0.25em;
}
.ui-size-item .desc .price .on_request {
    color: #999;
}
.ui-size-item .desc .dop_price {
    display: inline-block;
    padding: 0.25em 0 0 0;
    color: #999;
}
.ui-size-item .desc .dop_price span {
    font-size: 0.9375em;
}
.ui-size-item .comment {
    padding: 0 1em 1em 1em;
    border-radius: 0.9375em;
}
.ui-size-item .comment .alert {
    margin: 0;
    border-radius: 1.14em;
    font-size: 0.875em;
    line-height: 1.25em;
    padding: 0.875em;
    overflow: hidden;
}
.ui-size-item .size_button_line {
    padding: 0em 1em 1em 1em;
}
.ui-mapcard .size_button_line .col-6:first-child {
    padding-right: 0.3125em;
}
.ui-mapcard .size_button_line .col-6:last-child {
    padding-left: 0.3125em;
}
.ui-mapcard .size_button_line i {
    margin-right: 0.5em;
}
.ui-size-item.preloader {
    padding-top: 0.75em;
}
.ui-size-item.preloader h4,
.ui-size-item.preloader .floor,
.ui-size-item.preloader .price,
.ui-size-item.preloader .dop_price {
    position: relative;
}
.ui-size-item.preloader .image {
    width: calc(100% - 1.5em);
    height: 9em;
    left: 0.75em;
}
.ui-size-item.preloader .image .card-preloader {
    border-radius: 0.9375em;
}
.ui-size-item.preloader h4 {
    display: block;
    height: 1.25em;
    width: 8em;
    margin-bottom: 0.625em;
}
.ui-size-item.preloader .floor {
    position: absolute;
    top: 1.45em;
    right: 1.333em;
    display: block;
    height: 1.25em;
    width: 4em;
}
.ui-size-item.preloader .price {
    display: block;
    height: 1em;
    width: 11em;
    margin-bottom: 0.75em;
}
.ui-size-item.preloader .dop_price {
    display: block;
    height: 1em;
    width: 15em;
    margin-bottom: 0;
}
.ui-size-item.preloader .size_button_line .ui-button {
    height: 2.666em;
    border: none;
}

    /* Modal */
.modal-dialog:not(.top_modal) {
    min-height: calc(100vh - 60px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
@media(max-width: 768px) {
    .modal-dialog:not(.top_modal) {
        min-height: calc(100vh - 20px);
    }
}
.modal input[type="text"].error {
    border: 1px solid red !important;
}
.modal-content {
    border: none;
    border-radius: 1.25em;
    background: #f7f8fa;
}
.modal-header,
.modal-body {
    padding: 0.625em 1.75em;
}
.modal-header {
    position: relative;
    background: #fff;
    border-bottom: none;
    border-radius: 1.25em 1.25em 0 0;
    padding-top: 0;
    padding-bottom: 0;
}
.modal-header h3 {
    color: #333333;
    font-size: 1.25em;
    font-weight: 500;
    line-height: 1.5em;
    padding: 1em;
    text-align: center;
    width: 100%;
    border-bottom: 1px solid #E5E5E5;
}
.modal-body {
    background: #fff;
    border-radius: 0 0 1.25em 1.25em;
    box-shadow: 0 0.1em 0.1em rgba(0, 0, 0, .05);
    margin-bottom: 0.25em;
}
.modal-body.no-shadow {
    box-shadow: none;
    margin-bottom: 0;
}
.modal-body h5 {
    color: #333333;
    font-size: 1em;
    font-weight: bold;
    line-height: 140%;
    padding: 1em 0 0.5em 0;
    margin: 0;
}
.modal-header .close {
    position: absolute;
    top: 1.125em;
    right: 1.125em;
    font-size: 1.375em;
    cursor: pointer;
    line-height: 100%;
    padding: 0;
    color: #999;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.modal-body .line-container {
    padding-bottom: 1em;
}
.modal-body .line-container.mt-025 {
    padding-top: 0.25em;
}
.modal-body .line-container.mt-05 {
    padding-top: 0.5em;
}
.modal-body .line-container.mb-05 {
    padding-bottom: 0.5em;
}
.modal-body .close {
    font-size: 0.875em;
    cursor: pointer;
    line-height: 140%;
    padding: 0;
    margin: 0.5em -0.5em 0 0;
    color: #999;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.modal-body .modal-sepenter {
    width: 100%;
    border-bottom: 1px solid #E5E5E5;
    margin: 0.75em 0;
}
.modal-footer {
    padding: 1.25em 1.75em;
    border-top: none;
    position: -webkit-sticky;
    position: -moz-sticky;
    position: -ms-sticky;
    position: -o-sticky;
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(247, 248, 259, 0.9);
    z-index: 1;
    border-radius: 0 0 1.25em 1.25em;
    width: 100%;
    justify-content: left;
}
.modal-footer > * {
    margin: 0;
}
.agree_conf {
    font-size: 0.8125em;
    line-height: 150%;
    color: #999;
    display: inline-block;
    padding: 0;
}
.agree_conf.bottom {
    padding-top: 1em;
}
@media (max-width: 575px) {
    .agree_conf {
        padding-top: 1em;
    }
}
.modal-dialog .thanks {
    padding: 1.5em 1.75em;
    background: #fff;
    border-radius: 0 0 1.25em 1.25em;
}
.modal-dialog .thanks .title {
    padding: 0 0 1em 0;
    font-weight: 500;
}
.modal-dialog .thanks .text {
    padding: 0 0 0.5em 0;
}


/* YA API V3 */
.circle-content {
    font-size: 0.75em;
    display: block;
    background: #fff;
    color: #333;
    text-align: center;
    border-radius: 2em;
    border: 0.4375em solid #6EA1F5;
    width: 3.5em;
    height: 3.5em;
    line-height: 2.75em;
    cursor: pointer;
}
.circle-content:before {
    content: "";
    top: -0.25em;
    left: -0.25em;
    position: absolute;
    width: 4em;
    height: 4em;
    border-radius: 2em;
    background: #fff;
    opacity: 0.7;
    z-index: -1;
}
.marker_dot_wrap {
    position: relative;
    cursor: pointer;
}
.marker_dot_wrap:hover .marker_dot_value {
    display: block;
}
.marker_dot_wrap .marker_dot {
    display: block;
    background: #0985CA;
    width: 0.5625em;
    height: 0.5625em;
    border-radius: 0.5em;
    transform:translate(-50%, -50%);
}
.marker_dot_wrap .marker_dot:after {
    content: "";
    position: absolute;
    bottom: -0.6875em;
    left: 0.2812em;
    transform:translate(-50%, -50%);
    display: inline-block;
    border: 0.6em solid transparent;
    border-top: 0.6em solid #cdcdcd;
}
.marker_dot_wrap .marker_dot.adminonly:after {
    border-top: 0.6em solid #705EE7;
}
.marker_dot_wrap .marker_dot:before {
    content: "";
    position: absolute;
    bottom: -0.75em;
    left: 50%;
    transform:translate(-50%, -50%);
    width: 1em;
    height: 1em;
    border-radius: 1em;
    background: #6EA1F5;
    opacity: 0.3;
    z-index: -1;
}
.marker_dot_wrap.active .marker_dot {
    background: #5FC149 !important;
}
.marker_dot_wrap.active .marker_dot:before {
    background: #5FC149;
}
.marker_dot_wrap .marker_dot_value {
    position: absolute;
    font-size: 0.875em;
    font-weight: 500;
    color: #333;
    top: -1.5625em;
    left: 0;
    transform:translate(-50%, -50%);
    padding: 0.125em 0.5em 0.125em 0.5em;
    display: block;
    background: #F8FBFE;
    border-radius: 1em;
    white-space: nowrap;
    box-shadow: 0 0 0.5em rgba(0, 0, 0, 0.4);
}
.marker_dot_wrap.active .marker_dot_value {
    border: 1px solid #5FC149 !important;
    background: #f4fff2 !important;
}
.marker_dot_wrap .marker_dot_value.adminonly {
    background: #EBE8FF;
    border: 1px solid #705EE7;
}
.marker_dot_wrap .marker_dot_value:before {
    content: "";
    position: absolute;
    bottom: -0.7em;
    left: 50%;
    transform:translate(-50%, -50%);
    display: inline-block;
    border: 0.25em solid transparent;
    border-top: 0.25em solid #F1F7FF;
}
.marker_dot_wrap.active .marker_dot:after {
    border-top: 0.6em solid #5FC149 !important;
}
.marker_dot_wrap .marker_dot_value.adminonly:before {
    border-top: 0.25em solid #EBE8FF;
}
.marker_dot_wrap:hover .marker_dot_value {
    box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.55);
}
.marker_dot_wrap .marker_dot_value .count {
    position: relative;
    left: -0.375em;
    display: inline-block;
    background: #518cec;
    color: #fff;
    border-radius: 1em;
    text-align: center;
    line-height: 1.75em;
    min-width: 1.75em;
    padding: 0 0.5em;
}
.marker_dot_wrap.active .marker_dot_value .count:not(.contract) {
    background: #5FC149 !important;
}
.marker_dot_wrap .marker_dot_value .count.small {
    line-height: 0.75em;
    min-width: 0.75em;
    padding: 0;
    left: 0;
    margin-right: 0.375em;
}
.marker_dot_wrap .marker_dot_value .count.red {
    background: #FF5A5A;
}
.marker_dot_wrap .marker_dot_value .count.violet {
    background: #705EE7;
}
.marker_dot_wrap .marker_dot_value .count.yellow {
    background: #EACB2E;
}
.marker_dot_wrap .marker_dot_value .count.green {
    background: #5FC149;
}
.marker_dot_wrap .marker_dot_value .text {
    display: inline-block;
    font-size: 0.928em;
}
.map-zoom-control {
    display: flex;
    flex-direction: column;
    gap: 0.5em;
    position: absolute;
    top: 50%;
    top: calc(50% - 1em);
    left: 1em;
}
.map-zoom-control .zoom-btn {
    width: 2em;
    height: 2em;
    background: #fff;
    border-radius: 0.625em;
    font-size: 1.25em;
    cursor: pointer;
    text-align: center;
    line-height: 2em;
    user-select: none;
    box-shadow: 0 0.1em 0.25em rgba(0,0,0,.2);
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.map-zoom-control .zoom-btn:hover {
    box-shadow: 0 0.1em 0.25em rgba(0,0,0,.3);
    background: #fefefe;
}

/* ui-list-card */
.list_block .row.items {
    --bs-gutter-x: 1rem;
}
.ui-list-card {
    position: relative;
    height: 34.6875em;
    padding: 0 0 4.125em 0;
    margin-bottom: 1em;
    overflow: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    /*overscroll-behavior: contain;*/
}
.ui-list-card.similiar-card {
    height: inherit;
    padding: 0;
}
.ui-list-card .image_container {
    width: 100%;
    height: 12.9375em;
    border-radius: 0.9375em 0.9375em 0 0;
    overflow: hidden;
    padding: 0.9375em 0 0 0;
    position: relative;
}
.ui-list-card .image_container.one-img {
    padding: 0;
    border-radius: 0.9375em;
    height: 11em;
}
.ui-list-card .image_container.one-img .img {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}
.ui-list-card .image_container.one-img img {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    align-self: center;
}
.ui-list-card.similiar-card .class-bl {
    padding: 0.5em 0.5em 0 0.5em;
}
.ui-list-card .image_container .swiper {
    height: 12em;
    cursor: pointer;
}
.ui-list-card .image_container .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 1em;
    cursor: pointer;
}
.ui-list-card .image_container .swiper-slide:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 1em;
    background: linear-gradient(
            to bottom,
            rgba(0, 0, 0, 0.075) 0%,
            rgba(0, 0, 0, 0) 25%,
            rgba(0, 0, 0, 0) 75%,
            rgba(0, 0, 0, 0.05) 100%
    );
}
.ui-list-card .class-bl {
    --active-radius: 0.9375em;
    --active-color: #fff;
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 0.5em 0 0 0.5em;
    z-index: 1;
    background: var(--active-color);
    border-radius: var(--active-radius) 0 0 0;
    white-space: nowrap;
}
.ui-list-card .class-bl::before,
.ui-list-card .class-bl::after {
    content: '';
    display: block;
    width: var(--active-radius);
    height: var(--active-radius);
    background-size: calc(var(--active-radius)) calc(var(--active-radius));
    position: absolute;
    bottom: 0;
}
.ui-list-card .class-bl::before {
    background-image: radial-gradient(circle at top left, transparent 70%, var(--active-color) 70%);
    left: calc(var(--active-radius) * -1);
}
.ui-list-card .class-bl::after {
    background-image: radial-gradient(circle at top left, transparent 70%, var(--active-color) 70%);
    background-position: 100% 0;
    top: calc(var(--active-radius) * -1);
    right: 0;
}
.ui-list-card .class-bl > .ui-button {
    margin-right: 0.25em;
}
.ui-list-card .class-bl > .ui-button:last-child {
    margin-right: 0;
}
.ui-list-card .inner-list-container {
    padding: 1.25em;
}
.ui-list-card .inner-list-container h3 {
    font-size: 1.125em;
    padding: 0 0 0.625em 0;
    margin: 0;
}
.ui-list-card .inner-list-container h3 a {
    font-weight: 500;
    color: #333;
    text-decoration: none;
    display: flex;
    gap: 0.25em;
    align-items: center;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    width: 100%;
}
.ui-list-card.similiar-card .inner-list-container h3 a {
    line-height: 1.5em;
}
.ui-list-card .inner-list-container h3 a span.floor {
    font-size: 0.83333em;
    font-weight: 400;
    color: #999;
    padding-left: 0.25em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ui-list-card .inner-list-container .price {
    padding: 0;
    white-space: nowrap;
}
.ui-list-card .inner-list-container .price .cost {
    font-size: 1.125em;
    font-weight: 500;
    color: #333;
    padding: 0 0.25em 0 0;
}
.ui-list-card .inner-list-container .price i.v3-icons-ruble {
    font-size: 0.875em;
    font-weight: 600;
}
.ui-list-card .inner-list-container .price .cw-unit {
    color: #999;
    line-height: 120%;
    font-size: 0.9375em;
    margin-left: 0.25em;
    margin-right: -0.25em;
}
.ui-list-card .inner-list-container .price .dropdown {
    margin-left: 0.25em;
}
.ui-list-card .inner-list-container .price .on_request {
    color: #999;
}
.ui-list-card .inner-list-container .dop_price {
    display: block;
    padding: 0.25em 0 0 0;
    color: #999;
}
.ui-list-card .inner-list-container .dop_price .plus_line {
    font-size: 0.9375em;
}
.ui-list-card .inner-list-container .dop_price .v3-icons-ruble {
    font-size: 0.8125em;
    opacity: 0.5;
}
.ui-list-card .inner-list-container .address {
    padding: 1em 0 0 0;
    font-size: 0.9375em;
    color: #333;
}
.ui-list-card .inner-list-container .obj_address {
    display: block;
    padding: 0;
    color: #999;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    width: 100%;
}
.ui-list-card.similiar-card .inner-list-container .obj_address {
    font-size: 0.9375em;
}
.ui-list-card .inner-list-container .metro {
    padding: 0.125em 0 0 0;
    margin: 0;
}
.ui-list-card .inner-list-container .metro ul {
    padding: 0;
    margin: 0;
    list-style: none;
    align-items: center;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    width: 100%;
}
.ui-list-card .inner-list-container .metro ul li {
    display: block;
    color: #333333;
    font-size: 0.9375em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ui-list-card .inner-list-container .metro ul li i {
    margin: 0 0.5em 0 0;
    border-radius: 50%;
    width: 0.5em;
    height: 0.5em;
    display: inline-block;
}
.ui-list-card .inner-list-container .metro .time {
    display: inline-block;
    padding: 0 0 0 0.75em;
    margin: 0;
    color: #999;
}
.ui-list-card .inner-list-container .metro .time span.walk {
    padding: 0 0 0 0.25em;
}
.ui-list-card .inner-list-container .metro .time span.bus {
    padding: 0 0 0 0.5em;
}
.ui-list-card .inner-list-container .size_price_line {
    padding: 1em 0 0 0;
    white-space: nowrap;
}
.ui-list-card .inner-list-container .size_price_line .ui-button {
    margin-right: 0.5em;
}
.ui-list-card .inner-list-container .description {
    padding: 1.25em 0 0 0;
    font-size: 0.9375em;
    font-weight: 300;
    color: #999;
    line-clamp: 3;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}
.ui-list-card .inner-list-container .description.clamp_desc_1 {line-clamp: 1; -webkit-line-clamp: 1;}
.ui-list-card .inner-list-container .description.clamp_desc_2 {line-clamp: 2; -webkit-line-clamp: 2;}
.ui-list-card .inner-list-container .description.clamp_desc_3 {line-clamp: 3; -webkit-line-clamp: 3;}
.ui-list-card .inner-list-container .description.clamp_desc_4 {line-clamp: 4; -webkit-line-clamp: 4;}
.ui-list-card .inner-list-container .description.clamp_desc_5 {line-clamp: 5; -webkit-line-clamp: 5;}
.ui-list-card .inner-list-container .description p {
    margin: 0;
}
.ui-list-card .inner-list-container .description strong {
    font-weight: 400;
}
.ui-list-card .inner-list-container .button_line {
    position: absolute;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 1em;
    background: #fff;
}
.ui-list-card .inner-list-container .button_line a > i {
    position: relative;
    top: 0.125em;
    font-size: 1.375em;
    line-height: 1em;
    font-weight: 600;
}
.ui-list-card .inner-list-container .button_line a.phone {
    width: 3.125em;
}

/*  ui-obj-size-item */
.ui-obj-size-item.adminonly:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    border: 3px solid #d0bdf4;
    border-radius: 1.25em;
    pointer-events: none;
}
.ui-obj-size-item .image {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: 1.25em;
    overflow: hidden;
}
.ui-obj-size-item .image.one-img {
    min-height: 6.5em;
    cursor: pointer;
}
.ui-obj-size-item.mini .image.one-img {
    min-height: 5em;
}
.ui-obj-size-item .image.one-img:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 1em;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.075) 0%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.05) 100%);
}
.ui-obj-size-item .image.one-img .img {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}
.ui-obj-size-item .image.one-img img {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    align-self: center;
}
.ui-obj-size-item .image .swiper {
    height: 100%;
    cursor: pointer;
}
.ui-obj-size-item .image .swiper-slide:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 1em;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.075) 0%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0.05) 100%);
}
.ui-obj-size-item .image .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
}
.ui-obj-size-item .class-bl {
    left: 0;
    padding: 0.5em;
    background: transparent;
    white-space: nowrap;
    --active-radius: 0.9375em;
    --active-color: #fff;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
}
.ui-obj-size-item .ui-list-card .class-bl > .ui-button {
    margin: 0.375em 0 0 0;
    background: rgba(0, 0, 0, 0.5);
    border: none;
    font-size: 0.875em;
    font-weight: 500;
}
.ui-obj-size-item .ui-list-card .class-bl > .ui-button:last-child {
    margin-right: 0;
}
.ui-obj-size-item .image.motion-pagination .swiper-pagination {
    left: 0.5em;
}
.ui-obj-size-item .desc {
    padding: 1.375em 0 0 0;
}
.ui-obj-size-item.mini .desc {
    padding: 1em 0;
}
.ui-obj-size-item .desc h3 {
    font-size: 1.125em;
    color: #333;
    margin: 0;
    padding: 0 0 0.75em 0;
    position: relative;
}
.ui-obj-size-item.mini .desc h3 {
    font-size: 1em;
    padding: 0 0.5em 0.25em 0;
}
.ui-obj-size-item .desc h3 a {
    color: #333;
    text-decoration: none;
}
.ui-obj-size-item .desc h3 a:hover {
    text-decoration: underline;
}
.ui-obj-size-item .desc h3 span.info {
    position: relative;
    top: -0.125em;
    display: inline-block;
    font-size: 0.875em;
    margin-left: 0.5em;
    font-weight: 400;
    background: #FCF7EF;
    border: 1px solid #E1A872;
    color: #E1A872;
    border-radius: 2em;
    width: 1.35em;
    line-height: 1.25em;
    text-align: center;
    cursor: pointer;
}
.ui-obj-size-item .desc h3 span[tooltip]:before,
.ui-obj-size-item .desc h3 span[tooltip]:after {
    font-size: 0.9375em;
}
.ui-obj-size-item [tooltip]:not([flow])::before,
.ui-obj-size-item [tooltip][flow^="up"]::before {
    bottom: calc(100% + 5px);
}
.ui-obj-size-item [tooltip]:not([flow])::after,
.ui-obj-size-item [tooltip][flow^="up"]::after {
    bottom: calc(100% + 10px);
}
.ui-obj-size-item .desc .floor {
    font-size: 0.9375em;
    color: #999;
    line-height: 1.5em;
    padding: 0 0.75em 1em 0;
}
.ui-obj-size-item.mini .desc .floor {
    padding: 0 0.75em 0 0;
}
.ui-obj-size-item .price_wrap {
    padding: 1.3125em 0 0 0;
}
.ui-obj-size-item .price {
    margin: 0;
    padding: 0 0 0.75em 0;
    position: relative;
}
.ui-obj-size-item .price .cost {
    font-size: 1.125em;
    font-weight: 500;
    color: #333;
    padding: 0 0.25em 0 0;
}
.ui-obj-size-item .price i.v3-icons-ruble {
    font-size: 0.875em;
    font-weight: 600;
}
.ui-obj-size-item .price .cw-unit {
    color: #999;
    line-height: 120%;
    font-size: 0.9375em;
    margin-left: 0.25em;
    margin-right: -0.25em;
}
.ui-obj-size-item .price .dropdown {
    margin-left: 0.25em;
}
.ui-obj-size-item.price .on_request {
    color: #999;
}
.ui-obj-size-item .dop_price {
    font-size: 0.9375em;
    color: #999;
    line-height: 1.5em;
    padding: 0 0.75em 1em 0;
}
.ui-obj-size-item .address {
    font-size: 0.9375em;
    color: #999;
    line-height: 1.5em;
    position: relative;
    padding: 0 1em 1.375em 0;
}
.ui-obj-size-item.mini .broker {
    display: inline-block;
    padding: 0;
    font-size: 0.875em;
    color: #0985CA;
    line-height: 125%;
}
.ui-obj-size-item.preloader .desc,
.ui-obj-size-item.preloader .price,
.ui-obj-size-item.preloader .address {
    height: 2em;
    margin: 0.25em 0 0 0;
}
.ui-obj-size-item.preloader .address {
    padding: 1em 0;
}
.ui-obj-size-item .card-preloader {
    z-index: 0;
}
.ui-obj-size-item .desc .card-preloader,
.ui-obj-size-item .price .card-preloader,
.ui-obj-size-item .address .card-preloader
{
    height: 1em;
    width: 50%;
}
.left-nar-col .ui-button.preloader {
    cursor: default;
}
.left-nar-col .ui-button.preloader .card-preloader {
    z-index: 0;
}

.ui-obj-size-item .address .card-preloader {
    line-height: 3em;
}

/* recaptcha */
.ui-recaptcha {
    padding: 0 0 0.5em 0;
}
.ui-recaptcha > div {
    width: 100% !important;
}
.ui-recaptcha.mini iframe {
    max-width: 100%;
    height: 76px;
    border-radius: 5px;
    outline: 1px solid #d4d4d4;
    outline-offset: -1px;
}
.error_captcha {
    color: red;
    padding: 0 0 0.5em 0;
    font-size: 0.875em;
}

/* ui-record-viewing */
.ui-record-viewing .obj-item .image {
    position: relative;
    border-radius: 0.625em;
    width: 100%;
    height: 100%;
    min-height: 4em;
    overflow: hidden;
    box-shadow: 0px 0px 3px rgba(0,0,0,0.1);
}
.ui-record-viewing .obj-item .image .img {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}
.ui-record-viewing .obj-item .image .img img {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    align-self: center;
}
.ui-record-viewing .obj-item .desc h3 {
    font-family: Roboto;
    font-style: normal;
    font-weight: bold;
    font-size: 1em;
    margin-bottom: 0.25em;
    line-height: 140%;
    color: #0985CA;
}
.ui-record-viewing .obj-item .desc .address {
    font-size: 0.875em;
    line-height: 140%;
    color: #999999;
}
.ui-record-viewing .viewing-time {
    padding: 1.5em 0;
}
.ui-record-viewing h4 {
    font-family: Roboto;
    font-style: normal;
    font-weight: bold;
    font-size: 0.9375em;
    margin-bottom: 1em;
    line-height: 140%;
    color: #333;
}
.ui-record-viewing .right-contact {
    border-left: 1px solid #efefef;
    padding-left: 1.75em;
    margin-bottom: 1.5em;
}
@media (max-width: 575px) {
    .ui-record-viewing .right-contact {
        border-left: none;
        padding-left: 15px;
        margin-bottom: 1.5em;
    }
}
.ui-record-viewing .right-contact .ui-button {
    padding: 0;
}
.ui-record-viewing .viewing_timepicker {
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 0em;
    -moz-column-gap: 0em;
    column-gap: 0em;
    padding: 0;
    margin: 0;
    list-style: none;
}
@media (max-width: 767px) {
    .ui-record-viewing .viewing_timepicker {
        padding-top: 1em
    }
}
.ui-record-viewing .viewing_timepicker li {
    padding: 0 0.4em 0.4em 0;
}
.ui-record-viewing .viewing_timepicker li a {
    padding: 0;
    -webkit-transition: all .0s;
    -moz-transition: all .0s;
    -o-transition: all .0s;
    transition: all .0s;
    background: #F5F5F5;
}
.ui-record-viewing .viewing_timepicker li a:hover {
    background: #f0f0f0;
}
.ui-record-viewing .viewing_timepicker li a.selected {
    background: #5cc4ef !important;
    border-color: #5cc4ef;
    color: #fff;
}

/* ym-bubble */
.ym-bubble {
    font-size: 1em;
    position: relative;
    user-select: none;
    pointer-events: auto;
    display: none;
    transform: translate(-50%, -100%);
    top: -0.5em;
}
.ym-bubble::before {
    content: "";
    position: absolute;
    bottom: -0.75em;
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-block;
    border: 0.25em solid transparent;
    border-top: 0.25em solid #F1F7FF;
    z-index: 1;
}
.ym-bubble__card {
    position: relative;
    width: 18.75em;
    background: #fff;
    border-radius: 1.25em;
    box-shadow: 0 0.625em 1.5em rgba(0,0,0,.18);
    overflow: hidden;
}
.ym-bubble__body {
    padding: 0.75em;
}
.ym-bubble__body .ui-mapcard-listing {
    width: 100%;
}
.ym-bubble__body .ui-mapcard-listing .object_desc h3 {
    font-size: 1em;
}
.ym-bubble__body .ui-mapcard-listing .object_desc .address,
.ym-bubble__body .ui-mapcard-listing .sizes ul.s_param,
.ym-bubble__body .ui-mapcard-listing .sizes .more_block,
.ym-bubble__body .v3-icons-ruble {
    font-size: 0.875em;
}
.ym-bubble__close {
    position: absolute; top: 0.5em; right: 0.5em;
    border: 0;
    background: transparent;
    font-size: 1.25em;
    line-height: 1;
    cursor: pointer;
    color: #777;
    z-index: 2;
}
.ym-bubble__arrow {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -0.5em;
    width: 0;
    height: 0;
    border-left: 0.5em solid transparent;
    border-right: 0.5em solid transparent;
    border-top: 0.5em solid #fff;
    filter: drop-shadow(0 -1px 1px rgba(255,255,255,1));
}
.ym-bubble__loading { padding: 0.625em; font-size: 0.875em; color: #555; }
.ym-bubble__error { padding: 0.625em; font-size: 0.875em; color: #c00; }

/* ui-mapcard-listing */
.ui-mapcard-listing {
    position: relative;
    width: 16em;
    margin-bottom: 0 !important;
    border-radius: 0 !important;
}
.ui-mapcard-listing .close {
    position: absolute;
    top: 0;
    right: 0;
    line-height: 0;
    cursor: pointer;
}
.ui-mapcard-listing .close i {
    font-size: 0.75em;
    cursor: pointer;
}
.ui-mapcard-listing .object_desc {
    width: 100%;
    position: relative;
    padding: 0 1.5em 0 0;
}
.ui-mapcard-listing .object_desc h3 {
    font-family: Roboto;
    font-style: normal;
    font-weight: bold;
    font-size: 1.25em;
    margin-bottom: 0;
    line-height: 140%;
}
.ui-mapcard-listing .object_desc h3 a {
    text-decoration: none !important;
    color: #145f88;
}
.ui-mapcard-listing .object_desc .address {
    font-size: 1em;
    line-height: 140%;
    color: #999999;
}
.ui-mapcard-listing .object_desc .address span {
    white-space: nowrap;
    overflow: hidden;
}
.ui-mapcard-listing .sizes {
    width: 100%;
    position: relative;
    padding: 0.75em 0 0 0;
}
.ui-mapcard-listing img {
    width: 100%;
    border-radius: 0.625em;
}
.ui-mapcard-listing .sizes .sizes_item {
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    border-top: 1px solid #f5f5f5;
}
.ui-mapcard-listing .col-8 {
    padding-left: 0;
}
.ui-mapcard-listing .sizes .more_block {
    padding: 0.75em 0 0 0;
    border-top: 1px solid #f5f5f5;
}
.ui-mapcard-listing .sizes a.sizes_link {
    display: block;
}
.ui-mapcard-listing .sizes a.sizes_link:hover {
    background: #f6fcff;
}
.ui-mapcard-listing .sizes .all_sizes {
    float: right;
    font-size: 0.9375em;
    line-height: 2.625em;
    color: #999;
    padding: 0 0.25em 0 0;
}
.ui-mapcard-listing .sizes ul.s_param {
    padding: 0;
    margin: 0;
    margin-top: -0.25em;
    list-style: none;
}
.ui-mapcard-listing .sizes ul.s_param li {
    border-bottom: 2px dotted #C2C2C2;
    position: relative;
    padding: 0;
    margin-bottom: 0;
}
.ui-mapcard-listing .sizes ul.s_param li span {
    background-color: #FFF;
    margin: 0;
}
.ui-mapcard-listing .sizes ul.s_param span.text {
    position :relative;
    bottom: -0.5em;
    margin-right: 1em;
    padding-right: 0.25em;
    font-size: 1em;
    color: #999;
}
.ui-mapcard-listing .sizes ul.s_param span.value {
    position: absolute;
    right: 0;
    bottom: -0.5em;
    padding-left: 0.25em;
    padding-right: 0.25em;
    font-size: 1em;
    font-weight: 600;
    color: #333;
}
.ui-mapcard-listing .sizes a.sizes_link:hover ul.s_param span.text,
.ui-mapcard-listing .sizes a.sizes_link:hover ul.s_param span.value {
    background: #f6fcff;
}
.ymaps-2-1-79-hint {
    position: relative;
    top: -3.25em;
    left: -1.25em;
    padding: 0 !important;
    border-radius: 0.625em;
    overflow: hidden;
    border: 0 !important;
    max-width: 15em;
}
.ymaps-2-1-79-hint__text {
    padding: 0.5em 1em !important;
    background: #fff !important;
    font: inherit important;
    display: block;
    float: initial;
    color: #212121;
    font-size: 0.875em;
    line-height: 1.25em;
}
.ymaps-2-1-79-balloon__close+.ymaps-2-1-79-balloon__content {
    margin-right: 0 !important;
    padding-right: 12px !important;
}

/* ui-loading */
.ui-loading {
    position: relative;
    overflow: hidden;
}
.ui-loading:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fafafa;
    opacity: 0.85;
}

.ui-loading:before {
    content: "";
    width: 1em;
    height: 1em;
    position: absolute;
    animation: ui-loading-animation 1.5s ease infinite;
    top: 50%;
    left: 50%;
    margin: -36px 0 0 -11px;
    z-index: 1;
}


/* START TOOLTIP STYLES */
[tooltip] {
    position: relative; /* opinion 1 */
}

/* Applies to all tooltips */
[tooltip]::before,
[tooltip]::after {
    text-transform: none; /* opinion 2 */
    font-size: .9em; /* opinion 3 */
    line-height: 1;
    user-select: none;
    pointer-events: none;
    position: absolute;
    display: none;
    opacity: 0;
}
[tooltip]::before {
    content: '';
    border: 5px solid transparent; /* opinion 4 */
    z-index: 11; /* absurdity 1 */
}
[tooltip]::after {
    content: attr(tooltip); /* magic! */
    font-size: 0.875em;
    text-align: center;
    min-width: 3em;
    max-width: 21em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 1ch 1.5ch;
    border-radius: .3ch;
    background: #0985CA;
    box-shadow: 0px 30px 30px rgba(0, 0, 0, 0.08);
    color: #fff;
    z-index: 10;
}

/* Make the tooltips respond to hover */
[tooltip]:hover::before,
[tooltip]:hover::after {
    display: block;
}

/* don't show empty tooltips */
[tooltip='']::before,
[tooltip='']::after {
    display: none !important;
}

/* FLOW: UP */
[tooltip]:not([flow])::before,
[tooltip][flow^="up"]::before {
    bottom: calc(100% + 30px);
    border-bottom-width: 0;
    border-top-color: #0985CA;
}
[tooltip]:not([flow])::after,
[tooltip][flow^="up"]::after {
    bottom: calc(100% + 35px);
}

.sizes_table [tooltip]:not([flow])::before,
.sizes_table [tooltip][flow^="up"]::before {
    bottom: calc(100% + 0px);
}
.sizes_table [tooltip]:not([flow])::after,
.sizes_table [tooltip][flow^="up"]::after {
    bottom: calc(100% + 5px);
}

[tooltip]:not([flow])::before,
[tooltip]:not([flow])::after,
[tooltip][flow^="up"]::before,
[tooltip][flow^="up"]::after {
    left: 50%;
    transform: translate(-50%, -.5em);
}

/* FLOW: DOWN */
[tooltip][flow^="down"]::before {
    top: 100%;
    border-top-width: 0;
    border-bottom-color: #0985CA;
}
[tooltip][flow^="down"]::after {
    top: calc(100% + 5px);
}
[tooltip][flow^="down"]::before,
[tooltip][flow^="down"]::after {
    left: 50%;
    transform: translate(-50%, .5em);
}

/* FLOW: LEFT */
[tooltip][flow^="left"]::before {
    top: 50%;
    border-right-width: 0;
    border-left-color: #0985CA;
    left: calc(0em - 5px);
    transform: translate(-.5em, -50%);
}
[tooltip][flow^="left"]::after {
    top: 50%;
    right: calc(100% + 5px);
    transform: translate(-.5em, -50%);
}

/* FLOW: RIGHT */
[tooltip][flow^="right"]::before {
    top: 50%;
    border-left-width: 0;
    border-right-color: #0985CA;
    right: calc(0em - 5px);
    transform: translate(.5em, -50%);
}
[tooltip][flow^="right"]::after {
    top: 50%;
    left: calc(100% + 5px);
    transform: translate(.5em, -50%);
}

/* KEYFRAMES */
@keyframes tooltips-vert {
    to {
        opacity: .9;
        transform: translate(-50%, 0);
    }
}

@keyframes tooltips-horz {
    to {
        opacity: .9;
        transform: translate(0, -50%);
    }
}
@keyframes animate_gradient {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

/* FX All The Things */
[tooltip]:not([flow]):hover::before,
[tooltip]:not([flow]):hover::after,
[tooltip][flow^="up"]:hover::before,
[tooltip][flow^="up"]:hover::after,
[tooltip][flow^="down"]:hover::before,
[tooltip][flow^="down"]:hover::after {
    animation: tooltips-vert 300ms ease-out forwards;
}

[tooltip][flow^="left"]:hover::before,
[tooltip][flow^="left"]:hover::after,
[tooltip][flow^="right"]:hover::before,
[tooltip][flow^="right"]:hover::after {
    animation: tooltips-horz 300ms ease-out forwards;
}