html, body {
    color: #454545;
    font-family: 'Roboto', sans-serif;
    font-size: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
}
body {
    font-size: 16px;
}


.d-none {
    display: none;
}
.text-center {
    text-align: center;
}
.my-2 {
    margin: 20px 0;
}
.mt-3 {
    margin-top: 30px;
}

.enter {
    flex-grow: 1;
    background: url("/img/enter.png?v=2") no-repeat center center;
    margin: 10px;
}
h1, h2, h3, h4, h5, h6 {
    font-style: italic;
    margin: 0;
    font-weight: 500;
}
h1 {
    margin-bottom: 20px;
    font-size: 1.5em;
}
h2 {
    font-size: 1.3em;
    font-weight: normal;
    margin: 20px 0 0;
    text-align: center;
}
h3 {
    font-size: 1.2em;
}
h4 {
    font-size: 1.2em;
}
h5 {
    font-size: 1.154em;
    margin: 0 0 5px;
    font-weight: normal;
}
h6 {
    font-size: 1em;
}
p {
    margin: 0;
}
img {
    border: 0 none;
    margin: 0;
    padding: 0;
}
strong {
    font-weight: 500;
}
ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.mobile_only {
    display: none;
}
.header {
    background-color: #ffffff;
    padding: 5px 0 0;
}
.menu_wrapper {
    width: 200px;
    flex-shrink: 0;
    margin: 0 20px;
    position: fixed;
    display: flex;
    flex-direction: column;
    max-height: 100%;
}
.menu {
    font-size: 12px;
    text-transform: lowercase;
    padding-top: 100px;
    overflow-y: scroll;
    -ms-overflow-style: none;  /* Internet Explorer 10+ */
    scrollbar-width: none;  /* Firefox */
}
.menu::-webkit-scrollbar { 
    display: none;  /* Safari and Chrome */
}
.menu li {
    margin: 20px 0;
    padding: 0;
    white-space: nowrap;
}
.menu a {
    color: #222222;
}
.submenu {
    display: none;
    margin-left: 20px;
}
.submenu_active {
    display: block;
}
.submenu li {
    margin: 10px 0;
    /* text-transform: none; */
}
li {
    margin: 0;
    padding: 0 10px;
}
ul#preview {
    margin: 75px 0 75px 50px;
    overflow: hidden;
    padding: 0;
    width: 205px;
}
ul#preview li {
    float: none;
    margin: 35px 0;
    padding: 0;
}
a {
    /* main green */
    color: #00a651;
    text-decoration: none;
}
a:hover {
    color: #448852;
    text-decoration: none;
}
a:active {
    color: #00a651;
    text-decoration: none;
}
.wrapper {
    display: flex;
    margin: 0 auto;
    max-width: 1350px;
    width: 100%;
    min-height: 100%;
}
.footer-wrapper {
    background-color: #e6e6e6;
    margin-top: 10px;
    padding: 50px 0;
}
.footer {
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
}
.footer-content {
    padding-top: 40px;
}
.footer-content > p {
    margin-bottom: 20px;
}
.footer-logo {
    flex-shrink: 0;
    flex-basis: auto;
    width: 200px;
    margin: 0 100px 0 40px;
}
.footer-logo img {
    width: 100%;
}
.footer-contacts {
    display: flex;
    margin-bottom: 20px;
}
.footer-contacts-info {
    margin-left: 10px;
}
.footer-social {
    margin-top: 60px;
}
.footer-social a {
    margin-right: 20px;
}
.footer-social img {
    width: 25px;
}
.logo {
    background: url("/img/logo-main.png?v=2") no-repeat center left;
    background-size: contain;
    height: 60px;
    display: block;
    flex-shrink: 0;
}
.landing-logo {
    display: none;
}
.content {
    margin: 15px 0 55px 230px;
    min-height: 100%;
    flex-grow: 1;
}
#main.content {
    background: #717171 none repeat scroll 0 0;
}
#result {
    margin: 0;
    position: fixed;
    z-index: 15;
}
#news_result {
    margin: 0;
    padding: 0;
    position: fixed;
    z-index: 15;
}
.news_preview {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
ul#gal_preview {
    margin: 0;
    padding: 0;
}
#gal_preview img {
    margin: 0;
    padding: 30px;
}
.language_selector {
    display: flex;
    justify-content: flex-end;
}
.language_selector li {
    width: 40px;
    padding: 0;
}
.language_selector a {
    color: #222222;
}
.language_selector li.active {
    display: block;
}
.content .language_selector {
    margin-bottom: 30px;
}
#artists {
    position: relative;
}
#menu_line {
    border: 0 none;
    display: block;
    height: 1px;
    margin: 4px 0;
    padding: 0;
    width: 100%;
}
#result_descr {
    background: #666666 none repeat scroll 0 0;
    color: #ffd430;
    display: none;
    padding: 15px 5px 5px 0;
}
#result_image {
    display: none;
}
ul.footer {
    float: left;
    font-size: 13px;
    list-style-type: none;
    margin: 0;
    padding: 5px 0 5px 238px;
}

.landing-hero {
    height: 80vh;
}
.landing-hero-slide {
    background-position: top center;
    background-size: contain;
    background-repeat: no-repeat;
    height: 100%;
}
.landing-hero-content {
    height: 100%;
    font-size: 24px;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
}
.landing-hero-desktop {
    display: block;
}
.landing-hero-mobile {
    display: none;
}
.landing-hero-content h1 {
    font-size: 24px;
}
.landing-hero-title {
    max-width: 700px;
    padding: 10px;
    background-color: #ffffffbf;
    margin: 30px;
}
div.swiper-button-prev,
div.swiper-button-next {
    color: #ffffff;
    -webkit-text-stroke: 1px #bbb;
}
div.swiper-button-prev:focus,
div.swiper-button-next:focus {
    outline: 0;
}
span.swiper-pagination-bullet {
    background-color: #ffffff;
    width: 12px;
    height: 12px;
}

.landing-exhibition-wrapper {
    padding: 50px 0;
}
.landing-exhibition-content {
    max-width: 750px;
    margin: 0 auto;
}
.landing-exhibition-content p {
    margin-bottom: 30px;
}

.news_pics {
    display: inline-block;
    margin: 30px;
    text-align: center;
}
.news_pics p {
    max-width: 180px;
}
.news_text {
    min-height: 300px;
    word-wrap: break-word;
}
.news_header {
    position: relative;
}
.card {
    display: block;
    color: #454545;
    padding: 15px 25px;
    margin: 15px;
    width: calc(33% - 50px);
    box-shadow:  0 0 0 rgba(0,0,0,0.12), 0 0 0 rgba(0,0,0,0.24);
    transition: box-shadow 0.3s cubic-bezier(.25,.8,.25,1);
    box-sizing: border-box;
}
.picture-card {
    margin: 10px;
    padding: 0;
    width: calc(33% - 20px);
    box-sizing: border-box;
}
.card:hover {
    color: #454545;
    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
}
.card-header {
    margin-bottom: 10px;
}
.card-header, .article_expand_label {
    color: #00a651;
}
.card img, .picture-card img {
    max-width: 100%;
}
.exhibition_preview {
    overflow: hidden;
}
#back_arrow {
    color: #ffffff;
    display: none;
    position: fixed;
    z-index: 15;
}
#back {
    display: none;
    left: 0;
    position: absolute;
    top: -60px;
    z-index: 15;
}
#next {
    display: none;
    left: 0;
    position: absolute;
    top: -60px;
    z-index: 15;
}
.emf {
    font-weight: 500;
    text-decoration: underline;
}
.partners_content {
    font-size: 15px;
    margin: 0 auto;
    padding: 0;
}
.partners_content a {
    display: inline-block;
    margin: 10px;
    min-width: 237px;
    text-align: center;
    vertical-align: top;
}
.publications_content {
    font-size: 15px;
    margin: 0;
    padding: 0;
    text-align: center;
}
.publications_content a {
    display: inline-block;
    float: none;
    margin: 15px 25px;
    text-align: center;
    vertical-align: top;
    width: calc(33% - 50px);
}
.publications_content p {
    margin: 0 auto;
    width: 250px;
}
.next-page-link {
    display: none;
}
.page_numbers {
    clear: both;
    margin: 0 0 20px;
    text-align: center;
}
.page_numbers span {
    margin: 0 15px;
}
.page_numbers a {
    color: #454545;
}
.page_numbers .current {
    color: #00a651;
    font-weight: 500;
}
.date {
    font-style: italic;
    margin: 5px 0;
}
#imagelightbox {
    position: fixed;
    z-index: 9999;
}
.set_heading {
    margin: 40px;
}
.set_heading a {
    color: #454545;
    text-decoration: underline;
}
.set_heading a:hover {
    color: #00a651;
}
.set_heading h3 {
    font-weight: normal;
}
.set_pictures li {
    margin: 10px;
    padding: 0;
    width: calc(33% - 20px);
    box-sizing: border-box;
}
.set_pictures img {
    height: 100%;
    display: block;
    line-height: 0;
}
.set_pictures img {
    width: 100%;
    height: auto;
}
.sets_list {
    margin: 30px 0 0;
    text-align: justify;
    width: 100%;
}
.sets_list li {
    text-align: center;
    position: relative;
}
.sets_list h1 {
    position: absolute;
    margin: 0;
    padding-bottom: 5px;
    bottom: 0;
    left: 0;
    right: 0;
    font-size: 20px;
    background-color: rgba(256, 256, 256, 0.7);
}
.sets_list_brief {
    margin: 0;
    padding: 0;
}
.sets_list_brief li {
    margin: 10px 0;
    padding: 0;
}
.sets_list_brief img {
    max-width: 100%;
}
.set_artist_heading {
    text-align: center;
}
.cover_image {
    max-width: 100%;
    max-height: 220px;
}
.contacts_content {
    margin: 60px 0 0 0;
}
.bio_pic_switch {
    font-size: 1.3em;
}
li.active > a {
    color: #00a651;
}
.menu li.active > a {
    color: #00a651;
}

.captioned_illustration {
    margin: 20px;
}
.interview_content img, .article_content img {
    margin: 20px;/*this margin is immidiately eliminated on load, 
    it is needed to prevent images from bumping while loading*/
    max-width: 880px;
    height: auto;
}
.interview_content, .article_content {
    font-family: 'Roboto', sans-serif;
    background: none;
    text-align: justify;
}
.article_expand_label {
    margin: 5px 0;
}
.image_caption {
    text-align: center;
}
.interviews_list img, .articles_list img {
    margin: 0 0 10px;
    width: 100%;
}
.interview_cover, .article_cover {
    text-align: center;
    width: 100%;
}
.artists_list {
    text-align: center;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
}
.artists_list li {
    width: 33.33%;
    position: relative;
    margin: 0;
    padding: 25px;
    box-sizing: border-box;
    overflow: hidden;
}
.artists_list img {
    width: 100%;
    height: auto;
}
.artists_list h1 {
    position: absolute;
    top: 40px;
    left: 40px;
    font-size: 20px;
    width: 0;
    font-weight: 500;
}
.artist_wrapper {
    display: flex;
}
.artist_biography {
    margin-right: 80px;
    width: 550px;
    flex-shrink: 0;
}
.artist_biography h1 {
    margin-bottom: 40px;
    text-align: center;
}
.artists_exhibitions_toggle {
    display: inline-block;
    margin: 40px 0 20px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    text-align: left;
    text-transform: uppercase;
}
.artists_exhibitions {
    display: none;
}
.hidden_artist {
    opacity: 0.5;
}
.artists_list a, .sets_list a {
    color: #000000;
}
.artists_list a:hover, .sets_list a:hover {
    color: #00a651;
}
.clear {
    clear: both;
}
.content:after
{
    content: " ";
    display: block;
    clear: both;
}

.social_container {
    position: fixed;
    right: 0;
    top: 30%;
    width: 180px;
    height: 180px;
    overflow: hidden;
    z-index: 10;
}
.social_button {
    background-color: #ffffff;
    width: 180px;
    height: 48px;
    position: relative;
    right: -140px;
    border: 1px solid black;
}
.facebook {
    background: #ffffff url("/img/facebook.png") no-repeat scroll 6px center;
    margin-top: -1px;    
}
.instagram {
    background: #ffffff url("/img/instagram.png") no-repeat scroll 2px center;
    margin-top: -1px;
}
.facebook_like {
    background: #ffffff url("/img/facebook_like.png") no-repeat scroll 2px center;
    padding: 0 0 0 60px;
}
.facebook_like > div {
    margin: 3px 0 0 0;
    width: 100px;
}
.social_button p {
    margin: 15px 10px;
    font-size: 15px;
    text-align: right;
}
.social_button a {
    color: #333333;
    outline: none;
    min-height: 100%;
    display: block;    
}
.social_button a:hover {
    color: #333333;
}

.videowrapper {
    float: none;
    clear: both;
    width: 100%;
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 25px;
    height: 0;
}
.videowrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.mobile-hover h1 {
    transition: all 0.5s;
    white-space: nowrap;
}
.mobile-hover-focus a h1 {
    color: #00a651;
}
.mobile-hover:hover h1, .mobile-hover-focus h1 {
    background-color: rgba(256, 256, 256, 0.9);
    z-index: 10;
    font-size: 30px;
    padding: 10px;
    left: 0;
    width: 100%;
    top: 80%;
}
.sets_list_brief .mobile-hover:hover h1, .sets_list_brief .mobile-hover-focus h1 {
    top: initial;
    padding-left: 0;
    padding-right: 0;
}

.item_container {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
.item_breadcrumbs {
    margin-left: 50px;
}
.item_breadcrumbs a {
    color: #454545;
    text-decoration: underline;
}
.item_breadcrumbs a:hover {
    color: #00a651;
}
.item_link:hover .item_info_preview {
    top: 50%;
    opacity: 1;
}
.item_link:hover {
    background-color: #fff;
}
.item_info {
    text-align: center;
}
.item_gallery { 
    display: flex;
    align-items: center;
    margin: 30px 0;
}

.item_image {
    max-width: 800px;
    margin: 0 auto;
}
.item_image_showcase {
    margin: 0 auto;
    max-width: 800px;
    position: relative;
}
.item_images .slick-current {
    border-color: #9daad6;
}
.item_images .slick-slide {
    margin-right: 15px; 
}
.item_images_preview {
    height: 100px;
    margin: 10px;
    cursor: pointer;
}
.item_images .slick-slide, 
.item_images_preview, 
.item_link {
    border: 1px solid transparent;
    box-sizing: border-box;
}
.item_images .slick-slide {
    border-width: 2px;
}
.item_name_container {
    margin: 10px;
}

.item-arrows-container {
    display: none;
}
.arrow {
    cursor: pointer;
    display: block;
    width: 30px;
    height: 30px;
    margin: 10px;
    border-bottom: 3px solid #454545;
    border-left: 3px solid #454545;
}
.arrow-next {
    transform: rotate(-135deg);
}
.arrow-prev {
    transform: rotate(45deg);
}
.item-spin {
    position: relative;
    margin-top: 30px;
    display: flex;
    align-items: center;
}
.item-spin > .tridi-viewer-image {
    margin: 0 auto;
    max-width: 1100px;
    max-height: 960px;
}

.item-spin-hint {
    position: relative;
}
.item-spin-hint::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 40px;
    background: url("/img/spin.png") no-repeat center;
}
.item-spin-description {
    margin: 30px auto 0;
    max-width: 800px;
}
.spin_cover img {
    width: 100%;
}
.nft-item .item_image_showcase {
    margin: 0;
}

@media (max-width: 1200px) {
    .artists_list li {
        width: 50%;
    }
    .artist_sets {
        min-width: 200px;
        overflow: hidden;
    }
    .card {
        padding: 15px;
        margin: 15px;
        width: calc(50% - 30px);
    }
    .publications_content a {
        margin: 15px;
        width: calc(50% - 30px);
    }
}

@media (max-width: 1000px) {
    .artist_biography {
        margin-right: 30px;
        width: initial;
        flex-shrink: 1;
    }
}

@media (max-width: 800px) {
    .logo {
        background-size: initial;
    }
    .landing-logo {
        display: block;
        margin-right: 80px;
        margin-left: 20px;
        margin-top: 10px;
    }
    .landing-hero-desktop {
        display: none;
    }
    .landing-hero-mobile {
        display: block;
    }
    .landing-hero-title {
        padding: 20px;
    }
    .landing-hero-content {
        font-size: 20px;
    }
    .swiper-container {
        /* height: calc(100% - 100px); */
        height: initial;
    }
    div.swiper-button-prev, div.swiper-button-next {
        color: #454545;
        bottom: 0;
        top: unset;
        -webkit-text-stroke-width: 0;
    }
    span.swiper-pagination-bullet {
        background-color: #454545;
    }
    .swiper-container-horizontal>.swiper-pagination-bullets {
        bottom: 20px;
    }
    .landing-hero-image-mobile {
        width: 100%;
    }
    .landing-hero-content h1 {
        font-size: 20px;
    }
    .menu_wrapper {
        display: none;
    }
    .content {
        margin: 20px 0;
    }
    .footer-logo {
        margin: 0 30px;
    }
    .item_image {
        width: 100%;
        max-width: 100%;
    }
    .language_selector {
        justify-content: flex-start
    }
    .content .language_selector {
        display: none;
    }
    .menu {
        font-size: initial;
        padding-top: 20px;
    }
    .set_heading {
        margin: 40px 20px 20px;
    }
    .item_container {
        margin-top: 40px;
    }
    .item_gallery {
        width: 100%;
        margin: 20px 0 10px;
    }
    .item_breadcrumbs {
        margin: 0 10px;
    }
    .item_name_container {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .item_name_container .arrow {
        flex-shrink: 0;
    }
    .item_name_container div {
        display: block;
        min-width: 40px;
    }
    .item_name_container h1 {
        text-align: center;
        margin: 0;
    }
    .item_image_showcase {
        max-width: 100vw;
    }
    .item-image {
        max-width: 100vw;
    }
    .item-arrows-container {
        display: flex;
        justify-content: space-between;
        margin-right: 50px;
        padding: 0 30px;
    }
    .item_gallery .arrow {
        display: none;
    }
    .arrow {
        width: 20px;
        height: 20px;
    }
    .publications_content {
        margin-top: 30px;
    }
    .artists_content {
        margin-top: 20px;
    }
    .item-spin > .tridi-viewer-image {
        width: 100%;
        height: auto;
    }
}

@media (max-width: 600px) {
    .logo {
        background-size: contain;
    }
    .artists_list li {
        width: 100%;
    }
    .artist_wrapper {
        flex-wrap: wrap;
    }
    .artist_biography {
        width: 100%;
        padding: 0 20px;
        box-sizing: border-box;
    }
    .contacts_content, .exhibition_content {
        padding: 0 20px;
    }
    .bio_pic_switch {
        margin-left: 20px;
    }
    .card {
        width: calc(100% - 30px);
        padding: 15px;
        box-shadow: 0 4px 8px rgba(0,0,0,0.15), 0 5px 5px rgba(0,0,0,0.12);
    }
    .set_pictures li, .picture-card {
        width: calc(100% - 20px);
    }
    .publications_content a {
        margin: 15px;
        width: calc(100% - 30px);
    }
    .footer {
        flex-wrap: wrap;
    }
    .footer-logo {
        margin: 0 0 50px 0;
    }
    .footer-content, .landing-exhibition-content, .interview_content, .article_content, .auction_content {
        padding: 0 20px;
    }
    .interview_content, .article_content {
        margin-top: 40px;
        text-align: left;
    }
    .footer-social {
        margin-top: 40px;
        text-align: center;
    }
    .captioned_illustration, .image_caption {
        width: 100% !important;
    }
    .captioned_illustration {
        margin: 20px 0;
    }
    .captioned_illustration img {
        max-width: 100%;
    }

}

@media (min-width: 800px) {
    .videos_list .videowrapper {
        width: 70%;
        padding-bottom: 39%;
    }
}

@media (max-width: 530px), (max-height: 520px) {
    .enter {
        background-size: contain;
        margin: 10px 60px;
    }
}