/*
Theme Name: PaulIsLava Simple
Description: PaulIsLava Theme
Author: Paul Kondratov
Author URL: https://paulislava.space/
Version: 1.0
Text Domain: pil-simple
*/ 

:root {
    --bright: #FFFFFF;
    --white: var(--bright);

    --dark: #313131;
    --dark-1: #000000;
    --red: #FF0000;
    --red-2: #FF6666;
    --red-3: #C93838;
    --red-4: #E84242;

    --gray: #898989;
    --gray-1: #C4C4C4;
    --gray-2: #E5E5E5;
    --gray-3: #ECF1F7;
    --gray-4: #E5E5EB;

    --color-1: #FFFFFF;
    --color-2: #18A0FB;
    --color-3: #898989;
    --color-4: #FAC948;
    --color-5: #E1DFEF;
    --color-6: #F0F3FF;
    --error-color: #FF1744;
    --wrap-width: 1200px;
    --wrap-padding: 11vw;
    --wrap-padding-small: 8vw;

    --text-color: var(--dark-1);
    --text-color-1: var(--color-1);
    --color-small: var(--color-3);
    --html-back: var(--color-1);

    --logo-width: 14rem;
    --tabs-1-color: var(--color-8);
    --tabs-1-active-color: var(--color-2);
    --footer-background: transparent;
    --footer-color: var(--color-1);
    --unchecked-text: rgba(0, 0, 0, 0.5);
    --checked-text: var(--dark-1);
    --menu-item-color: var(--color-1);
    --menu-item-active-color: var(--color-1);
    --menu-item-active-border: transparent;
    --form-gap: 1.3rem;
    --button-width: 16.5rem;
    --nav-background: var(--dark-1);
    --billet-radius: .6rem;
    --billet-box-shadow: 0px 0px 34px rgba(173, 173, 173, 0.5);
    --radius: .3rem;

    --left-label-color: var(--dark-1);

    --text-size: 1.1vw;
    --text-size-1: calc(0.82 * var(--text-size));
    --text-size-2: var(--text-size-1);
    --text-size-3: var(--text-size-1);

    --subtitle-size: calc(1.12 * var(--text-size));
    --subtitle-2-size: calc(0.778 * var(--text-size));
    --subtitle-3-size: var(var(--subtitle-2-size));

    --caption-size: calc(0.583 * var(--text-size));
    --caption-size-2: calc(0.417 * var(--text-size));
    --headline-1: calc(2.67 * var(--text-size));
    --headline-2: calc(2 * var(--text-size));
    --headline-3: calc(1.25 * var(--text-size));
    --headline-4: var(--text-size);
    --headline-5: calc(0.8 * var(--text-size));
    --small-text: var(--text-size-1);
    --outline-color: var(--color-2);
    --button-text-size: var(--text-size-1);
    --button-radius: var(--billet-radius);
    --button-2-text-size: var(--subtitle-size);
    --numbers-text-size: var(--headline-2);
    --input-text-size: var(--text-size);

    --form-input-background: var(--gray-3);

    --header-background: transparent;
    --header-static-back: transparent;
    --header-text-color: var(--color-1);
    --header-text-size: var(--text-size-1);

    --footer-link-text-size: var(--footer-text-size);

    --container-padding-top: 3rem;
    --container-padding-bottom: 4rem;
    
    --document-line-height: 1.6;
}

/* @media screen and (min-width: 1500px) {

} */


@media screen and (max-width: 768px) {
    :root {
        --wrap-padding: 8vw;
        --wrap-padding-2: 8vw;
        --wrap-padding-small: 15vw;
        --container-padding-top: 2rem;
        --container-padding-bottom: 2rem;
        
        --main-header-height: 6rem;
        --menu-header-height: 0px;
        --form-gap: .8rem;
        --button-width: 9rem;
        --logo-width: 36vw;

        --billet-radius: .3rem;

        --text-size: 13px;
        --text-size-1: calc(0.86 * var(--text-size));
        --subtitle-size: var(--text-size);
        --headline-1: calc(2.29 * var(--text-size));
        --headline-2: calc(1.71 * var(--text-size));
        --headline-3: calc(1.14 * var(--text-size));
        --headline-4: calc(1 * var(--text-size));
        --headline-5: calc(1.14 * var(--text-size));
        --caption-size: calc(0.57 * var(--text-size));
        --caption-size-2: calc(0.48 * var(--text-size));
        --small-text: calc(0.625 * var(--text-size));
        --button-2-text-size: var(--headline-5);
    }
}

:root {
    --footer-text-size: var(--text-size-1);

    --wrap-padding-2: calc(var(--wrap-padding) * 2);
    --wrap-padding-half: calc(var(--wrap-padding) / 2);
    --button-height: calc(var(--button-width) / 3);
    --small-button-width: calc(var(--button-width) / 1.5625);
    --small-button-height: calc(var(--small-button-width) / 3);

    --header-height: 6rem;

    --minus-wrap-padding: calc(-1 * var(--wrap-padding));
}

html.blocked {
    height: 100vh;
    overflow: hidden;
}

body {
    font-family: 'Montserrat', sans-serif;
    font-size: var(--text-size);
    font-weight: 400;
    color: var(--text-color);
    line-height: var(--document-line-height);
}


body, .body-back {
    background: var(--html-back);
    background-size: 100% auto;
}

body:not(.fl-builder-edit) {
    box-sizing: border-box;
}

body.page:not(.fl-builder) .site-content {
    padding: 3em var(--wrap-padding) 4em;
}

@media screen and (max-width: 768px) {
    body {
        line-height: 1.7;
    }
}

#body-back {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
}

#body-back .video-front {
    background: rgba(0, 0, 0, 0.6);
}

.form-gap, .fl-grid-row.form-gap-row .fl-col-group {
    gap: var(--form-gap);
}

/* Text */

small, .small-text {
    font-size: var(--small-text);
    line-height: 1.5;
    display: block;
    color: var(--color-3);
}

.input-label {
    font-size: var(--caption-size);
    line-height: 1.25;
    display: block;
    color: var(--color-3);
    font-weight: normal;
    text-align: left;
}

@media screen and (max-width: 768px) {
    .input-label {
        color: inherit;
    }
}

.descr, blockquote {
    font-size: 1.5em;
    line-height: 1.4;
}

blockquote {
    color: var(--color-2);
}

p, .h4-block {
    margin-bottom: 1.6em;
    line-height: 1.6;
}

.margin-1 {
    margin-bottom: 1.5rem;
}

.text a {
    color: var(--color-2);
}

.text-1 {
    max-width: calc(43 * var(--text-size));
}

.text-width-1 {
    max-width: calc(37 * var(--text-size));
}

.text-width-2 {
    max-width: calc(50 * var(--text-size));
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-size-1 {
    font-size: var(--text-size-1);
}

.text-size-2 {
    font-size: var(--text-size-2);
}

.text-size-3 {
    font-size: var(--text-size-3);
}


.subtitle {
    font-size: var(--subtitle-size);
    letter-spacing: 0.2px;
}

.subtitle p {
    line-height: inherit;
}


.subtitle-2 {
    font-size: var(--subtitle-2-size);
}

.subtitle-3 {
    font-size: var(--subtitle-3-size);
}

.caption, caption {
    font-size: var(--caption-size);
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 0.02em;
}

h3 + .caption {
    margin-top: -1rem;
}

b, strong, .bold {
    font-weight: bold;
}

.medium-text {
    font-weight: 500;
}

.semibold {
    font-weight: 600;
}

.label-1 {
    font-weight: 600;
    letter-spacing: -0.2px;
}

h1, .h1 {
    font-size: var(--headline-1);
    line-height: 1.22;
    font-weight: bold;
    margin-bottom: 1rem;
}

h2, .h2 {
    font-size: var(--headline-2);
    margin-bottom: .7em;
    font-weight: bold;
    line-height: 1.4;
    color: inherit;
    letter-spacing: 0;
    
}

h3, .h3 {
    font-size: var(--headline-3);
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: .4rem;
    color: var(--color-2);
    letter-spacing: 0;
}

.normal, h3 .normal, h1 .normal, h2 .normal {
    font-weight: normal;
}

h3 em, .h3 em {
    font-size: 1.77em;
    margin-right: .3em;
}

h4, .h4 {
    font-size: var(--headline-4);
    font-weight: bold;
    color: inherit;
    line-height: 1.6;
}

h4 em, .h4 em {
    font-size: 3.2em;
    font-weight: 900;
    line-height: 1;
}

h5, .h5 {
    font-weight: bold;
    font-size: var(--headline-5);
}

h5 a, .h5 a {
    text-decoration: underline;
}



@media screen and (max-width: 768px) {
    h1, .h1, h2, .h2 {
        margin-bottom: .7em;
    }
}

.bright-block h4, .bright-block h3, .bright-block h1, .bright-block h2, .bright-block h1 {
    color: inherit;
}

.entry-content li {
    padding-left: 2rem;
    background: linear-gradient(to right, var(--dark), var(--dark)) no-repeat;
    background-size: 1rem 1px;
    background-position: left center;
    margin: 1em 0;
    display: block;
}

.wrap, .wrap-parent>div, .wrap-parent-2>div>div, .wrap-parent-3>div>div>div, .container, .container-1, .container-2 {
    box-sizing: border-box;
    width: 100%;
    padding-right: var(--wrap-padding);
    padding-left: var(--wrap-padding);
    margin: 0 auto;
}

.container {
    padding-top: var(--container-padding-top);
    padding-bottom: var(--container-padding-bottom);
}

.container-ordinal:not(.bright-block):not(.container-separate)+.container-ordinal:not(.bright-block):not(.container-separate) {
    padding-top: 0;
}

@media screen and (min-width: 769px) {
    .container-1 {
        padding-right: var(--wrap-padding-small);
        padding-left: calc(var(--wrap-padding-small) + var(--wrap-padding));
        position: relative;
        padding-top: 5rem;
    }

    .container-1::before {
        content: ' ';
        display: block;
        position: absolute;
        z-index: 0;
        top: 0;
        left: 0;
        width: var(--wrap-padding);
        height: 100%;
        background: var(--color-1);
    }
}

@media screen and (max-width: 768px) {
    .container-1 {
        padding-bottom: 3rem;
    }
}

.container-2 {
    padding-top: 4rem;
    padding-bottom: 4rem;
    background: var(--color-2);
}

.wrap-2 {
    padding: 5rem var(--wrap-padding-2);
}

/* Colors */

.color-block-1 {
    color: var(--color-1);
}

.color-block-1 h1, .color-block-1 h2 {
    color: var(--color-1);
}

/* Links */

.single .entry-content .content a {
    color: var(--color-2);
    text-decoration: underline;
    cursor: pointer;
}

.link-1 {
    font-weight: bold;
    color: var(--color-2);
}

.link-3 {
    color: var(--color-2);
    font-weight: 500;
}


.button, .button-cont a {
    display: inline-block;
    padding: 1em 2em;
    min-width: 8em;
    max-width: 19em;
    background-color: var(--color-2);
    border-radius: 2rem;
    text-align: center;
    color: var(--color-1);
    font-size: var(--button-text-size);
    font-weight: 600;
    line-height: 1.2;
    transition: all 200ms;
    border: 2px solid var(--color-2);
}

.button-cont a {
    padding: 1em 2em !important;
}

.button.t2, .button-cont.t2 a {
    background: transparent;
}

.button:not(.static):hover, .button-cont:not(.static) a:hover {
    background: var(--color-2);
    color: var(--color-1);
}



.button.t1, .button-cont.t1 a {
    border-color: var(--color-1);
    background: transparent;
}

.button.t1:hover, .button-cont.t1 a:hover {
    background: var(--color-1);
    color: var(--color-2);
}

.button.t2 {
    padding-left: 1.5em !important;
    padding-right: 1.5em !important;
}

.bright-block .button.t2 {
    border-color: var(--color-1);
}

.bright-block .button.t2:hover {
    border-color: var(--color-2);
}

.button.t1.c3 {
    border-color: var(--color-3);
}

.button.t1.c3:hover {
    background: var(--color-3);
}

@media screen and (min-width: 769px) {
	.button.t3 {
		min-width: 15em;
	}
}
.button.t3 {
    margin-top: 2em;
}

@media screen and (max-width: 768px) {
    .button, .button-cont a {
        padding: 1.3em 3em;
        font-size: var(--text-size);
        border-color: transparent;
        max-width: 21em;
    }

    .button:hover, .button-cont a:hover {
        background: var(--color-1);
        color: var(--color-2);
    }
}

.bright-back .button {
    border-color: var(--dark-1);
    background: transparent;
    color: var(--dark-1);
}

.bright-back .button:hover {
    border-color: var(--color-2);
    background: var(--color-2);
    color: var(--color-1);
}

.button-2, .button-2-cont a {
    font-weight: 600;
    display: inline-block;
    min-width: 14em;
    padding: 1em 3em;
    line-height: 1.21;
    font-size: var(--button-2-text-size);
    letter-spacing: 0.2px;
    margin-top: 2em;
    background: var(--color-2);
    color: var(--color-1);
    border-radius: 3em;
    text-align: center;
    width: max-content;
    transition: all 200ms;
    border: 2px solid var(--color-2);
}

.button-2:hover, .button-2-cont:hover {
    color: var(--color-2);
    background: transparent;
}

.button-2.t2, .bright-block .button-2, .button-2-cont.t2 a {
    border-color: var(--color-1);
}

.button-2.t2:hover, .bright-block .button-2:hover {
    background: var(--color-1);
    color: var(--color-2);
}

.button-2.t1 {
    background: var(--color-4);
    color: var(--color-2);
    border-color: var(--color-4);
}

.button-4 {
    margin-top: 2em;
    background: var(--color-2);
    color: var(--color-1);
    font-weight: 600;
    display: inline-block;
    padding: 1em 4em;
    border-radius: .5rem;
    transition: color 200ms, background-color 200ms;
}

.button-4.toggle-active.toggled-red, .button-4.red-2 {
    background: var(--red-2);
    color: var(--color-1);
}

.button-4.plus-icon {
    background-image: url(img/plus.svg);
    background-repeat: no-repeat;
    background-position: 1.2em center;
    background-size: 1.2em 1.2em;
}

.button-4:disabled {
    background: var(--gray-2);
    color: var(--color-1);
}

.button-5 {
    background: var(--color-2);
    color: var(--color-1);
    font-weight: 600;
    font-size: var(--text-size-1);
    padding: 1.5em 2em;
    border-radius: .5rem;
    transition: color 200ms, background-color 200ms;
}

.button-5.outlined {
    background: transparent;
    color: var(--color-2);
    border: 2px solid var(--color-2);
}


@media screen and (min-width: 769px) {
    .input-button-row button {
        margin-left: 1.5rem;
    }
    .input-button-row {
        align-items: center;
    }
}

@media screen and (max-width: 768px) {
    .input-button-row {
        flex-flow: column;
    }
    .input-button-row>* {
        width: 100%;
    }
}


.outline {
    color: transparent;
    -webkit-text-stroke: 1px rgba(0, 0, 0, 0.4);
}

.outline-1 {
    font-size: var(--headline-1);
    text-transform: uppercase;
    font-weight: 900;
}

.bright-block .outline {
    -webkit-text-stroke-color: var(--color-1);
}



/* Header */


.site-header {
    top: 0;
    width: 100%;
    z-index: 100;
    position: relative;
    box-sizing: border-box;
    transition: all 200ms;
    background: var(--header-background);
    color: var(--header-text-color);
    font-size: var(--header-text-size);
}

.header-main {
    display: flex;
    flex-flow: row;
    align-items: center;
    margin-left: auto;
}

body.static-page.fixed-header #page {
    padding-top: var(--header-height);
}

.first-block .fl-row-content {
    padding-top: var(--header-height);
}

.site-header nav.menu-top {
    display: inline-block;
    position: relative;
    vertical-align: middle;
    margin-right: var(--wrap-padding);
}

.site-header nav.menu-top a {
    display: inline-block;
    position: relative;
    vertical-align: middle;
    margin: 0 20px;
    font-size: 1.15em;
}

.site-header nav.menu-top a:hover {
    color: var(--color-engineer-accent);
}

.site-header nav.menu-top a.active.button:hover {
    color: white;
    background-color: var(--color-engineer-accent);
}

.site-header.static.may-fixed:not(.open) {
    background: transparent;
    top: 0;
    position: absolute;
}

.site-header .login-link {
    color: inherit;
}

.site-content {
    background: transparent;
}

.page.fl-builder .site-content {
    padding-top: 0;
}

.site-header.fixed, .site-header.open {
    position: fixed;
}


body.admin-bar .site-header {
    top: 32px;
}

.header-wrap {
    height: var(--header-height);
    display: flex;
    padding: 1.5rem var(--wrap-padding);
    box-sizing: border-box;
    flex-flow: row;
    align-items: center;
    position: relative;
    z-index: 1;
}

.logo {
    max-width: var(--logo-width) !important;
    height: 100%;
    display: block;
    text-align: left;
    transition: all 200ms;
    opacity: 1;
    max-height: 5rem;
    overflow: hidden;
}

.logo img, .logo svg {
    height: 100%;
    object-fit: contain;
    width: auto;
    max-width: 100%;
    max-height: 100%;
}

.site-header .logo {
    overflow: hidden;
}

.site-header .logo-2 {
    margin-left: 3rem;
}

.site-header .logo svg, .site-header .logo svg * {
    transition: all 200ms;
}

.site-header.fixed .logo svg .hideable {
    opacity: 0;
}

@media screen and (min-width: 769px) {
    #nav-block {
        padding-left: 5vw;
        margin-left: auto;
    }
    #site-nav {
        display: flex;
        flex-flow: row;
    }
}

.site-header .menu {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    margin-left: auto;
}

.site-header .menu li {
    position: relative;
    margin-right: 3vw;
    color: var(--menu-item-color);
    transition: all 200ms;
}

.site-header .menu li:last-child {
    margin-right: 0;
}

.site-header .menu li a {
    padding: .5em 0;
    display: block;
}

#toggleNav {
    display: none;
}

#toggleNav svg, #toggleNav svg path, #toggleNav svg rect {
    transition: all 200ms;
}

@media screen and (min-width: 769px) {
    .site-header .profile-links {
        margin-left: 3em;
    }
}

#toggleNav {
    display: block;
    margin-left: auto;
    width: 2rem;
    height: 1.5rem;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: relative;
    z-index: 200;
}

@media screen and (min-width: 769px) {
    #toggleNav {
        display: none;
    }
}

#toggleNav div {
    height: 100%;
}
#toggleNav svg {
    max-width: 100%;
    height: 100%;
    width: auto;
    display: block;
    margin: auto;
}

.site-header:not(.open) #toggleNav .menu-close {
    display: none;
}
.site-header.open #toggleNav .menu-open {
    display: none;
}

@media screen and (max-width: 768px) {
    .site-header.no-fix .header-wrap {
        background: none;
    }
    .site-header.no-fix .header-wrap::before {
        width: 64%;
        height: calc(var(--header-height) + 1rem);
        clip-path: polygon(0% 0%, 100% 0%, 90% 80%, 0% 100%);
        -webkit-clip-path: polygon(0% 0%, 100% 0%, 90% 80%, 0% 100%);
    }
    .site-header {
        width: 100%;
        top: 0;
        z-index: 150;
    }
    .site-header .logo-2-pc {
        display: none;
    }
    .site-header.fixed, .site-header.open {
        top: 0 !important;
    }
    .site-header.open {
        background: var(--nav-background);
    }
    #toggleNav {
        display: block;
    }

    .site-header.open {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow-y: auto;
        z-index: 110;
    }
    #nav-block .btn {
        background: var(--color-1);
        color: var(--color-2);
    }
    #nav-block .nav-link, #nav-block li, #nav-block .profile-links {
        opacity: 0;
        transform: translate3d(0, 50px, 0);
        transition: opacity .15s ease-out, transform .15s ease-out;
        transition-delay: 0s;
    }
    .site-header.open #nav-block .nav-link, .site-header.open #nav-block li, .site-header.open #nav-block .profile-links {
        transform: translateZ(0);
        opacity: 1;
        transition: opacity .2s ease-out, transform .2s ease-out;
        transition-delay: .5s;
    }
    #nav-block {
        position: absolute;
        top: 0;
        left: 0;
        color: var(--color-1);
        width: 100%;
        padding-top: var(--header-height);
        padding-bottom: 2rem;
        display: flex;
        height: 100vh;
        box-sizing: border-box;
        flex-flow: column;
    }
    
    #site-nav {
        flex: 1;
        display: flex;
        flex-flow: column;
    }
    
    #site-nav ul {
        display: flex;
        flex-flow: column;
        width: 100%;
        flex: 1;
    }
    
    #nav-block li {
        width: 100%;
        margin-right: 0;
        box-sizing: border-box;
    }
    .site-header .menu {
        font-weight: bold;
    }
    #nav-block li a, #nav-block .nav-link {
        display: block;
        padding: 1em var(--wrap-padding);
    }
    .site-header:not(.open) #nav-block {
        -moz-transform: scaleY(0);
        transform: scaleY(0);
        -moz-transition: -moz-transform .2s ease-out 1s;
        transition: -moz-transform .2s ease-out 1s;
        transition: transform .2s ease-out 1s;
        transition: transform .2s ease-out 1s, -moz-transform .2s ease-out 1s;
    }
    .site-header.open #nav-block {
        -moz-transform: scaleX(1);
        transform: scaleX(1);
        -moz-transition: -moz-transform .2s ease-out;
        transition: -moz-transform .2s ease-out;
        transition: transform .2s ease-out;
        transition: transform .2s ease-out, -moz-transform .2s ease-out;
    }
}

.offset-site-header {
    margin-top: calc(-1 * var(--header-height));
}

/* Search */
.query-term {
    font-weight: 600;
    color: var(--color-4);
    text-decoration: underline;
}

.search-result {
    border-bottom: 1px solid rgba(25, 68, 150, 0.2);
    margin-bottom: var(--form-gap);
}

@media screen and (min-width: 769px) {
    .search-result>.news-card {
        display: grid;
        grid-template-columns: 1fr 4fr;
        gap: var(--form-gap);
    }

    .search-result .news-date {
        display: none;
    }
}

.search-result>.news-card {
    margin-bottom: var(--form-gap);
}



/* Cards */

.cards {
    position: relative;
    z-index: 20;
    display: block;
}

.card {
    z-index: 20;
}

.card-title {
    margin-bottom: .7em;
    font-weight: bold;
}

.card-thumbnail, .card-content, .card-back {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.card-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.card-content {
    display: flex;
    flex-flow: column;
    justify-content: flex-end;
    padding: 1rem;
    z-index: 10;
}

.card {
    color: var(--color-1);
    overflow: hidden;
}

.card-back {
    z-index: 0;
    transition: all 200ms;
    background: var(--gradient-1);
}



/* Video */

.video-list.owl-carousel, .links-cards {
    padding-right: var(--wrap-padding-2);
}

.video-list .owl-stage-outer, .links-cards .owl-stage-outer {
    overflow: visible;
}

.video-grid {
    display: grid;
    gap: var(--form-gap);
    grid-template-columns: 1fr 1fr 1fr;
}

.video-2-grid {
    grid-template-columns: 2fr 1fr;
}

.video-title {
    margin-top: .7em;
}

.video-header {
    margin-bottom: .7rem;
}

.video-label {
    font-weight: bold;
    color: var(--color-4);
    text-transform: uppercase;
}

@media screen and (max-width: 768px) {
    .video-grid {
        grid-template-columns: 1fr;
    }
    .video-header {
        align-items: flex-end;
        margin-bottom: .4rem;
    }
}

.archives {
    margin-top: 3rem;
}

.archives .video-header {
    display: none;
}

.video-archive {
    margin-top: 1rem;
}

.card-owl-nav {
	position: absolute;
	bottom: 100%;
	width: 100%;
    height: 1.2rem;
    display: grid;
    grid-template-columns: repeat(2, 3rem);
    gap: 2rem;
	justify-content: end;
	margin-bottom: 1rem;
}

.card-owl-nav.bottom-nav {
    bottom: auto;
	top: 100%;
	margin-top: .5rem;
}

.card-owl-nav.center-nav {
    justify-content: center;
}

.card-owl-nav.left-nav {
    justify-content: start;
}

.card-owl-nav button {
	height: 100%;
	width: 100%;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	transition: all 200ms;
	opacity: 1;
}


.owl-next {
    transform: scale(-1, 1);
    -webkit-transform: scale(-1, 1);
}

.card-owl-nav button {
	background-image: url(img/arrow-left.svg);
}

.owl-prev.disabled, .owl-next.disabled {
	display: none;
    opacity: 0;
}

.card-owl-nav.bright button, .bright-block .card-owl-nav button {
	background-image: url(img/arrow-left-white.svg);
}

@media screen and (max-width: 768px) {
    .owl-prev, .owl-next {
        width: 2rem;
    }
}

.card-owl-nav.right-nav button.disabled {
    display: block;
    opacity: 1;
}


/* Slider */
.slider-nav {
    width: max-content;
    display: grid;
    grid-template-columns: repeat(2, 3rem);
    height: 1.5rem;
}

.slider-nav .owl-prev, .slider-nav .owl-next {
    width: 100%;
    height: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}

.slider-nav button {
	background-image: url(img/arrow-right-white.svg);
}



/* Review cards */
/* Reviews */
.review-card-1 {
    display: grid;
    grid-template-columns: 10em 1fr;
    gap: var(--form-gap);
    color: var(--dark-1);
}

.review-card-1 .review-img {
    padding-top: 132%;
    height: 0;
}

.review-card-1 .review-sender {
    color: var(--color-2);
    font-size: var(--subtitle-size);
    font-weight: 600;
    letter-spacing: 0.2px;
}

.review-card-1 .review-sender-position {
    font-size: var(--text-size-1);
    letter-spacing: -0.2px;
    font-weight: 600;
    opacity: 0.4;
    margin-top: .5em;
}

.review-card-1 .review-text {
    margin-top: 1em;
}

.review-slider .owl-stage {
    display: flex;
    flex-flow: row;
}

.review-slider .owl-item + .owl-item {
    margin-left: var(--form-gap);
}

@media screen and (max-width: 768px) {
	.review-slider {
		margin-bottom: 2rem;
	}
}


/* Big review card */
.big-review-card {
    color: var(--color-1);
}

.big-review-back {
    background: linear-gradient(180deg, rgba(40, 41, 92, 0) 0%, #28295C 100%);
}

@media screen and (min-width: 769px) {
.big-review-card h3 {
    font-size: var(--headline-2);
}
}

.big-review-card h3 {
    color: inherit;
    margin: 0;
}

.big-review-card h4 {
    color: inherit;
}

.big-review-card .review-text {
    margin-top: 1.6em;
}

.big-review-slider .owl-dots {
    position: absolute;
    padding: 0 var(--wrap-padding);
    bottom: 7.5rem;
    width: calc(100% + 2rem);
    display: flex;
    flex-flow: row;
    align-items: center;
    z-index: 20;
    margin: 0 -1rem;
}

.big-review-slider .card-content {
    position: relative;
    padding: 2rem var(--wrap-padding);
    padding-bottom: 10rem;
    height: max-content;
    min-height: 46.25vw;
}

.big-review-slider button.owl-dot {
    flex: 1;
    background: var(--color-1);
    opacity: 0.2;
    height: .5rem;
    border-radius: var(--billet-radius);
    margin: 0 1rem;
    transition: all 200ms;
}

.big-review-slider button.owl-dot.active {
    opacity: 1;
}

.big-review-slider .slider-nav {
    position: absolute;
    width: 100%;
    bottom: 3rem;
    padding: 0 var(--wrap-padding);
    display: flex;
    flex-flow: row;
    justify-content: flex-end;
}

.big-review-slider .slider-nav .owl-prev {
    margin-right: 1.5rem;
}

@media screen and (min-width: 769px) {
    .review-text .more-symbol, .review-text .more-open {
        display: none;
    }
}

.review-text .more-open {
    font-weight: 600;
    color: var(--color-4);
}

.review-text .more-symbol {
    margin-right: 1em;
}

@media screen and (max-width: 768px) {
    .review-text:not(.opened) .review-second-part {
        display: none;
    }
    .review-text.opened .more-symbol {
        display: none;
    }
    .big-review-slider .card-content {
        min-height: calc(100vh - var(--header-height));
        padding-bottom: 6rem;
    }

    .big-review-card .review-text {
        margin-top: 0.5em;
    }

    .big-review-slider button.owl-dot {
        margin: 0 .6rem;
    }

    .big-review-slider .owl-dots {
        bottom: 3rem;
        margin: 0 -.6rem;
        width: calc(100% + 1.2rem);
    }
}

/* Gallery */
.gallery-image {
    padding-top: 56.56%;
}

.gallery {
    margin-top: var(--form-gap);
    display: grid;
    gap: var(--form-gap);
    grid-template-columns: 1fr 1fr 1fr;
}

@media screen and (min-width: 1025px) {
    .gallery .gallery-image:first-child {
        grid-column: 1 / 3;
        grid-row: 1 / 3;
    }
}

@media screen and (max-width: 1024px) {
    .gallery {
        grid-template-columns: 1fr 1fr;
    }
}

@media screen and (max-width: 768px) {
    .gallery {
        grid-template-columns: 1fr;
    }
}


.show-sides .owl-stage-outer {
	overflow: visible;
}

.owl-carousel.equal-heights .owl-stage {
    display: flex;
    flex-flow: row;
}

.owl-carousel.equal-heights .owl-item {
    height: auto;
}

.owl-carousel.equal-heights .owl-item>* {
    height: 100%;
}

/* Video */

.video-title {
    font-weight: bold;
    margin-top: 0.5em;
    color: var(--dark);
}

.fields {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.field-inner {
    position: relative;
    padding-top: 74.6%;
}

.field-title {
    text-transform: uppercase;
    margin-bottom: .7em;
}

.field-title-1 {
    font-weight: normal;
}

.field-title-2 {
    font-weight: bold;
}

.field-more {
    display: none;
    font-size: 0.75em;
    font-weight: bold;
}

.field-thumbnail, .field-content, .field-back {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.field-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.field-content {
    display: flex;
    flex-flow: column;
    justify-content: center;
    padding: 2rem;
    z-index: 10;
}

.field-card {
    color: var(--bright) !important;
    overflow: hidden;
}

.field-back {
    opacity: 0.5;
    z-index: 0;
    transition: all 200ms;
    background: #000000;
}

.field-card:hover .field-back {
    background: var(--blue);
}

.card-inner {
    position: relative;
    padding-top: 116.5%;
}


.post-inner {
    padding-top: 56.25%;
}


.card-title.news-title {
    font-size: 1.5em;
    line-height: 122%;
    font-weight: bold;
}

.news-more {
    font-size: 0.75em;
    font-weight: bold;
}

.cards.faces .owl-stage-outer {
    overflow: visible;
}

.contact-card .card-text {
    font-size: 0.75em;
}

@media screen and (max-width: 768px) {
    .cards.faces {
        padding-right: calc(var(--wrap-padding) * 2);
    }
}

/* News */
.news-card {
    display: block;
}

.news-thumbnail {
    padding-top: 56.34%;
    overflow: hidden;
}

h3.news-title {
    color: inherit;
    line-height: 1.33;
    font-size: var(--headline-4);
    transition: all 200ms;
}



.news-grid {
    grid-template-columns: repeat(3, 1fr);
    margin-bottom: 1rem;
}

.news-card:hover .news-thumbnail img {
    transform: scale(1.2);
    -webkit-transform: scale(1.2);
}

.news-thumbnail img {
    transition: all 200ms;
}

@media screen and (max-width: 768px) {
    .news-grid {
        grid-template-columns: 1fr;
    }
}

/* News page */

.single-post .reference {
    padding-top: 3em;
}

h1.news-title {
    font-size: var(--headline-2);
    color: var(--color-2);
}

.single-post .news-excerpt {
    
    max-width: calc(43 * var(--text-size));
}



/* Round contact */

.faces-1 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    justify-content: space-between;
    gap: 3vw;
}

.contact-card-1 .card-title {
    color: var(--color-2);
    margin: 0;
}

.contact-photo {
    margin-bottom: 1rem;
}

.contact-card-1 .contact-content {
    text-align: center;
}


@media screen and (max-width: 768px) {
    .faces-1 {
        grid-template-columns: repeat(auto-fit, minmax(13em, calc(50% - 1.5vw)));
        gap: 1.5rem 3vw;
    }
}

/* Contact card 2 (disks) */
.contact-card-2 {
    background: var(--color-1);
    color: var(--dark-1);
    padding: 1.5em;
    line-height: 1.15;
    display: flex;
    font-size: var(--text-size);
    flex-flow: column;
    min-height: 19em;
}

.faces-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.contact-card-2 .card-label>div:first-child {
    font-size: var(--caption-size);
}

.contact-card-2 .card-label>div:last-child {
    font-size: var(--caption-size-2);
    line-height: 1.4;
}

.contact-card-2 .card-header {
    align-items: start;
}

.contact-card-2 .card-label {
    color: var(--color-3);
    text-align: right;
}

.contact-card-2 .card-title {
    font-size: 0.75em;
}

.contact-card-2 .card-text {
    text-align: right;
    max-width: 20em;
    font-size: var(--caption-size);
    margin-top: auto;
    margin-left: auto;
}

.contact-card-2 .contact-photo {
    width: 62%;
    padding-top: 62%;
    margin: 1em auto;
}

.faces-2 {
    gap: 3rem var(--form-gap);
}

.faces-2 .contact-card-2 {
    margin-right: var(--wrap-padding-small);
}

@media screen and (min-width: 769px) {
    .faces-2 .contact-card-2:nth-of-type(4n-1), .faces-2 .contact-card-2:nth-of-type(4n) {
        margin-right: 0;
        margin-left: var(--wrap-padding-small);
    }
}

.contact-card-2 .contact-photo {
    border-radius: 100%;
    overflow: hidden;
}

.contact-card-2.secret-contact .card-title {
    font-size: 1.3em;
    font-weight: 600;
}

.contact-card-2.secret-contact .card-label {
    color: inherit;
}

@media screen and (max-width: 768px) {
    .faces-2 {
        grid-template-columns: 1fr;
    }

    .faces-2 .contact-card-2:nth-of-type(2n) {
        margin-right: 0;
        margin-left: var(--wrap-padding-small);
    }

    .contact-card-2 .card-title {
        font-size: 0.71em;
    }
}

/* Contact card 3 */
.contact-card-3 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--form-gap);
}

.faces-3 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4em;
}

.contact-card-3 .contact-photo {
    margin: 0;
    padding-top: 100%;
    border-radius: 100%;
    overflow: hidden;
}

.contact-card-3 .contact-content {
    margin-top: 20%;
}

.contact-card-3 .contact-name {
    font-size: var(--headline-3);
    font-weight: 400;
    line-height: 1.4;
    margin-bottom: .3em;
}

.contact-card-3 .card-text {
    font-size: var(--subtitle-3-size);
    line-height: 1.4;
}

@media screen and (max-width: 768px) {
    .faces-3 {
        grid-template-columns: 1fr;
    }
    
    .contact-card-3 {
        grid-template-columns: 1fr 1.5fr;
    }

    .contact-card-3 .contact-content {
        margin-top: 10%;
    }
}

/* Text card */

.text-card .card-title {
    color: var(--color-2);
    margin-bottom: 1em;
}

.text-card-row {
    flex-wrap: nowrap;
}

.text-card .card-text {
    color: inherit;
    flex: 1;
}

@media screen and (min-width: 769px) {
    .text-card-image {
        margin-left: 5rem;
        width: 40.7vw;
        margin-right: calc(-1 * var(--wrap-padding));
    }
}

.card-share {
    margin-top: 2.5rem;
}

.card-share-text {
    color: var(--color-2);
}

@media screen and (min-width: 769px) {
    .card-share-text {
        max-width: 18em;
        font-size: 1.5em;
        flex: 1;
    }
}

.card-share-links {
    display: flex;
    flex-flow: column;
    margin-right: 2.5rem;
    margin-left: 1rem;
}

.card-share-links a {
    width: 2.2rem;
    height: 2.2rem;
    margin-bottom: 1.5rem;
}

/* Logos */

.logos, .orgs {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3rem  3rem;
    margin: 2rem 0;
    align-items: center;
    justify-content: left;
}

.orgs {
    gap: 3rem var(--form-gap);
}

.logos-1 {
    grid-template-columns: repeat(6, 1fr);
    column-gap: 10%;
}

.logos-2 {
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
}

.logos.grid-5 {
    grid-template-columns: repeat(5, 1fr);
    gap: 3vw 6vw;
    margin-top: 3em;
}


.logos.grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

@media screen and (max-width: 768px) {
    .logos.m-grid-3 {
        grid-template-columns: repeat(3, 1fr);
        gap: 7vw 10vw;
    }

    .logos.m-grid-2 {
        grid-template-columns: 1fr 1fr;
        gap: 7vw;
    }
}



.logos a, .orgs a{
    display: flex;
    flex-flow: row;
    align-items: center;
    justify-content: center;
}

.partner-logo {
    padding-top: 50%;
    width: 100%;
    height: 0;
    position: relative;
}

.partner-logo img {
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;

    object-fit: contain;
}

.orgs a {
    border-bottom: 1px solid rgba(25, 68, 150, 0.2);
}

.org-logo.no-logo .org-name {
    text-align: center;
}

.org-logo .org-name {
    font-size: var(--caption-size);
    letter-spacing: 0.02em;
    line-height: 1.25;
    font-weight: 500;
}

.org-logo.has-logo {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: .5rem;
}

.logos img {
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.logos-2 img {
    max-width: 220px;
    max-height: 100px;
}

.logos-2 .big-logo img {
    max-height: 150px;
    max-width: 350px;
}

.big-logos {
    display: grid;
    grid-template-columns: repeat(auto-fit, calc(50% - 1rem));
    gap: 1rem;
}

.big-logos a {
    padding: 1rem;
}

.big-logos img {
    max-width: 250px;
    max-height: 250px;
    height: auto;
}

.big-logos .big-logo img {
    max-width: 400px;
}

@media screen and (max-width: 768px) {
    .logos a {
        max-height: 4rem;
    }

    .logos, .orgs {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
        justify-content: center;
    }
    .big-logos {
        grid-template-columns: repeat(auto-fit, minmax(20em, auto));
    }
    .big-logos a {
        text-align: center;
    }
    .big-logos img {
        max-width: 100% !important;
    }
    .logos a {
        text-align: center;
    }
    .big-logos img {
        max-height: 80px;
        max-width: 100%;
    }
    .logos img, .logos .big-logo img {
        max-width: 100%;
        max-height: 100%;
    }

    .logos-1 {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem 20%;
    }
}

/* Radiuses */
.billet-radius {
    border-radius: var(--billet-radius);
}

.radius {
    border-radius: var(--radius);
}

/* Post card */

.contact-card {
    line-height: 1.4;
}

.org-card .card-title {
    font-weight: bold;
    margin-bottom: .3em;
    font-size: 1.5em;
}

.contact-position {
    margin-bottom: 1.5em;
}

.contact-link {
    margin-bottom: .2em;
    display: block;
}

.contact-link:hover {
    text-decoration: underline;
}

@media screen and (min-width: 769px) {
    .org-card .card-content {
        padding-left: calc(14.62% + 1.5rem);
        background: url(img/org-label.svg) no-repeat;
        background-size: 14.62% auto;
        background-position: left center;
    }
}

@media screen and (max-width: 768px) {
    .org-card .card-title {
        font-size: 2em;
    }
}

@media screen and (min-width: 1201px) {
    .left-label h2:not(.static) {
        position: absolute;
        z-index: 10;
        transform: translate3d(-100%, -100%, 0) rotate(-90deg);
        margin-left: -1.5rem;
        color: var(--left-label-color);
        left: var(--wrap-padding);
        transform-origin: right bottom;
    }
}

.form label {
    display: block;
}

.form {
    margin: 2em 0;
}

@media screen and (max-width: 768px) {
    .form {
        font-size: 1em;
    }
}

/* form.success .form-content {
    display: none;
} */

.form-result:not(.showed) {
    display: none;
}




.big-form {
    max-width: 70em;
}

.form-grid {
    gap: 4em;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--form-gap);
    margin-bottom: var(--form-gap);
}

.form-row-1 {
    grid-template-columns: 1fr;
}

.form-row-2 {
    grid-template-columns: 1fr 1fr;
}

.form-row-3 {
    grid-template-columns: 1fr 1fr 1fr;
}

.form-row-4 {
    grid-template-columns: repeat(4, 1fr);
}

.form-row-6 {
    grid-template-columns: repeat(6, 1fr);
}

.form-row-2-1 {
    grid-template-columns: calc((100% - 2 * var(--form-gap)) * 2 / 3 + var(--form-gap)) 1fr;
}

@media screen and (max-width: 768px) {
    .form-row {
        grid-template-columns: 1fr;
    }
}

.form-row>label {
    display: flex;
    flex-flow: column;
}

.form-row>.button {
    margin-bottom: 1rem;
}

.form-row>label .link-1 {
    margin: auto 0;
}

.form-row>label.checkbox {
    justify-content: center;
}

.form-row>label>.form-control, .form-row>label>textarea {
    flex: 1;
}




.radioblock>span {
    margin-bottom: .7em;
    display: block;
}

.form-control, input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="number"], input[type="tel"], input[type="range"], input[type="date"], input[type="month"], input[type="week"], input[type="time"], input[type="datetime"], input[type="datetime-local"], input[type="color"], textarea {
    border: none;
    border-bottom: 1px solid var(--color-3);
    display: block;
    color: var(--dark);
    appearance: none;
    box-sizing: border-box;
    -webkit-appearance: none;
    padding: 0;
    padding-bottom: 0.7em;
    background: none;
    width: 100%;
    border-radius: 0;
    margin-bottom: 1rem;
    padding-top: .2rem;
    line-height: 1.4;
    font-size: var(--input-text-size);
}

@media screen and (max-width: 768px) {
    .form-control, input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="number"], input[type="tel"], input[type="range"], input[type="date"], input[type="month"], input[type="week"], input[type="time"], input[type="datetime"], input[type="datetime-local"], input[type="color"], textarea {
        padding-top: .7em;
        color: inherit;
    }
}

.ui.dropdown.form-control.form-control-style {
	border: none !important;
	border-bottom: 1px solid var(--color-4) !important;
	display: block;
	color: var(--dark) !important;
	appearance: none;
	-webkit-appearance: none;
	padding: 0 !important;
	padding-bottom: 0.7em !important;
	background: none !important;
	width: 100%;
	border-radius: 0 !important;
	min-height: 0 !important;
	line-height: 1.66;
	box-shadow: none !important;
}

.ui.dropdown.form-control>.default.text {
    padding: 0 !important;
    margin: 0 !important;
}

.ui.multiple.form-control-style.dropdown>.label {
	line-height: 1.66;
	padding: 0 !important;
	margin: 0 !important;
	font-weight: normal;
	background: none;
	box-shadow: none;
}

.ui.multiple.form-control-style.dropdown>.label>.delete.icon {
	display: none;
}

.ui.multiple.form-control-style.dropdown>.label::after {
	content: ', ';
	display: inline-block;
	margin-right: .5em;
}

.ui.multiple.form-control-style.dropdown>.label:last-of-type::after {
	display: none;
}

.ui.upward.selection.dropdown.visible.form-control-style {
	border-radius: 0 !important;
}

.ui.search.selection.dropdown>input.search {
    line-height: 1.66;
    padding: 0;
}

.ui.dropdown .menu>.item {
	font-size: 1em;
}

.ui.form-control.search.dropdown>.text, .ui.form-control.search.dropdown>input.search {
	margin: 0;
	line-height: 1.66;
}

.ui.dropdown>.dropdown.icon {
	display: none;
}

*[disabled] {
    color: var(--gray);
}

form h4 {
    margin-bottom: 1.5em;
    margin-top: 2em;
}

.form-container .wpcf7 br {
    display: none;
}

.wpcf7 form .wpcf7-response-output {
    border: none;
    padding: 0;
    margin: 1rem 0 1rem;
    font-size: var(--text-size-1);
}

input+.wpcf7-not-valid-tip {
    margin: -.7rem 0 .7rem;
    color: var(--gray);
}

.wpcf7-not-valid-tip {
    font-size: var(--text-size-1);
}

textarea {
    border: 1px solid var(--color-3);
    border-radius: .5em;
    padding: .7em 1.4em;
}

.textarea-label {
    position: absolute;
    margin-left: 2em;
    margin-top: .7em;
}

.textarea-label+textarea {
    padding-top: 1.4em;
}

textarea+small {
    margin-top: -1em;
}

input+small {
    margin-bottom: 1.4em;
    margin-top: -1em;
}

.radiorow, .radiorow .wpcf7-radio {
    display: flex;
    flex-flow: row;
    justify-content: space-around;
    margin-top: .5rem;
    margin-bottom: 1rem;
    width: max-content;
    font-size: var(--text-size);
}

span.wpcf7-list-item {
    margin-left: 0;
    margin-right: 2em;
}

.radiorow label {
    margin-right: 3em;
}

@media screen and (max-width: 768px) {
    .radiorow.m-col, .radiorow.m-col .wpcf7-radio {
        margin-bottom: 0;
    }
    .radiorow.m-col label, .radiorow.m-col .wpcf7-list-item-label {
        margin-bottom: 2em;
        margin-right: 0;
    }
}


.form-control-cont {
    position: relative;
}

.form-control-cont .svg {
    cursor: pointer;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: auto;
    display: flex;
    align-items: center;
    pointer-events: none;
}

.file-row {
    flex-wrap: nowrap;
}

.file-row .main-col {
    overflow: hidden;
}

.file-row .download-col {
    margin-left: 1rem;
}

.file-row .upload-text {
    padding-top: 1rem;
}

.file-choose label, label.file-choose {
    position: relative;
    display: flex;
    flex-flow: row;
    align-items: center;
    margin-bottom: .3em;
    cursor: pointer;
    overflow: hidden;
}

.file-choose>div {
    overflow: hidden;
    flex: 1;
}

.file-label {
    cursor: pointer;
}

.file-choose a {
    cursor: pointer;
}

.file-choose.form-control-choose::after, .file-choose-1::before {
    content: ' ';
    display: block;
    margin-left: .7rem;
    height: 1.2rem;
    width: 1.2rem;
    background: url(img/file.svg) no-repeat;
    background-position: center;
    background-size: contain;
}

.file-choose.file-choose-attachment::before {
    background-image: url(img/attachment.svg);
}

.file-choose-1::before {
    margin-left: 0;
    margin-right: .7rem;
}

.file-choose .filename {
    white-space: nowrap;
    display: block;
    flex: 1;
    overflow: hidden;
    margin: 0;
    text-overflow: ellipsis;
}

.file-choose.selected .noloaded-text, .file-choose:not(.selected) .uploaded-text {
    display: none;
}

.file-row {
    display: grid;
    grid-template-columns: 7rem 1fr;
    gap: var(--lk-gap);
}

.file-cont {
    padding-top: 133%;
    border: 1px solid var(--color-4);
    transition: all 200ms;
}

.file-cont .file {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.file.loaded svg {
    display: none;
}

.avatar.loaded .avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.file-cont svg {
    transition: all 200ms;
}

.file-row .upload-text {
    max-width: 10em;
}

.file-choose.selected .file-cont {
    border-color: var(--color-3);
}

.file-choose.selected .file-cont .avatar-img {
    display: none;
}

.file-choose.selected .file-cont svg {
    fill: var(--color-3);
    display: block;
}

.file-choose .link-1 {
    display: block;
    margin-top: .7em;
}

.file-choose h3 {
    margin-bottom: .8em;
}

.select-form-control .svg svg {
    height: 0.5rem;
    transition: transform 100ms;
}

.select-form-control select:focus+.svg svg {
    transform: rotate(-180deg);
}

.form-control-cont svg, .form-control-cont svg path {
    fill: var(--color-2);
}

select.form-control, .form-control-cont select {
    cursor: pointer;
}

select option {
    color: var(--dark);
}

*::placeholder, .ui.default.dropdown.form-control:not(.button)>.text, .ui.dropdown.form-control:not(.button)>.default.text {
    color: var(--gray);
}

.acception {
    margin: 1.5rem 0;
    font-size: 1em;
    max-width: 53em;
    color: inherit;
}

.acception a {
    text-decoration: underline;
}

@media screen and (max-width: 768px) {
    .acception {
        font-size: var(--caption-size);
        margin-top: 0;
        line-height: 1.33;
    }
}

/* Form input */
.form-input .form-control, .form-input input[type="text"], .form-input input[type="email"], .form-input input[type="url"], .form-input input[type="password"], .form-input input[type="search"], .form-input input[type="number"], .form-input input[type="tel"], .form-input input[type="range"], .form-input input[type="date"], .form-input input[type="month"], .form-input nput[type="week"], .form-input input[type="time"], .form-input input[type="datetime"], .form-input input[type="datetime-local"], .form-input input[type="color"], .form-input textarea, .form-input select {

    background-color: transparent;
    border: none;
    margin: 0 0 0.4em 0;
    padding: 1.2em;
    margin: 0;
}

.form-input {
    background: var(--form-input-background);
    border: none;
    border-radius: 0.5rem;
    margin: 0;

    cursor: pointer;

    display: flex;
    flex-flow: row;
}


.form-input textarea {
    cursor: text;
    height: 100%;
}

.form-input:not(.focused) .input-label.invisible {
    transform: translateY(150%) scale(1.4);
    -webkit-transform: translateY(150%) scale(1.4);
}

.form-input .input-label+*::placeholder {
    opacity: 0;
}

.form-input select[data-chosen=""], .form-input select[data-chosen="0"] {
    color: var(--gray);
}

.form-input .input-label {
    transform-origin: left center;
    -webkit-transform-origin: left center;
    transition: all 100ms;

    cursor: text;
}

.form-input.search-input {
    cursor: text;
}

.form-input.search-input *::placeholder {
    color: var(--text-color);
}

.form-input.search-input::before {
    content: ' ';
    display: block;
    width: 1.5em;
    margin: 0 0.7em;
    height: auto;
    background-image: url(img/search-input.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left center;

}

.form-input.search-input input {
    padding-left: 0;
}

.bright-block .form-input .input-label, .bright-block .form-input *::placeholder {
    color: var(--gray);
}

.bright-block .form-input .form-control, .bright-block .form-input input[type="text"], .bright-block .form-input input[type="email"], .bright-block .form-input input[type="url"], .bright-block .form-input input[type="password"], .bright-block .form-input input[type="search"], .bright-block .form-input input[type="number"], .bright-block .form-input input[type="tel"], .bright-block .form-input input[type="range"], .bright-block .form-input input[type="date"], .bright-block .form-input input[type="month"], .bright-block .form-input nput[type="week"], .bright-block .form-input input[type="time"], .bright-block .form-input input[type="datetime"], .bright-block .form-input input[type="datetime-local"], .bright-block .form-input input[type="color"], .bright-block .form-input textarea, .bright-block .form-input select {
    color: var(--text-color);
}

.bright-block .form-input {
    background: var(--color-1);
}

.copyright, .agree-links {
    font-size: var(--caption-size);
}

/* Footer */

.site-footer {
    padding: 2.5rem 0;
    box-sizing: border-box;
    background: var(--footer-background);
    color: var(--footer-color);
    position: relative;
    font-size: var(--footer-text-size);
}

#footer-wrap {
    width: 100%;
}

@media screen and (min-width: 769px) {
    #footer-creds {
        font-size: var(--caption-size);
        justify-content: flex-end;
    }

    #footer-links a {
        text-align: right;
    }
}

#footer-links a {
    display: block;
}

@media screen and (max-width: 768px) {
    #footer-links {
        margin-bottom: 1.5em;
    }
}

.site-footer-1 .footer-wrap {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 5vw;
    align-items: center;
    justify-content: space-between;
}

.site-footer-2 .footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2em;
}

@media screen and (max-width: 768px) {
    .site-footer-2 .footer-grid { 
        grid-template-columns: 1fr;
        text-align: center;
    }

    .site-footer-2 .social-links {
        justify-content: end;
        margin: auto 0;
    }
    
    .site-footer-2 #footer-1 {
        margin-bottom: 1em;
    }
}


.site-footer .copyright {
    margin-top: 1.5rem;
}

.site-footer .logo {
    margin: 0;
}

.site-footer h3 {
    margin-bottom: 1rem;
    font-size: var(--text-size);
    color: inherit;
    letter-spacing: 0.015em;
    text-transform: uppercase;
}

.site-footer h4 {
    margin-top: 1rem;
    font-size: 0.75em;
}

.site-footer-1 .footer-col {
    max-width: 30em;
    width: 100%;
    overflow: hidden;
    padding-top: 1.3em;
}

.site-footer-1 #footer-1 {
    max-width: 15em;
    padding-top: 0;
}

@media screen and (min-width: 769px) {
    #footer-2 {
        justify-content: space-between;
    }
}

.footer-data {
    font-size: 0.75em;
    margin-top: .7rem;
}

.footer-link {
    overflow: hidden;
    width: 100%;
    text-overflow: ellipsis;
    display: block;
    line-height: 1.5;
    margin-bottom: 1em;
    font-size: var(--footer-link-text-size);
}

#copyright-row {
    margin-top: 4rem;
}

#copyright-1 {
    max-width: 24em;
}

@media screen and (max-width: 768px) {
    #copyright-row {
        margin-top: 1.5rem;
        grid-template-columns: 1fr 1fr;
    }
    #copyright-1 {
        padding-right: .5em;
    }
    .site-footer {
        line-height: 1.2;
    }
    .footer-link {
        margin: 0;
    }
    .site-footer .logo {
        height: 3rem;
    }
    .site-footer h3 {
        margin-bottom: .5rem;
        line-height: 1.2;
        min-height: 2.4em;
    }
    #footer-2 .row {
        flex-flow: column;
    }
    #footer-2 .col {
        margin: 0 0 1.5rem;
    }
}

@media screen and (min-width: 769px) {
    .site-footer-3 .footer-wrap {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--form-gap);
    }
    
}


.site-footer-3 .footer-link, .site-footer-3 .contact-label, .site-footer-3 .copyright {
    font-weight: normal;
    opacity: 0.6;
    font-size: inherit;
}

.site-footer-3 .links-row .footer-link {
    margin: 0;
}

.site-footer-3 .copyright {
    line-height: 1.4;
    margin-top: 1.5em;
    max-width: 28em;
}

.site-footer-3 .footer-link-1 {
    font-weight: 600;
}

.site-footer-3 .footer-col {
    display: flex;
    flex-flow: column;
}

.site-footer-3 .button {
    width: max-content;
}

.site-footer-3 .contact-value {
    font-size: var(--headline-4);
    font-weight: 500;
    line-height: 1.21;
}

.site-footer-3 .contact-addr .contact-value {
    font-size: inherit;
    line-height: 1.4;
}

.site-footer-3 .footer-contact {
    margin-bottom: 2em;
}

.site-footer-3 .contact-label {
    margin-bottom: .3rem;
}

.site-footer-3 .footer-contacts {
    margin-bottom: var(--form-gap);
}

@media screen and (min-width: 769px) {
    .site-footer-3 #footer-1 {
        padding-right: 7em;
    }
}


/* forms */

.reg-form .wpcf7-response-output {
    margin: 1em 0;
    border-color: var(--blue);
    border-top: none;
    border-bottom: none;
    border-right: none;
    box-sizing: border-box;
}

.search-box input[type="search"] {
    line-height: 1.4;
    background: none;
    border: 2px solid var(--color-2);
    border-radius: var(--billet-radius);
    display: block;
    padding: 1em 0.7em;
    width: 100%;
    border-right: none;
    margin: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.search-box button {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    min-width: 15em;
    border-width: 2px;
}

.search-box {
    display: flex;
    flex-flow: row;
    margin: 0 0 3rem;
}

@media screen and (max-width: 768px) {
    .search-box input[type="search"] {
        padding-top: .3em;
        padding-bottom: .3em;
    }
    
    .search-box button {
        margin: 0;
        min-width: auto;
    }
}

/* Post */

.back-link svg {
    width: 2.7rem;
    margin-right: 1rem;
    vertical-align: middle;
}

.back-link svg, .back-link svg path, .back-link svg rect {
    fill: var(--gray);
}

.back-link {
    color: var(--gray) !important;
    margin-bottom: 2.5rem;
    display: block;
}

.single-post p {
    margin-bottom: 1.5em;
}

.thumbnail-wrap {
    padding: 0 var(--wrap-padding);
}

@media screen and (min-width: 769px) {
    .thumbnail-wrap {
        max-width: 68vw;
        margin-left: 0;
    }
}

.single-post .site-content {
    padding: 4em 0;
}

.news-full-thumbnail {
    padding-top: 56.26%;
    margin: 1rem 0 2rem;
}


.pre-entry-header {
    margin-top: 2rem;
}

.entry-header {
    margin-bottom: 2rem;
}

h1.entry-title {
    margin-bottom: .3em;
}

.single-post .entry-content {
    margin-top: 2rem;
}

.after-entry-footer {
    padding: 1rem var(--wrap-padding-2);
}

.single-field .after-entry-footer {
    padding: 1rem var(--wrap-padding);
}

.single-field .main-content {
    margin-bottom: 4rem;
}

.single-field .field-title-2 {
    font-weight: 900;
}

.single-field .main-content p {
    margin-bottom: 2em;
}

.single-field .field-row {
    padding: 0 var(--wrap-padding);
    display: flex;
    flex-flow: row;
}

.single-field .field.has-org {
    flex: 1;
    padding-right: 6rem;
}



@media screen and (max-width: 768px) {
    .single-field .field-row {
        flex-flow: column;
    }
    .single-field .field.has-org {
        padding-right: 0;
    }
    .single-field .main-content p {
        margin-bottom: 0.6rem;
    }
    .single-field .main-content {
        margin-bottom: 2rem;
    }
}

.field-info p {
    margin-bottom: 1.5em;
}

@media screen and (max-width: 768px) {
    .pre-entry-header {
        margin-top: 1rem;
    }
    .entry-header {
        margin-bottom: 1rem;
    }
}

/* Social */

#social-block {
    position: fixed;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-flow: column;
    z-index: 100;
    width: 1.5em;
}

#social-block .label {
    transform: rotate(90deg);
    transform-origin: 0 1.5em 0;
    width: 10em;
    height: 1.5em;
    padding-left: 3em;
    background: linear-gradient(to right, var(--main-color) 0, var(--main-color) 2em, transparent 2em, transparent 100%) no-repeat;
    background-size: 100% 0.12em;
    background-position: center;
}

@media screen and (max-width: 768px) {
    #social-block {
        transform: none;
        position: static;
        width: auto;
        flex-flow: row;
    }
    #social-block .social-links {
        flex-flow: row;
    }
    #social-block .social-links a {
        height: 2em;
        width: 2.5em;
        margin-bottom: 0;
        margin-right: 2rem;
    }
}

.site-header.static .vk-link {
    background-image: url(img/social/bright/vk.svg);
}

.site-header.static .inst-link {
    background-image: url(img/social/bright/instagram.svg);
}

.site-header.static .twitter-link {
    background-image: url(img/social/bright/twitter.svg);
}

.site-header.static .youtube-link {
    background-image: url(img/social/bright/youtube.svg);
}

/* Documents */

.document {
    position: relative;
    display: inline-block;
    margin-top: 1.5em;
    padding-bottom: 1rem;
    padding-top: 1rem;
    padding-left: 3rem;
    max-width: 19em;
    line-height: 1.2;
}

.document::before {
    content: ' ';
    position: absolute;
    width: 2rem;
    height: 3rem;
    top: 50%;
    transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    left: 0;
    background: url(img/document.svg) no-repeat;
    background-size: contain;
    background-position: left center;
}

.document-pdf::before {
    background-image: url(img/document-pdf.svg);
}

.document::after {
    content: ' ';
    position: absolute;
    width: 0;
    transition: all 200ms;
    height: 1px;
    box-sizing: border-box;
    border-bottom: 1px solid var(--dark);
    bottom: .8rem;
    left: 3rem;
}

.bright-block .document::before {
    background-image: url(img/document-bright.svg);
}

.bright-block .document::after {
    border-color: var(--bright);
}

.document:hover::after {
    width: calc(80% - 4rem);
}

@media screen and (max-width: 768px) {
    .document {
        padding: .5rem 0 .5rem 2.5rem;
    }
    .document::after {
        bottom: .4rem;
        left: 2.5rem;
    }
}

.underlined {
    display: block;
    padding-bottom: 1em;
    border-bottom: 1px solid var(--color-3);
}

.underlined.c4 {
    border-color: var(--color-4);
}

.task-document {
    line-height: 1.4;
    text-decoration: underline;
    color: var(--color-2);
    margin-top: 0;
}

.task-document::after {
    display: none;
}

@media screen and (min-width: 769px) {
    .site-header .logo-2-mobile {
        display: none;
    }
}

@media screen and (max-width: 768px) {
    .descr {
        font-size: 1em;
    }
    .wrap-2 {
        padding: 2rem var(--wrap-padding);
    }
    .wrap .wrap {
        padding: 0;
    }
    .container-2 {
        padding-top: 3em;
    }
    .text-card-row {
        flex-flow: column-reverse;
    }
    .text-card-image {
        margin-bottom: 1em;
    }
    .card-share {
        flex-flow: column;
        margin-top: 0;
    }
    .card-share-links {
        flex-flow: row;
        margin: auto;
        min-width: 60%;
    }
    .card-share-links a {
        flex: 1;
        margin: 1.5em 0;
    }
    .card-meta {
        font-size: 0.75em;
    }
    .entry-content li {
        padding: 0;
        padding-left: 2em;
    }

    .reg-form {
        max-width: 100%;
    }
}

@media screen and (max-width: 1200px) {
    .fields {
        grid-template-columns: repeat(auto-fit, minmax(11.5em, auto));
        gap: .2rem;
    }
    .field-content {
        padding: .5rem;
    }
    /* .field-back, .field-thumbnail {
        display: none;
    }
    
    .field-card {
        background: var(--blue-2);
    }

    .field-more {
        display: flex;
    } */
    .thumbnail-wrap {
        padding: 0;
    }
}

.drop {
    font-weight: 300;
}

.drop .drop-display {
    cursor: pointer;
    background: none;
    border: 2px solid var(--gray);
    border-radius: 5px;
    color: var(--m-dark-blue);
    padding: 0.5rem 1rem;
    min-height: auto;
}

.drop .drop-display .item {
    padding: 0;
    border: none;
    line-height: 1.5;
    height: auto;
    margin: 0;
    margin-right: 2px;
}

.drop .drop-display:after {
    top: 0;
    right: 0.5rem;
    content: ' ';
    width: 1rem;
    height: 100%;
    background: url(img/down.svg) no-repeat;
    background-size: auto 0.5rem;
    background-position: center;
}

.drop-display>div {
    height: 1.5em;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-right: 0.5rem;
}

.drop.open .drop-options {
    position: relative;
    background: transparent;
    border: 2px solid #465;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    border-top: none;
    margin-top: -5px;
    padding-top: 5px;
    overflow: hidden;
    max-height: 100%;
    box-shadow: none;
}

.drop.open .drop-options>div {
    overflow-y: auto;
    max-height: 200px;
}

.drop .drop-options a {
    color: var(--gray);
}

.drop .drop-options a:hover {
    color: var(--gray);
    box-shadow: none;
}

.drop .drop-display {
    font-size: 1em;
}

.checkbox {
    display: block;
}


label.checkbox>input[type="checkbox"],
label>input[type="radio"] {
    position: absolute;
    width: 1.3em;
    height: 1.3em;
    z-index: -1;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
}

label.checkbox>input[type="checkbox"]+span,
label:not(.hide-radio)>input[type="radio"]+span,
.drop .drop-options a {
	display: flex;
	flex-flow: row;
	cursor: pointer;
	align-items: center;
	color: var(--unchecked-text);
	
}

label.checkbox>input[type="checkbox"]+span::before,
label:not(.hide-radio)>input[type="radio"]+span::before,
.drop .drop-options a::before {
	content: ' ';
	display: inline-block;
	vertical-align: middle;
	height: 1.3em;
	padding-left: 1.3em;
	margin-right: .8em;

	background: url(img/checkbox-off.svg) no-repeat;
	background-position: left center;
	background-size: auto 100%;
}

label>input[type="checkbox"]+span .checkbox-on-text,
input[type="radio"]+span .checkbox-on-text {
    display: none;
}

label>input[type="checkbox"]:checked+span .checkbox-off-text,
input[type="radio"]:checked+span .checkbox-off-text {
    display: none;
}

label>input[type="checkbox"]:checked+span .checkbox-on-text,
input[type="radio"]:checked+span .checkbox-on-text {
    display: inline-block;
}

label:not(.hide-radio)>input[type="radio"]+span::before {
    background-image: url(img/radio-off.png);
}

label.checkbox>input[type="checkbox"]:checked+span::before,
.drop .drop-options a.checked::before {
	background-image: url(img/checkbox-on.svg);
}

.bright-block label.checkbox>input[type="checkbox"]+span::before {
	background-image: url(img/checkbox-off-bright.png);
}

.bright-block label.checkbox>input[type="checkbox"]:checked+span::before {
	background-image: url(img/checkbox-on-bright.png);
}

label>input[type="radio"]:checked+span::before {
	background-image: url(img/radio-on.png);
}

label.checkbox>input[type="checkbox"]:checked+span,
.drop .drop-options a.checked,
label>input[type="radio"]:checked+span {
    color: var(--checked-text);
}

@media screen and (max-width: 768px) {
    label.checkbox>input[type="checkbox"]+span,
    label:not(.hide-radio)>input[type="radio"]+span,
    .drop .drop-options a {
        min-height: 2em;
    }
    
    label.checkbox>input[type="checkbox"]+span::before,
    label:not(.hide-radio)>input[type="radio"]+span::before,
    .drop .drop-options a::before {
        height: 2em;
        padding-left: 2em;
        margin-right: 1rem;
    }
}

.radio-row {
    align-items: center;
    margin-bottom: 1rem;
}

.radio-buttons {
    display: grid;
    width: max-content;
    text-align: left;
}

.radio-buttons p {
    margin: 0;
}

.radio-buttons label {
    margin-bottom: 1em;
}

.drop .drop-options a {
    padding: 0.5em 1em;
    padding-left: 2.5rem;
    background-position-x: 0.5rem;
}

/* Jobs */

/* Jobs block */

.jobs-block h1 {
	margin-bottom: 1em;
}



.jobs-block .row {
    align-items: flex-start;
    flex-flow: row;
}

.jobs-filter {
    font-size: var(--text-size-1);
}

.jobs-block .jobs-filter {
    width: 17rem;
    margin-right: 4rem;
    margin-bottom: 1rem;
}

.jobs-block .jobs {
    flex: 1;
}

@media screen and (max-width: 768px) {
    .jobs-block .row {
        flex-flow: column;
    }
    .jobs-block {
        padding-top: 0;
        padding-bottom: 1rem;
    }
    .jobs-block .jobs {
        width: 100%;
    }
    .jobs-block .jobs-filter {
        width: 100%;
        margin-right: 0;
    }
    .jobs-block .search-box {
        margin: 1rem 0 1rem;
    }
}

/* Jobs filters */

.jobs-filter h4 {
    text-transform: none;
    margin-bottom: 1.5em;
    font-size: 1em;
}

.jobs-filter .form-control {
    border: 1px solid var(--gray);
    color: var(--gray);
    padding-left: 1em;
    border-radius: 0;
}

.jobs-filter .block label {
    color: var(--gray);
    line-height: 1;
    font-size: 1em;
    display: block;
    margin-bottom: 1em;
}

.jobs-filter .block {
    margin-bottom: 2.5rem;
}

.jobs-filter .filter-go {
	margin-top: 1.5rem;
}

.jobs-filter .drop .drop-display, .jobs-filter .drop .drop-options {
    border-radius: 0;
    border-width: 1px;
    border-color: var(--gray);
}

.clear-filters svg {
    vertical-align: middle;
    margin-right: 0.5rem;
}

.clear-filters a {
    color: var(--gray);
}

.clear-filters svg {
    fill: var(--gray);
}

.clear-filters a:hover {
    color: var(--dark);
    box-shadow: none;
}

.clear-filters a:hover svg {
    fill: var(--dark);
}

@media screen and (min-width: 769px) {
    .jobs-filter .apply-btn {
        margin-top: 2rem;
    }
}

@media screen and (max-width: 768px) {
    .jobs-filter .block {
        margin-bottom: 1.5rem;
    }
    .clear-filters {
        margin: 1.5rem 0;
    }
}

.mobile-spoiler-header {
    display: none;
    text-align: left;
    font-size: var(--headline-3);
    font-weight: 600;
    color: var(--color-2);
    padding: 0.5rem 0;
    cursor: pointer;
}

.mobile-spoiler-header span {
    vertical-align: middle;
}

.mobile-spoiler-header svg {
    margin-left: 0.7rem;
    width: auto;
    height: .5rem;
    vertical-align: middle;
    transition: transform 100ms;
}

.mobile-spoiler.opened>.mobile-spoiler-header svg {
    transform: rotate(-180deg);
}

@media screen and (max-width: 768px) {
    .mobile-spoiler-header {
        display: block;
    }
    .mobile-spoiler-content {
        display: none;
        padding: 1rem 0;
    }
    .mobile-spoiler {
        background: var(--main-color);
    }
}

.jobs-filter .ui.dropdown.form-control.form-control-style, .ui.dropdown.form-control.box-style, .form-control.box-style {
    border: 2px solid var(--outline-color) !important;
    padding: .7em !important;
    border-radius: var(--billet-radius) !important;
}

.jobs-filter .ui.form-control.search.dropdown>.text, .ui.form-control.box-style.search.dropdown>.text  {
    left: .7em;
	top: auto;
	color: inherit;
}

.jobs-list, .jobs {
    margin-bottom: 3rem;
}

.post-list {
    margin-bottom: 1rem;
}

.jobs-list .post, .post-list .post {
    border: 1px solid var(--gray);
    border-bottom: none;
    background: var(--color-1);
    padding: 1.5rem 2rem;
}

.jobs-list .post:last-child {
    border-bottom: 1px solid var(--gray);
}

.post-list .one-post {
    position: relative;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--gray);
}

.pagination a {
    display: block;
}

.pagination.page-1 .pagination-prev, .pagination.last .pagination-next, .pagination.page-1 .pagination-first, .pagination.last .pagination-last {
    display: none;
}

.pagination.page-1 .pagination-more-1, .pagination.page-2 .pagination-more-1 {
    display: none;
}

.pagination.last .pagination-more-2 {
    display: none;
}

.pagination.pre-last .pagination-more-2, .pagination.page-2 .pagination-more-1 {
    display: none;
}

.pagination.pre-pre-last .pagination-more-2, .pagination.page-3 .pagination-more-1 {
    display: none;
}

.pagination.page-2 .pagination-prev.pagination-int, .pagination.pre-last .pagination-next.pagination-int {
    display: none;
}

.pagination {
    display: flex;
    flex-flow: row;
    justify-content: flex-end;
    align-items: center;
}

.pagination-current {
    font-weight: bold;
}

.pagination-link span {
    display: none;
}

.pagination-int {
    width: 2.5rem;
    height: 2.5rem;
    line-height: 2.5rem;
    text-align: center;
    margin: 0 0.5em;
}

.pagination.last .pagination-current {
    margin-right: 0;
}

.pagination.page-1 .pagenation-current {
    margin-left: 0;
}

.pagination-more {
    margin: 0 0.5em;
    user-select: none;
    opacity: 0.7;
}

.pagination-link {
    color: var(--text-color);
}

.pagination-current, .pagination-int:hover {
    color: var(--color-1) !important;
    background: var(--color-2);
    border-radius: 100%;
}

/* .pagination-prev, .pagination-first {
    color: var(--gray) !important;
}

.pagination-next, .pagination-last {
    color: var(--dark) !important;
} */

.pagination-prev.pagination-link {
    margin-right: 1.5rem;
}

.pagination-next.pagination-link {
    margin-left: 1.5rem;
}

.job-main-content h3 {
    font-size: 1.25em;
    margin-bottom: 1em;
}

.job-main-content .content {
    margin-bottom: 3rem;
}

.job .company-logos {
    width: max-content;
}

.job-title {
    color: var(--color-2);
    margin-bottom: 0;
    flex: 1;
    font-size: 1.25em;
    margin-right: 1em;
}

.post-meta {
    color: var(--gray);
    font-size: 0.7em;
    display: block;
}

.job-header, .post-header {
    margin-bottom: 1em;
}

.job-header, .job-footer, .post-footer {
    display: flex;
    flex-flow: row;
}

.job-text, .post-text {
    margin: 1em 0;
    line-height: 1.8;
}

.job-link, .post-link {
    color: var(--color-4) !important;
    font-weight: 600;
    background: none;
}

.account-company .job-link {
    display: none;
}

.job-main-content, .post-main-content {
    padding-left: var(--wrap-padding);
    padding-right: 3rem;
}

.job-info, .post-info {
    font-size: 1.25em;
    line-height: 1.4;
    width: 15em;
    box-sizing: content-box;
    padding: 4rem var(--wrap-padding) 2rem;
    color: var(--color-1);
    background: var(--color-4);
    clip-path: polygon(0% 0%, 100% 1rem, 100% 100%, 1rem 100%);
    -webkit-clip-path: polygon(0% 0%, 100% 1rem, 100% 100%, 1rem 100%);
    height: max-content;
}

.job-info-block, .post-info-block {
    margin-bottom: 1.5rem;
}

.job-info-block strong, .post-info-block strong {
    display: block;
}

.job-info-block:last-child, .post-info-block:last-child {
    margin-bottom: 0;
}

.job-salary, .job-date, .post-date {
    margin-left: auto;
    white-space: nowrap;
}

.post-meta .date {
    margin-left: auto;
    margin-right: 0;
}

svg {
    display: block;
    max-height: 100%;
    height: auto;
    width: auto;
}

.m-icon svg {
    display: none;
}

.pagination-link svg {
    width: 3rem;
    height: auto;
    vertical-align: middle;
}

@media screen and (max-width: 768px) {
    .m-icon svg {
        display: block;
    }
    .jobs-list .post, .post-list .post {
        padding: 1rem;
    }
    .job-title {
        font-size: 1em;
    }
    .job-footer {
        margin-top: 1.5rem;
    }
    .jobs-list, .post-list {
        margin-bottom: 1rem;
    }
    .jobs {
        margin-bottom: 0;
    }
    .m-icon span {
        display: none;
    }
    .search-box button svg {
        width: 1rem;
        height: auto;
        max-height: 100%;
    }
    .pagination {
        padding: 0 1rem;
        width: max-content;
        margin: auto;
        justify-content: center;
    }
    .pagination-link svg {
        width: 2rem;
    }
    .pagination-next.pagination-link {
        margin-left: auto;
    }
    .pagination-prev.pagination-link {
        margin-right: auto;
    }
    .pagination-more {
        margin: 0;
    }
}

.int-block {
    display: flex;
    flex-flow: row;
    align-items: flex-start;
}

.int-block>span {
    color: var(--color-4);
    font-size: var(--headline-1);
    line-height: 72%;
    font-weight: bold;
    margin-right: var(--form-gap);
    width: 1.7em;
    height: 1.7em;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--color-2);
    border-radius: 100%;
}

.int-block .content {
    flex: 1;
}

@media screen and (max-width: 768px) {
    .int-block>span {
        position: absolute;
        width: 3em;
        height: 3em;
    }

    .int-block h4 {
        padding-left: 6.5em;
        min-height: 5.5em;
        display: flex;
        align-items: center;
    }
}

.int-blocks-1 {
    margin-top: 1.5rem;
}

.int-block-1 span.int {
    color: var(--color-4);
    font-size: var(--headline-2);
    line-height: 72%;
    font-weight: bold;
    margin-right: var(--form-gap);
    width: 1.8em;
    height: 1.8em;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--color-2);
    border-radius: 100%;
    position: relative;
    margin-right: var(--form-gap);
}

.int-block-1 .content {
    font-size: var(--text-size-1);
}

.int-block-1 .head::after {
    content: ' ';
    flex: 1;
    height: 2px;
    background: var(--color-2);
}

.int-block-1 .head {
    margin-bottom: 1.5rem;
    display: flex;
    flex-flow: row;
    align-items: center;
}

@media screen and (min-width: 769px) {
    .int-blocks-1 .int-block-1:last-of-type .head::after {
        display: none;
    }
}

.int-block-2 .int {
    font-size: var(--numbers-text-size);
    font-weight: bold;
}

.int-block-2 h3 {
    font-size: var(--text-size);
    color: inherit;
    font-weight: 700;
}

.int-block-2 .text {
    font-size: var(--text-size-1);
}

/* Page icon link */

.aspect-img.page-icon {
    padding-top: 61.7%;
    margin-bottom: .5rem;
}

.page-icons {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.page-icon-link {
    text-align: center;
}

.page-icon-link .page-icon {
    opacity: 0.8;
    transition: all 200ms;
}

.page-icon-link .page-title {
    opacity: 0.7;
    transition: all 200ms;
}

.page-icon-link:hover .page-title, .page-icon-link:hover .page-icon {
    opacity: 1;
}

.page-icon img {
    object-fit: contain;
}

/* Blocks */
.image-background {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.image-background.image-dark-foreground {
    position: relative;
}

.image-background.image-dark-foreground::before {
    content: ' ';
    position: absolute;
    display: block;
    background: var(--dark-1);
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    opacity: 0.5;
    z-index: 0;
}

.infoblock+.infoblock {
    margin-top: 5em;
}

.infoblock {
    line-height: 1.65;
}

.infoblock .headline {
    letter-spacing: 0.2px;
    font-weight: 600;
    font-size: var(--subtitle-size);
}

.infoblock {
    max-width: 15em;
}

@media screen and (max-width: 768px) {
    .infoblock+.infoblock {
        margin-top: 2.5em;
    }
    
    .infoblock {
        line-height: 1.21;
    }
    
    .infoblock .headline {
        margin-bottom: .7em;
    }
}

/* Info */

.info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(auto, 19em));
    gap: 2vw;
    justify-content: space-between;
}

.info-grid, .infograph, .infograph p {
    font-weight: 500;
    line-height: 1.4;
}

.infograph h4 {
    color: var(--color-4);
}

@media screen and (max-width: 768px) {
    .info-grid {
        gap: 7vw;
        grid-template-columns: repeat(auto-fit, minmax(auto, 16em));
    }
}

.bright-block .infograph h4 {
    color: inherit;
}

/* Steps */

.steps {
    justify-content: space-between;
}

.step {
    text-align: center;
    max-width: 18em;
    margin: auto;
    line-height: 1.4;
}

.step .int {
    display: block;
    width: max-content;
    text-align: center;
    font-weight: 900;
    font-size: 2.4em;
    line-height: 2.4em;
    height: 2.4em;
    width: 2.4em;
    box-sizing: border-box;
    margin: auto;
    border: 2px solid var(--color-1);
    border-radius: 100%;
}

@media screen and (max-width: 768px) {
    .steps {
        grid-template-columns: 1fr;
        gap: 2em;
    }
    .steps-2 {
        grid-template-columns: 1fr 1fr;
    }
    .steps-auto {
        grid-template-columns: minmax(10em, 12em);
    }
    .step {
        text-align: left;
        max-width: unset;
        width: 100%;
        max-width: 12em;
        margin: 0;
    }
    .step .int {
        margin: 0;
        font-size: 1.4em;
        line-height: 2.2em;
    }
}

.step-2 {
    position: relative;
}

@media screen and (min-width: 769px) {
    .step-2 .step-int {
        position: absolute;
        top: 0;
        right: 100%;
        width: var(--wrap-padding);
        text-align: center;
        font-size: 11em;
    }
}

.step-2 .step-int {
    font-weight: 900;
    line-height: .7;
}

.step-2 h2 {
    margin-bottom: 1em;
}

.step-2 h3 {
    margin-bottom: 1.5em;
}

.step-2 p {
    margin-top: .7em;
    margin-bottom: 1.5em;
}

.step-2-content {
    gap: 8vw;
}

@media screen and (max-width: 768px) {
    .step-2 .step-int {
        font-size: 6.5em;
        line-height: .9;
        margin-right: 1rem;
    }
    .step-2 h2 {
        margin-bottom: 0;
        max-width: 7em;
    }
    .step-2 {
        margin-bottom: 2em;
    }
    .step-2 .step-header {

        margin-bottom: 2.5em;
        display: flex;
        flex-flow: row;
        align-items: flex-end;
    }
}

.steps-3 {
    gap: 3rem;
}


.step-3 {
    max-width: 15em;
}

.step-3 .step-header {
    display: flex;
    flex-flow: row;
    align-items: flex-end;
    color: var(--color-5);
    margin-bottom: 1em;
}

.step-3.disabled .step-header, .step-3.disabled {
    color: var(--gray);
}

.step-3 .step-header h2 {
    margin: 0;
    color: inherit;
    margin-right: 1rem;
    font-size: 3.2em;
    line-height: 1;
}

@media screen and (max-width: 768px) {
    .steps-3 {
        gap: 1.5rem;
    }
}


/* Bright */

.bright-block {
    color: var(--color-1);
}

.bright-block-1 {
    background: var(--color-2);
}

.bright-block small, .bright-block .input-label {
    color: var(--color-1);
}

.bright-block .link-2 {
    color: var(--color-1);
}

.bright-block .link-2::after {
    background-image: url(img/link-arrow-bright.svg);
}

.bright-block .form-control, .bright-block input[type="text"], .bright-block input[type="email"], .bright-block input[type="url"], .bright-block input[type="password"], .bright-block input[type="search"], .bright-block input[type="number"], .bright-block input[type="tel"], .bright-block input[type="range"], .bright-block input[type="date"], .bright-block input[type="month"], .bright-block input[type="week"], .bright-block input[type="time"], .bright-block input[type="datetime"], .bright-block input[type="datetime-local"], .bright-block input[type="color"], .bright-block textarea {
    color: var(--color-1);
    border-color: var(--color-1);
}

.bright-block label>input[type="radio"]+span, .bright-block label>input[type="checkbox"]+span {
    color: var(--color-1);
}

.bright-block input[type="radio"]+span {
    background-image: url(img/radio-off-bright.svg);
}

.bright-block *::placeholder {
    color: var(--color-1);
}

.bright-block *[disabled] {
    color: var(--color-1) !important;
}

.bright-block .form-control::placeholder, .bright-block .form-control.file-choose .filename {
    color: var(--gray);
    transition: all 100ms;
}

.bright-block .form-control.file-choose.selected .filename {
    color: var(--color-1);
}

.bright-back {
    background: var(--bright);
    color: var(--dark);
}

.bright-back h1, .bright-back h2 {
    color: var(--dark-1);
}

/* Colors */

.red {
    color: var(--red);
}

.red-2 {
    color: var(--red-2);
}

.red-3 {
    color: var(--red-3);
}

.red-4 {
    color: var(--red-4);
}

.gray {
    color: var(--gray);
}

.c1 {
    color: var(--color-1);
}

.c2 {
    color: var(--color-2);
}

.c3 {
    color: var(--color-3);
}

.c4 {
    color: var(--color-4);
}

.c5 {
    color: var(--color-5);
}

.c6 {
    color: var(--color-6);
}

.c7 {
    color: var(--color-7);
}

.b1 {
    background: var(--color-1);
}

.b2 {
    background: var(--color-2);
}

.b3 {
    background: var(--color-3);
}

/* Modal */

.blocker {
    z-index: 1000;
}

.modal {
    padding: 2rem;
    border-radius: 0;
}

.message-modal {
    border-radius: 0;
    padding: 2rem;
    text-align: center;
}

.message-modal .buttons-row {
    margin-top: 1.5rem;
}

.modal form:not(.success) .form-result {
    margin-bottom: 1rem;
}


.modal.inner-close a.close-modal {
    right: 1.6rem;
    top: 1.6rem;
    width: 1.5rem;
    height: 1.5rem;
}

.modal.white-close a.close-modal {
    background-image: url(img/close.svg);
}

/* List */
.list, .list-block ul {
    font-size: var(--text-size-1);
    margin-top: .7em;
}

.list li, .list-block li {
    position: relative;
    margin-bottom: .7em;
    padding-left: 2rem;
    line-height: 1.5;
}

.list li::before, .list-block li::before {
    content: ' ';
    position: absolute;
    display: block;
    width: .5rem;
    height: .5rem;
    background: var(--color-2);
    border-radius: 100%;
    left: 0;
    top: .3rem;
}

/* Tabs */

.tabs {
    list-style: none;
    display: flex;
    flex-flow: row wrap;
}

.tabs>a, .tabs>li {
    position: relative;
    flex: 1;
    height: 100%;
}

.tabs-1 a {
    padding: 1rem;
    text-align: center;
}

.tabs-1>a, .tabs-1>li {
    color: var(--tabs-1-color);
    border-bottom: 1px solid var(--tabs-1-color);
}

.tabs-1 li {
    background: none;
    margin: 0;
    padding-left: 0;
}

.tabs-1 li a {
    display: block;
    height: 100%;
    position: relative;
}

.tabs-1>a.active, .tabs-1>li.active {
    color: var(--tabs-1-active-color);
}

.tabs-1>a.active::after, .tabs-1>li.active a::after {
    content: ' ';
    position: absolute;
    display: block;
    height: 6px;
    width: 100%;
    left: 0;
    background: var(--tabs-1-active-color);
    bottom: 0;
}

/* Auth */
.blocker {
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: var(--header-height);
    overflow-y: auto;
}

.modal.auth-modal {
    width: 100%;
    padding: 5vw 5vw 0;
    background: transparent;
    max-width: 100%;
    height: 100%;
    box-shadow: none;
}

.auth-modal .form-row {
    grid-template-columns: 1fr;
}

.auth-modal a.close-modal {
    display: none;
}

.modal .form {
    padding: 0;
    margin-bottom: 0;
}

.buttons-row {
    align-items: center;
}

.buttons-row .button-col .button {
    display: block;
    min-width: 13em;
}

.auth-tabs, .auth-content-tabs {
    gap: var(--wrap-padding);
}

.auth-content-tabs {
    padding-bottom: 5vw;
}

.auth-form .forgot-link {
    font-weight: bold;
    color: var(--color-1);
}

.auth-form .button-col, .auth-form .forgot-link {
    margin: 1.5rem 0 2rem;
    display: block;
    text-align: center;
}

.reg-form .button-col, .reg-form .forgot-link {
    margin-top: 0;
}

@media screen and (min-width: 769px) {
    .auth-form .back-auth-link {
        text-align: right;
    }
    .auth-form .form-result {
        margin-bottom: 1.5rem;
    }
}

.auth-form .support-link {
    text-align: center;
}

@media screen and (max-width: 768px) {
    .auth-form .form-result {
        margin-bottom: 1rem;
    }
    .auth-form .button-col{
        margin: 1.5rem 0;
    }
    .auth-form .forgot-link {
        margin: 0;
    }
    .modal.auth-modal {
        width: 100%;
        clip-path: none;
        -webkit-clip-path: none;
        padding: .5rem 1.5rem 1rem;
    }
    .buttons-row {
        justify-content: center;
    }
    .tabs-1>a.active::after {
        height: 4px;
    }
}

/* Program */

.program {
    width: 100%;
    table-layout: fixed;
    text-align: left;
    line-height: 1.6;
    margin: 1.5rem 0;
}

.program th {
    line-height: 1.6;
    font-weight: 600;
    padding: .5em 0;
}

.program tr {
    display: grid;
    gap: var(--form-gap);
}

.program-events p {
    margin-bottom: .4em;
}

.program-events tr {
    grid-template-columns: 3em 13em 1fr 17em 25em;
}

.program tbody tr {
    margin-top: 1.5rem;
}

.program a {
    color: var(--color-2);
    font-weight: 600;
    font-size: var(--text-size-1);
}

.program .time-col, .program-event {
    min-height: 2rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}

.program-day-text {
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}


.program-day {
    padding-bottom: 2rem;
}

.program-day-text p:last-child {
    margin-bottom: 1em;
}

.schedule-3 .program tr {
    grid-template-columns: 4em 1fr;
}

.program .time-col, .program-event {
    padding-bottom: 1rem;
}

@media screen and (min-width: 769px) {
    .program-nav .owl-prev, .program-nav .owl-next {
        right: 0;
        height: 1.5rem;
    }
    .program-nav .owl-prev {
        top: 0;
    }
    .program-nav .owl-next {
        bottom: 0;
    }
}

.program .event-more {
    margin-top: 1.5rem;
}


.program-save {
    margin-top: -60%;
}

.account-company .program-events .add-col {
    display: none;
}

.account-company .program-events tr {
    grid-template-columns: 15em 1fr;
}

@media screen and (min-width: 769px) {
    .program-events .add-col label>input[type="checkbox"]+span svg {
        display: none;
    }
}

.program-day .next-day {
    position: absolute;
    bottom: .7rem;
    right: 3rem;
    margin-right: var(--form-gap);
    transform: translateY(50%);
    -moz-transform: translateY(50%);
}

@media screen and (max-width: 768px) {
    .program-days {
        margin: 2rem 0;
    }
    .program-events tbody tr {
        margin-top: 0.5rem;
    }
    .program-nav {
        width: 100%;
        position: absolute;
        bottom: 0;
        height: 1.5rem;
        display: flex;
        flex-flow: row;
    }
    .program-day .next-day {
        right: 2rem;
    }
    .program-nav .owl-prev, .program-nav .owl-next {
        position: relative;
    }
    .program-nav .owl-next {
        margin-left: auto;
    }
    .program-nav .owl-prev {
        margin-right: auto;
    }
    .program-events {
        margin: 1rem 0;
    }
    .program-events tr {
        grid-template-columns: 4em 1fr 10em 1.5rem;
    }
    .program-events td {
        display: flex;
        flex-flow: column;
        justify-content: flex-start;
        padding-bottom: .3em;
    }
    .program .number-col {
        display: none;
    }
    .program-events .add-col label>input[type="checkbox"]+span {
        background: none !important;
        padding: 0;
    }
    .program-events .add-col label>input[type="checkbox"]+span span {
        display: none;
    }
    .program-events .add-col label span svg {
        width: 100%;
        height: auto;
    }
    .program-events .add-col label span svg, .program-events .add-col label span svg path {
        fill: transparent;
        transition: all 200ms;
    }
    .program-events .add-col label>input[type="checkbox"]:checked+span svg path {
        stroke: var(--color-2);
        fill: var(--color-2);
    }
    .program-events th.add-col span {
        display: none;
    }

    .program-events .descr-col {
        display: none;
    }

    .program tr.empty {
        display: none;
    }

    .program tfoot {
        display: none;
    }

    .program-events tbody tr {
        font-size: var(--text-size-1);
    }

    .program-events .descr {
        margin-top: 1em;
        opacity: 0.6;
    }
}


.schedule-simple .program-events tr {
    grid-template-columns: 13em 2fr 1fr;
}

@media screen and (max-width: 768px) {
    .schedule-simple .program-events tr {
        grid-template-columns: 3.5rem 1fr;
    }
}


@media screen and (min-width: 769px) {
    .schedule-3 .events-col {
        display: flex;
        flex-flow: row;
    }

    .schedule-3 .program-event {
        flex: 1;
        overflow: hidden;
    }
    
    .schedule-3 .program-event+.program-event {
        margin-left: var(--form-gap);
    }
}

.schedule-3 .event-block-label {
    color: var(--color-2);
}

.schedule-3 .event-dir {
    font-weight: 600;
    color: var(--color-2);
    margin-bottom: .7em;
    font-size: var(--text-size);
}

.events-col-3 {
    font-size: var(--text-size-1);
}

.schedule-3 .events-col-1 .event-block-subject .event-block-label, .schedule-3 .events-col-1 .event-block-place .event-block-label {
    display: none;
}

.schedule-3 .events-col-1 .event-block-subject .event-block-content {
    font-weight: bold;
}

.schedule-3 .program {
    line-height: 1.4;
}

@media screen and (max-width: 768px) {
    .schedule-3 .events-col {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--form-gap);
    }
}

.more-block.opened .more-open {
    display: none;
}

/* Companies */
.companies-block {
    margin-bottom: 2rem;
}
.companies-block .btn-4 {
    margin-top: 2rem;
}

.companies-block .companies {
    margin-top: .7rem;
}

.companies {
    gap: var(--form-gap);
}

@media screen and (max-width: 768px) {
    .logos.companies {
        grid-template-columns: repeat(auto-fit, minmax(auto, calc((100% - 2 * var(--form-gap)) / 3)));
        justify-content: left;
    }
}

.billet {
    transition: all 200ms;
    height: 6em;
    cursor: pointer;
    padding: 1em 1.5em;
    border: 1px solid var(--color-8);
}

.s-billet {
    padding: 1.2em;
    background: var(--color-1);
    border-radius: var(--billet-radius);
    color: var(--text-color);
    line-height: 1.4;
    box-shadow: var(--billet-box-shadow);
}


/* Partners block */
.partners {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4rem var(--wrap-padding-small);
}

.partner {
    display: flex;
    align-items: center;
    justify-content: start;
    flex-flow: column;
}

.partner .resume-link {
    font-size: var(--text-size-1);
    text-align: center;
    font-weight:600;
    margin-top:1em;
    line-height: 1.4;
}

.partner .partner-link {
    margin: 0 auto;
    width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.general-partner {
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4rem var(--wrap-padding-small);
    grid-column: 1 / 5;
    border-bottom: 1px solid rgba(0, 0, 0, 0.5);
    
    padding-bottom: var(--form-gap);
}

.general-partner .partner-logo {
    margin: 0;
}

.general-partner-main {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-column: 2 / 4;
    align-items: center;
    gap: 4rem var(--wrap-padding-small);
}

.general-label {
    font-weight: 600;
}

@media screen and (min-width: 769px) {
    .partner-go-button {
        padding: 0 1.5vw;
    }
}

.partner-go-button .button {
    color: var(--color-1);
    background: var(--color-2);
    border-color: var(--color-2);
}

@media screen and (max-width: 768px) {
    .partners{
        grid-template-columns: 1fr 1fr;
        row-gap: 2rem;
    }

    .general-partner {
        grid-template-columns: 1fr 1fr;
        grid-column: 1 / 3;
        row-gap: .5rem;
        padding-bottom: 1.5rem;
    }

    .general-partner-main {
        row-gap: 1rem;
        grid-template-columns: 1fr;
        grid-column: auto;
    }

    .general-label {
        grid-column: 1 / 3;
    }

}
/* Social billet */


.social-billet {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1.6px solid var(--color-2);
    font-weight: bold;
    color: var(--color-3);
    height: 3.5rem;
}

.social-billet.active {
    color: var(--color-2);
}

.social-billet.selected {
    color: var(--color-1);
    background: var(--color-2);
}

.ints-row {
    display: flex;
    flex-flow: row wrap;
    margin: 0 0 0.3rem;
}

.ints-row a {
    width: 2.5rem;
    color: var(--color-3);
    border: 1px solid var(--color-8);
    font-size: 0.9em;
    box-sizing: border-box;
    display: block;
    text-align: center;
    line-height: 2.5rem;
    transition: all 100ms;
}

.ints-row a.complete {
    color: var(--color-4);
    border-color: var(--color-4);
}

.ints-row a.current {
    background: var(--color-4);
    color: var(--color-1);
    font-weight: bold;
}

/* .ints-row a.current {
	border: 1px solid var(--m-dark-blue);
} */

@media screen and (max-width: 1200px) {
    .ints-row {
        margin: 0 0 0.3rem;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(2rem, auto));
        gap: 2px;
        justify-content: left;
    }
    .ints-row a {
        margin: 0;
        font-size: 0.66em;
    }
}

.off-interact {
    user-select: none;
}

/* Courses */

.course {
    padding-bottom: 1.5rem;
    margin-bottom: 2rem;
}

@media screen and (min-width: 769px) {
    .course-thumbnail {
        width: 25em;
        margin-right: var(--form-gap);
		height: 100%;
    }
}

.course-thumbnail {
    display: flex;
}

.course-title {
    font-size: 1.25em;
    margin-bottom: 1em;
}

.course-toggler {
    margin-top: 1em;
}

.course-footer {
    margin-top: 3rem;
}

.course-program tr {
    grid-template-columns: 15em 15em 1fr;
}

.course-content {
    display: none;
}

.course-content {
    margin-top: 2rem;
}

.course-program-label {
    text-transform: none;
    color: var(--color-2);
}

.account-company .course-join {
    display: none;
}

@media screen and (max-width: 768px) {
    .course-program tr {
        grid-template-columns: 7em 7em 1fr;
    }

    .course-thumbnail {
        width: 100%;
        margin-bottom: 1.5rem;
    }
    .course-footer {
        margin-top: 1.5rem;
    }
}

/* Logined */

body.logined .unlogined-block {
    display: none;
}

/* Cat page */
.cat-projects .project {
    margin: 0;
}

.cat-header {
    padding-top: 5rem;
    padding-bottom: 4rem;
}

.category h2 {
    color: var(--color-2);
}

/* Company page */

.tax-company .site-header .header-wrap::before {
    display: none;
}

.tax-company .site-header .header-wrap {
    background: none;
}

.tax-company .company-preview {
    padding-top: 23.44%;
    width: 100%;
    margin-top: calc(-1 * var(--header-height));
    clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 4vw), 0% 100%);
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100%  calc(100% - 4vw), 0% 100%);
}

.company-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tax-company .company-preview.no-loaded {
    background: var(--color-4);
}

.company-preview-fore {
    background: rgba(0, 0, 0, 0.4);
}

.company-content {
    position: relative;
    z-index: 1;
}

.tax-company .site-header {
    margin-bottom:0;
}

.company-header h1 {
    color: var(--color-1);
    margin: 0;
    margin-right: 3rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.company-header {
    align-items: flex-end;
    color: var(--color-1);
    padding-bottom: 9vw;
}

.company-main {
    margin-top: 4rem;
}

@media screen and (min-width: 769px) {
    .company-promo {
        width: 60%;
    }

    .company-description {
        margin-right: 2rem;
    }
}

.tax-company .company-jobs {
    margin-top: 4rem;
    margin-bottom: 6rem;
    max-width: 55em;
}

@media screen and (max-width: 768px) {
    .tax-company .company-preview {
        padding: 0;
    }

    .tax-company .company-header {
        position: relative;
        padding-top: var(--header-height);
    }

    .company-header .company-site {
        display: none;
    }

    .company-main {
        margin-top: 2rem;
    }

    .company-promo {
        margin-top: 1.5rem;
    }

    .tax-company .company-jobs {
        margin: 2rem 0;
    }


}

.tax-company #toggleNav svg, .tax-company #toggleNav svg path, .tax-company #toggleNav svg rect {
    fill: var(--color-1);
}

/* Schedule */
.schedule .program .date-col {
    display: none;
}

.schedule .program tr {
    grid-template-columns: 15em 1fr;
}

@media screen and (max-width: 768px) {
    .schedule .program tr{
        grid-template-columns: 7em 1fr;
    }
}

/* Logined */

body.logined .unlogined-block {
    display: none;
}

body.logined .reg-block {
    display: none;
}

body.logined:not(.facultetus) .reg-link {
    display: none;
}

body.event-page:not(.fl-builder-edit) #block5 {
	display: none;
}

/* Spoiler */
.spoiler .spoiler-content {
    
    overflow: hidden;
    display: none;
    opacity: 0;
    transition: opacity 200ms;
}

.spoiler-header {
    cursor: pointer;
}

.spoiler.opened>.spoiler-content {
    opacity: 1;

}

.spoiler-arrow svg {
    transition: all 200ms;
}

.spoiler-header.opened .spoiler-arrow svg {
    transform: rotate(-180deg);
}

/* Grids and rows */
.grid, .fl-grid-row .fl-col-group {
    gap: var(--form-gap);
}


@media screen and (min-width: 769px) {
    .row-style-1 {
        padding-left: var(--wrap-padding);
        align-items: flex-start;
    }
    
    .row-style-1>div:first-child {
        margin-right: var(--wrap-padding-small);
        flex: 1;
    }
    
    .row-style-1>div:last-child {
        flex: 0.5;
    }
    
    .row-style-2 {
        align-items: end;
        flex-wrap: nowrap;
    }

    .row-style-2 .fact {
        width: var(--wrap-padding);
        margin-right: var(--form-gap);
    }

}

.row-style-2>div:last-child {
    flex: 1;
}

@media screen and (max-width: 768px) {
    .row-style-2 {
        flex-flow: column-reverse;
    }

    .row-style-2>div {
        width: 100%;
    }

    .row-style-2 .fact {
        margin-top: 1.5rem;
    }
}
/* Cat card */
.cat-card {
    width: 100%;
    height: 100%;
    padding: 1.5em;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-flow: column;
    border: 2px solid var(--color-2);
    border-radius: var(--billet-radius);
    font-size: var(--headline-4);
    letter-spacing: 0.015em;
    font-weight: 600;
    text-align: center;
    line-height: 1.2;
    min-height: 11em;
    transition: all 100ms;
}

.cats-grid {
    margin-bottom: 2rem;
}

.cat-card-image {
    position: relative;
    width: 5em;
    height: 5em;
    margin-bottom: 1rem;
}

.cat-card-image>* {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.cat-card-title {
    max-width: 10em;
}

.cat-card-title.cat-3-color {
    max-width: 11em;
}

.cat-card * {
    transition: all 100ms;
}

a.cat-card:hover {
    border-color: var(--color-2) !important;
    background: var(--color-2);
}

a.cat-card:hover * {
    color: var(--color-1) !important;
}

/* Int card */
.int-card {
    text-align: left;
    align-items: flex-start;
    min-height: 5em;
    justify-content: center;
    padding: 0.5em 1.5em;
}

.int-card .label {
    line-height: 1.56;
    font-size: .8em;
    max-width: 13em;
}

.int-card .int {
    font-weight: 700;
    font-size: 1.7em;
    letter-spacing: 0.025em;
    line-height: 1.18;
}

/* Subscribe form */
.subscribe-form {
    max-width: 30em;
}
.subscribe-form .wpcf7 {
    display: flex;
    align-items: center;
}

.subscribe-form input[type="email"] {
    margin-bottom: 0;
    padding-top: 1.4em;
}

.subscribe-form .wpcf7-not-valid-tip {
    display: none;
}

.subscribe-form .button {
    height: max-content;
}


/* Button + text blocks */
.button-text-blocks, .button-text-block {
    margin: 2rem 0;
}

.button-text-blocks .block .button-1, .button-text-block .button-1 {
    margin-bottom: 1.5rem;
}

/* Screen video */ 
.screen-video-block {
	height: 100vh;
	width: 100vw;
	overflow: hidden;
}

.screen-video-block .embed-container {
	width: 178vh;
    min-width: 100vw;
    box-sizing: border-box;
    min-height: 110vh;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
}

/* Fact */
.fact {
    font-size: var(--text-size-1);
    line-height: 1.8;
    font-weight: 500;
    margin-top: auto;
}

.fact::before, .button-1, a.button-1 {
    display: block;
    font-size: var(--caption-size);
    color: var(--color-2);
    font-weight: 600;
    border-radius: 2rem;
    border: 2px solid var(--color-2);
    padding: .5em 1.5em;
    width: max-content;
    margin-bottom: .5rem;
}

.button-1 {
    margin-top: .8rem;
}

.fact::before {
    content: 'Интересный факт';
}

.fact .date {
    font-size: var(--headline-3);
    margin-top: .5rem;
    font-weight: 700;
}

/* H4 block */
@media screen and (max-width: 768px) {
    .h4-block {
        position: relative;
        padding-left: var(--wrap-padding-small);
    }
    
    .h4-block::before {
        content: ' ';
        position: absolute;
        width: calc(var(--wrap-padding-small) + var(--wrap-padding));
        margin-left: -1rem;
        opacity: 0.4;
        background: var(--color-1);
        height: 3px;
        top: 1em;
        left: calc(-1 * var(--wrap-padding));
    }
    
    .h4-block:nth-child(3n - 2)::before {
        margin-left: -1.5rem;
    }
    
    .h4-block:nth-child(3n - 1)::before {
        margin-left: -2.5rem;
    }
}

/* Animations */
body:not(.fl-builder-edit) .wow {
    visibility: hidden;
}

@media screen and (max-width: 768px) {
    .wow.mobile-no-animate {
        visibility: visible;
    }   
}

@media screen and (max-width: 768px) {
    .mobile-no-delay {
        animation-delay: 0s;
    }
    .mobile-no-animate {
        animation: none !important;
    }
}

/* Scales */
/* Scales */
.scale {
	width: 100%;
	position: relative;
}

.scale-container {
	display: flex;
	flex-flow: row;
	position: relative;
}

.scale-1 {
    background: linear-gradient(90deg, #FC466B 0%, #3F5EFB 100%);
	border-radius: 5em;
	max-width: 30em;
	min-height: 3em;
	padding: 0 1.5em;
}

.scale-1 .scale-filled {
	position: absolute;
}

.scale-1 .scale-slider {
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    background: var(--color-1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4em;
    height: 4em;
    box-sizing: border-box;
    text-align: center;
    margin: 0.5em 0;
    font-size: var(--caption-1-size);
    color: var(--color-2);
    font-weight: 600;
	position: relative;
  }


.scale-1::before, .scale-1::after {
    display: block;
    position: absolute;
    font-size: var(--caption-size);
    bottom: 100%;
}

.scale-1::before {
    content: '0%';
    left: 0;
}

.scale-1::after {
    content: '100%';
    right: 0;
}

.scale-2 {
    background: var(--color-1);
    border-radius: var(--billet-radius);
    overflow: hidden;
}

.scale-2 .scale-filled {
    height: .5em;
    background: var(--site-color-2);
}

/* Calendar */
.calendar-carousel {
    width: 100%;
    position: relative;
}

table.calendar-content {
    width: 100%;
    table-layout: fixed;
    border-collapse: separate;
    text-align: center;
    margin: 1.5em 0;
    font-weight: 600;
    font-size: var(--text-size-1);
    letter-spacing: -0.2px;
}

.calendar-content .day-of-week {
    color: var(--gray-1);
}

.calendar-content td.disabled {
    color: var(--gray-2);
}

.calendar-row {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-content td {
    padding: 1.5em 1em;
}

.calendar-content th {
    padding: 1em 0;
}

.calendar .month-title {
    text-align: center;
    font-size: var(--subtitle);
    font-weight: 600;
    letter-spacing: 0.2px;
    line-height: 1.21;
    margin-bottom: 1.5em;
}

.calendar-content .red-point {
    position: relative;
}

.calendar-content .red-point::before {
    content: ' ';
    display: inline-block;
    position: absolute;
    width: .5em;
    height: .5em;
    background: var(--red-2);
    border-radius: 100%;
    top: 65%;
    left: 50%;
    transform: translateX(-50%);
}

.calendar-nav .owl-prev, .calendar-nav .owl-next {
    width: 1.6em;
    height: 1.6em;
    display: inline-block;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

.calendar-nav {
    position: absolute;
    top: 0;
    width: 100%;
    left: 0;
    height: 1.6em;
    transform: translateY(-15%);
    -webkit-transform: translateY(-15%);
    text-align: center;
}

.calendar-nav .owl-prev {
    background-image: url(img/calendar-left.svg);
    margin-right: 12em;
}

.calendar-nav .owl-next {
    background-image: url(img/calendar-right.svg);
}

.calendar-nav .owl-prev.disabled, .calendar-nav .owl-next.disabled {
    cursor: default;
}

.calendar-nav .owl-prev.disabled {
    background-image: url(img/calendar-left-disabled.svg);
}

.calendar-nav .owl-next.disabled {
    background-image: url(img/calendar-right-disabled.svg);
}

.calendar-content .date {
    position: relative;
}

.calendar-content .date::before {
    content: ' ';
    position: absolute;
    width: 3.2em;
    height: 3.2em;
    border-radius: 100%;
    left: 50%;
    top: 50%;
    transform: translate3d(-50%, -50%, 0);
    -webkit-transform: translate3d(-50%, -50%, 0);
    z-index: -1;

}

.calendar-content .date-chooser.choosed {
    color: var(--color-1);
}

.calendar-content .date-chooser.choosed .date::before {
    background: var(--color-2);
}

.calendar-content .current-day {
    color: var(--color-1);
}

.calendar-content .current-day::before {
    background: var(--gray-2);
}

.free-calendar .free-dates {
    margin: .5em 0 2em;
}

.free-calendar .subtitle {
    margin-bottom: .6em;
}


/* Block variants */
.block-variant:not(.active) {
    display: none;
}

/* Chat */
.chat-message {
    margin-bottom: 2em;
    display: grid;
    grid-template-columns: 1fr 10em;
}

.chat, .chats, .messages-block {
    height: 30em;
    display: flex;
    flex-flow: column;
}

.chat-messages, .chats .chats-list {
    flex: 1;
    overflow-y: auto;
}

.chat-message-sender {
    font-weight: 600;
    letter-spacing: -0.2px;
    font-size: var(--text-size-1);
    line-height: 1.43;
}

.chat-message-text {
    line-height: 1.67;
    font-size: var(--caption-size);
    margin: .5em 0;
}

.chat-message-date {
    text-align: right;
    font-weight: 600;
    font-size: var(--caption-size);
    letter-spacing: -0.02em;
    line-height: 1.67;
    color: var(--gray-1);
}

.chat-input {
    background: var(--color-6);
    padding: 1em 1.5em;
}

.status-block.chat {
    padding: 0;
}

.chat-messages {
    padding: 1.5em;
}

.chat-input .row {
    align-items: start;
}

.chat-input .chat-send-button {
    margin: 0;
    margin-left: 2em;
}

.chat-textarea {
    border: none;
    background: var(--color-1);
    height: 3.2em;
    margin: 0;
}

.chat-messages .chat-message:last-of-type {
    margin-bottom: 0;
}

.status-block.messenger {
    padding: 0;
    display: grid;
    grid-template-columns: 15em 1fr;
}

.messenger .chats {
    padding: 1.5em 0;
    border-right: 2px solid var(--color-6);
}


.messenger .chats h2 {
    border-bottom: 2px solid var(--color-6);
    padding: 0 1rem .5em;
    margin: 0;
}

.chat-preview {
    cursor: pointer;
    display: grid;
    grid-template-columns: 70px 1fr;
    padding: 1em 1rem;
    border-bottom: 2px solid var(--color-6);
    gap: 1em;
    font-size: var(--text-size-1);
    align-items: center;
    transition: all 50ms;
}

.chat-preview-photo {
    border-radius: 100%;
    overflow: hidden;
    border: 3px solid var(--color-1);
}

.chat-preview-last-message {
    font-size: var(--caption-size);
    color: var(--gray);
    line-height: 1.67;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-preview-member {
    font-weight: 600;
    line-height: 1.43;
    letter-spacing: -0.2px;
    margin-bottom: .2em;
}

.chat-preview-main {
    width: 100%;
    overflow: hidden;
}

.chat-preview.choosed {
    background: var(--color-6);
}

.chats-block .flex-center {
    height: 100%;
}

.chats-block {
    height: 100%;
}

@media screen and (max-width: 768px) {
    .status-block.messenger {
        box-shadow: none;
        border-radius: 0;
        grid-template-columns: 1fr;
    }
    
}

/* Video contacts */
/* Video contacts */
.video-contacts {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--form-gap);
}

.video-contact-card .video {
    cursor: pointer;
    padding-bottom: 180%;
    margin-bottom: 1.5rem;
}

.video-contact-card .card-text {
    line-height: 1.41;
    letter-spacing: -0.01em;
    margin-top: 1rem;
}

.video-stub {
    transition: all 200ms;
}

.manual-video.active .video-stub {
    opacity: 0;
}

.manual-video::after {
    content: ' ';
    display: block;
    position: absolute;
    z-index: 10;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(img/play-contact.svg) no-repeat;
    background-position: center;
    background-size: 15% auto;
}

.manual-video.active::after {
    display: none;
}

.video-contact-card .button-block {
    box-sizing: border-box;
    display: block;
    position: absolute;
    bottom: 0;
    width: 100%;
    text-align: center;
    padding: 1rem;
    z-index: 20;
}

.video-contact-card .button-block .button {
    width: 100%;
}

.video-contacts .card-owl-nav.bottom-nav {
    margin-top: 1rem;
}

@media screen and (max-width: 768px) {
    
    .video-contacts {
        padding-right: 20vw;
    }
    
    .video-contacts .social-links {
        zoom: 1.6;
    }
}

/* Loaders */
/* Loading bar */


.loader {
	text-indent: -9999em;
	width: 2.5em;
	height: 2.5em;
	border-radius: 50%;
	background: var(--color-5);
	background: -moz-linear-gradient(left, var(--color-5) 10%, rgba(24, 160, 251, 0) 42%);
	background: -webkit-linear-gradient(left, var(--color-5) 10%, rgba(24, 160, 251, 0) 42%);
	background: -o-linear-gradient(left, var(--color-5) 10%, rgba(24, 160, 251, 0) 42%);
	background: -ms-linear-gradient(left, var(--color-5) 10%, rgba(24, 160, 251, 0) 42%);
	background: linear-gradient(to right, var(--color-5) 10%, rgba(24, 160, 251, 0) 42%);
	position: relative;
	-webkit-animation: load3 1.4s infinite linear;
	animation: load3 1.4s infinite linear;
	-webkit-transform: translateZ(0);
	-ms-transform: translateZ(0);
	transform: translateZ(0);
}

.loader:before {
	width: 50%;
	height: 50%;
	background: var(--color-5);
	border-radius: 100% 0 0 0;
	position: absolute;
	top: 0;
	left: 0;
	content: '';
}

.loader:after {
	width: 75%;
	height: 75%;
	background: var(--color-1);
	border-radius: 50%;
	content: '';
	margin: auto;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

@-webkit-keyframes load3 {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@keyframes load3 {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

body.loading {
	cursor: progress;
}

.loading-bar {
    position: fixed;
    bottom: 2em;
    right: 2em;
    background: var(--gray-1);
    z-index: 1000;
    border-radius: var(--billet-radius);
	padding: 1.2em 1.5em;
	min-width: 16em;
	opacity: 0;
	display: none;
	transition: all 100ms;
}

body.loading .loading-bar {
	display: block;
	opacity: 1;
}

.loading-bar .loader:after {
	background: var(--gray-1);
}

.loading-bar .label {
    font-weight: 500;
    margin-left: 1.5em;
}

.loading-bar .row {
    align-items: center;
}

form.data-ended .auto-loader .auto-loader-more, form.going .auto-loader .auto-loader-more {
    display: none;
}

