@font-face {
    font-family: "regular";
    src: url("../fonts/SFPro/SFProText-Regular.ttf") format("truetype");
    font-style: normal;
    font-weight: normal;
}

@font-face {
    font-family: "bold";
    src: url("../fonts/SFPro/SFProText-Bold.ttf") format("truetype");
    font-style: normal;
    font-weight: normal;
}

@font-face {
    font-family: "light";
    src: url("../fonts/SFPro/SFProText-Light.ttf") format("truetype");
    font-style: normal;
    font-weight: normal;
}
















body {
    margin: 0;
    padding: 0;
    background-color: #f1f1f1;
}

a {
    text-decoration: none;
    color: var(--main-color);
    font-size: 0.75vw;
}

p {
    font-size: 0.65vw;
}

h1,
h2,
h3,
p {
    margin: 0;
    padding: 0;
}









.hidden {
    display: none !important;
}







/* Reset Default Styles */

form {
    margin-block-end: 0;
}

textarea {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    border: none;
    background: none;

    padding: 0;
    margin: 0;
    box-shadow: none;

    &:hover {
        background-color: unset;
        border: unset;
        box-shadow: unset;
        color: unset;
        outline: unset;
    }

    &:focus {
        background-color: unset;
        border: unset;
        box-shadow: unset;
        color: unset;
        outline: unset;
    }
}

input {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    border: none;
    background: none;

    padding: 0;
    margin: 0;
    box-shadow: none;

    &[type="number"] {
        -moz-appearance: textfield;
    }

    &[type="number"]::-webkit-inner-spin-button,
    &[type="number"]::-webkit-outer-spin-button {
        -webkit-appearance: none;
        margin: 0;
    }

    &[type="search"] {
        -webkit-appearance: none;
        outline: none;
    }

    &[type="search"]::-webkit-search-decoration,
    &[type="search"]::-webkit-search-cancel-button,
    &[type="search"]::-webkit-search-results-button,
    &[type="search"]::-webkit-search-results-decoration {
        -webkit-appearance: none;
    }

    &:focus {
        outline: none;
        border: unset;
        box-shadow: unset;
        background-color: unset;
    }

    &[type="text"] {}

    &[type="text"]:hover,
    &[type="text"]:focus {}
}

button {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    background: none;
    border: none;
    box-shadow: none;

    padding: 0;
    margin: 0;

    font: inherit;
    color: inherit;
    text-align: inherit;

    cursor: pointer;

    &:hover {
        background-color: unset;
        border: unset;
        box-shadow: unset;
        color: unset;
        outline: unset;
    }

    &:focus {
        background-color: unset;
        border: unset;
        box-shadow: unset;
        color: unset;
        outline: unset;
    }
}

select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    background: none;
    border: none;
    box-shadow: none;

    padding: 0;
    margin: 0;

    font: inherit;
    color: inherit;
    text-align: inherit;

    &::-ms-expand {
        display: none;
    }

    &:hover,
    &:focus {
        background: unset;
        border: unset;
        box-shadow: unset;
        color: unset;
        outline: unset;
    }
}


/*
input[type="file"] {
    width: 100%;
    padding: 0.5vw 0.9vw;
    border: none;
    border-bottom: 0.1vw solid var(--secondary-color);
    background-color: transparent;
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    cursor: pointer;
    outline: none; 
    appearance: none; 
    -webkit-appearance: none; 
    -moz-appearance: none; 
    transition: border-bottom 0.2s;
}

input[type="file"]:hover,
input[type="file"]:focus {
    border-bottom: 0.1vw solid var(--primary-color);
}

input[type="file"]::file-selector-button {
    display: none;
}

input[type="file"]::before {
    content: "Р’С‹Р±РµСЂРёС‚Рµ С„Р°Р№Р»";
    display: inline-block;
    color: inherit;
}

input[type="file"]:valid::before {
    content: attr(data-file-name); 
}

input {
    width: 100%;
    padding: 0.5vw 0.9vw;
    border-bottom: 0.1vw solid var(--secondary-color);
    transition: 0.2s;
}

input:hover,
input:focus {
    cursor: pointer;
    border-bottom: 0.1vw solid var(--primary-color);
}

select {
    width: 100%;
    padding: 0.5vw 0.9vw;
    border-bottom: 0.1vw solid var(--secondary-color);
    transition: 0.2s;
}

select:hover,
select:focus {
    cursor: pointer;
    border-bottom: 0.1vw solid var(--primary-color);
}
*/



















.tippy-content {
    font-size: 0.55vw;
    line-height: 0.7vw;
    font-family: "light";
}












.wrapper {
    width: 85vw;
}

.wrapper h3 {
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "light";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}


























.header-wrap {
    width: 100%;
    padding: 1vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.header-wrap .wrapper {
    display: flex;
    justify-content: space-between;
    align-content: center;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
}

.header-wrap .header-group-wrap {
    display: flex;
    justify-content: space-between;
    align-content: center;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
}








.logo-wrap {
    display: flex;
    gap: 1.5vw;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
}

.logo {
    width: 8vw;
    height: 3vw;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    transition: 0.2s;
}

.logo:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.logo img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.slogan {
    font-size: 0.65vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    max-width: 8vw;
}








.ya-rating-wrap {
    width: 8vw;
    height: 2.6vw;
    border-radius: 0.35vw;
    overflow: hidden;
}

.ya-rating-wrap img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}






.menu-wrap {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
    align-content: flex-start;
    row-gap: 0.75vw;
    column-gap: 2.5vw;
    flex-wrap: wrap;
    max-width: 47vw;
}

.menu-wrap .menu-item {
    font-size: 0.65vw;
    font-family: "bold";
    color: #111;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.menu-wrap .menu-item:hover {
    cursor: pointer;
    transform: scale(0.95);
}









.socials-wrap {
    display: flex;
    gap: 1vw;
}

.socials-wrap .social-wrap {
    width: 2vw;
    height: 2vw;
    border-radius: 50%;
    overflow: hidden;
    background-color: rgba(0, 0, 0, 0.05);
    transition: 0.2s;
}

.socials-wrap .social-wrap img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.socials-wrap .social-wrap:hover {
    cursor: pointer;
    transform: scale(0.95);
}








.feedback-wrap {
    display: flex;
    gap: 0.5vw;
    flex-direction: column;
    align-items: center;
}


.feedback-wrap .working-hours {
    font-family: "light";
    font-size: 0.75vw;
    color: #111;
    letter-spacing: 0.05em;
}

.feedback-wrap .feedback {
    font-family: "bold";
    font-size: 0.9416666667vw;
    line-height: 0.99541666667vw;
    color: #111;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.feedback-wrap .feedback:hover {
    cursor: pointer;
    transform: scale(0.95);
    color: var(--main-color);
}

.feedback-wrap .callback {
    font-family: "bold";
    font-size: 0.7416666667vw;
    line-height: 0.89541666667vw;
    color: var(--main-color);
    letter-spacing: 0.05em;
    transition: 0.2s;
    padding-bottom: 0.25vw;
    border-bottom: 1px solid;
}

.feedback-wrap .callback:hover {
    cursor: pointer;
    transform: scale(0.95);
}















.breadcrumbs-wrap {
    width: 100%;
    padding: 1vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.breadcrumbs-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    row-gap: 1vw;
    column-gap: 0;
    flex-direction: row;
    flex-wrap: wrap;
}

.breadcrumbs-wrap .wrapper .breadcrumb {
    display: flex;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
}


.breadcrumbs-wrap .wrapper .breadcrumb a {
    font-size: 0.85vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    transition: 0.2s;

}

.breadcrumbs-wrap .wrapper .breadcrumb a::before {
    content: "";
    width: 0.0520833333vw;
    height: 0.6770833333vw;
    background-color: #8C8C8C;
    margin: 0 0.78125vw;
    display: inline-block;
}

.breadcrumbs-wrap .wrapper .breadcrumb:first-child a::before {
    display: none;
}

.breadcrumbs-wrap .wrapper .breadcrumb a:hover {
    cursor: pointer;
    transform: scale(0.95);
}








.titles-wrap {
    width: 100%;
    padding: 1vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.titles-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    gap: 2vw;
    flex-direction: column;
    flex-wrap: wrap;
}

.titles-wrap .wrapper .title {
    font-size: 2.45vw;
    line-height: 2.5vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    text-align: center;

    transition: 0.2s;
    max-width: 50vw;
}

.titles-wrap .wrapper .subtitle {
    font-size: 1.85vw;
    line-height: 2.15vw;
    font-family: "light";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    text-align: center;

    transition: 0.2s;
    max-width: 50vw;
}

.titles-wrap .wrapper .subtitle b {
    font-family: "bold";
}

.titles-wrap .wrapper .text {
    font-size: 1.25vw;
    line-height: 1.5vw;
    font-family: "light";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
    max-width: 50vw;
}







.first-wrap .wrapper .title {
    position: relative;

    font-size: 3.55vw;
    line-height: 3.5vw;
}

.first-wrap .wrapper .title::before {
    content: '';
    position: absolute;
    top: -25%;
    left: -5%;
    width: 20vw;
    height: 20vw;
    background-color: rgb(213 18 40 / 38%);
    border-radius: 35%;
    z-index: -1;
    filter: blur(3vw);
    
    /* Анимация */
    animation: pulsatingBackground 8s ease-in-out infinite;
}

@keyframes pulsatingBackground {
    0% {
        transform: translate(0, 0) rotate(0deg);
        background-color: rgb(213 18 40 / 38%);
    }
    25% {
        transform: translate(5vw, -3vw) rotate(15deg);
        background-color: rgb(213 18 40 / 45%);
    }
    50% {
        transform: translate(8vw, 2vw) rotate(30deg);
        background-color: rgb(213 18 40 / 60%);
    }
    75% {
        transform: translate(3vw, 5vw) rotate(15deg);
        background-color: rgb(213 18 40 / 45%);
    }
    100% {
        transform: translate(0, 0) rotate(0deg);
        background-color: rgb(213 18 40 / 38%);
    }
}

.first-wrap .wrapper .subtitle {
    font-size: 2.35vw;
    line-height: 2.3vw;
}









.actions-wrap {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;

    margin: 3vw 0;
}

.action-wrap {
    display: flex;
    gap: 1.5vw;
    flex-direction: row;
    align-content: center;
    justify-content: center;
    align-items: center;
}







.marquiz-pops__content * {
    font-family: "bold" !important;    
}






.action {
    position: relative;
    padding: 1.55vw 2.25vw;
    border-radius: 2.75vw;
    background-color: var(--main-color);
    overflow: hidden;
    color: #fff;
    font-size: 1.245vw;
    font-family: "bold";
    letter-spacing: 0.05em;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    transition: 0.2s;
}

.action::before {
    margin-left: -30px;
    content: " ";
    width: 1.5rem;
    height: 300px;
    background: #fff;
    -webkit-animation-delay: 0.05s;
    animation-delay: 0.05s;
    position: absolute;
    left: -40px;
    top: -70px;
    animation-timing-function: ease-in-out;
    transition: all 0.1s;
    animation-name: slideme;
    animation-duration: 3.5s;
    animation-iteration-count: infinite;
    transform: rotate(45deg);
    z-index: 5;
}

.action:hover {
    cursor: pointer;
    transform: scale(0.95);
        box-shadow: .21vw .21vw 1.5vw rgb(213 18 40 / 50%);
}

.action-near {
    font-size: 0.65vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    max-width: 7vw;
}






















.terms-wrap {
    position: relative;

    width: 100%;
    margin: 3vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    gap: 1vw;
    column-gap: 1vw;
}

.terms-wrap h3 {
    margin-bottom: 3vw;
}


.terms-wrap .wrapper {
    position: relative;

    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    gap: 1vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.terms-wrap .wrapper .swiper-container {
    width: 100%;
}

.wrapper .swiper-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.terms-wrap .wrapper .term {
    padding: 0.35vw 0.75vw;
    min-height: 3vw;

    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    gap: 0.5vw;
    background-color: #fff;
    border-radius: 3.5vw;
    transition: 0.2s;
    flex-direction: row;
}

.terms-wrap .wrapper .term .term-title {
    position: relative;
    font-size: 1vw;
    font-family: "regular";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
    text-overflow: ellipsis;
    transition: 0.2s;
    z-index: 0;
}

.terms-wrap .wrapper .term:hover .term-title::before,
.terms-wrap .wrapper .active-term .term-title::before {
    position: absolute;
    bottom: -0.6vw;
    left: 0;
    content: '';
    width: 100%;
    height: 8px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 6' preserveAspectRatio='none'%3E%3Cpath d='M0,3 C20,0 30,6 50,3 C70,0 80,6 100,3' stroke='%23D51228' fill='none' stroke-width='1' stroke-linecap='round'/%3E%3C/svg%3E");
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
}

.terms-wrap .wrapper .term:hover {
    cursor: pointer;
    transform: scale(1.25);
    background-image: linear-gradient(180deg, rgb(213 18 40 / 0%, rgb(213 18 40 / 20%, rgb(213 18 40 / 40%, rgb(213 18 40/ 60%, rgb(213 18 40 / 80%, rgb(213 18 40 / 100%)))))));
    box-shadow: 0 .1vw 1vw #dcdcdc;
    z-index: 1;
}

/*
.terms-wrap .wrapper .term:hover .term-title  {
    font-family: "bold" !important;
}
*/

.terms-wrap .wrapper .active-term .term-title {
    font-family: "bold" !important;
}


.terms-wrap .wrapper .term .term-img {
    width: 3vw;
    height: 3vw;
    margin: 0 -0.15vw 0 -0.35vw;

    border-radius: 50%;
    overflow: hidden;
    background-color: #fcfcfc;
}

.terms-wrap .wrapper .term .term-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
}



/*
.terms-wrap .wrapper .term:hover .term-title,
.terms-wrap .wrapper .active-term .term-title {
    color: #fff;
}
*/

.terms-wrap .wrapper .term span {
    font-family: "regular";
    font-size: 0.75vw;
    color: #ffffff;
    letter-spacing: 0.05em;
    background-color: var(--main-color);
    padding: 0.2vw 0.5vw;
    border-radius: 1.5vw;
    transition: 0.2s;
}

/*
.terms-wrap .wrapper .term:hover span,
.terms-wrap .wrapper .active-term span {
    color: var(--main-color);
    background-color: #fff;
}
*/





























.projects-wrap {
    width: 100%;
    padding: 1vw 0;
    margin-bottom: 3vw;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}


.projects-wrap .wrapper {
    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: center;
    gap: 3vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.projects-wrap .wrapper .project-wrap {
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    row-gap: 1vw;
    column-gap: 1vw;
    flex-direction: column;
    flex-wrap: wrap;
    width: 26vw;
}






.projects-wrap .wrapper .mockup-wrap {
    position: relative;

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url('../img/laptop.png');

    width: 100%;
    height: 14vw;
}

.projects-wrap .wrapper .mockup-wrap .mockup {
    position: absolute;
    top: 0.25vw;
    left: 2.25vw;
    width: 21.5vw;
    height: 12vw;
    background-color: #020001;
}

.projects-wrap .wrapper .mockup-wrap .mockup img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 10;
}





.projects-wrap .wrapper .mockup-wrap .mockup .blackout-wrap {
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;
    transition: 0.2s;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.projects-wrap .wrapper .mockup-wrap .mockup .blackout-wrap:hover {
    cursor: pointer;
}

.projects-wrap .wrapper .mockup-wrap .mockup .blackout-wrap .blackout {
    width: 2.5vw;
    height: 2.5vw;
    background-color: rgba(255, 255, 255, 1);
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px 0px;
    border-radius: 50%;
    transition: 0.2s;
    opacity: 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-content: center;
    align-items: center;
}

.projects-wrap .wrapper .mockup-wrap .mockup .blackout-wrap .blackout img {
    width: 50%;
    height: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
    filter: invert();
}

.projects-wrap .wrapper .mockup-wrap .mockup .blackout-wrap:hover .blackout {
    opacity: 1;
}







.projects-wrap .wrapper .mockup-wrap .label-wrap {
    position: absolute;
    display: flex;
    gap: 0.2vw;
    flex-direction: row;
    flex-wrap: wrap;
    max-width: 8vw;
    justify-content: flex-end;
}

.projects-wrap .wrapper .mockup-wrap .label {
    font-size: 0.45vw;
    line-height: 0.55vw;
    font-family: "bold";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;

    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0.25vw 0.5vw;
    background-color: #fff;
    border-radius: 0.5vw;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px 0px;

    transition: 0.2s;
}


.projects-wrap .wrapper .mockup-wrap .label:hover {
    cursor: pointer;
    transform: scale(0.95);
}



.projects-wrap .wrapper .mockup-wrap .label-region {
    bottom: 3vw;
    left: 1vw;
}

.projects-wrap .wrapper .mockup-wrap .label-region .label {
    background-color: #0072ff;
    color: #fff;
}



.projects-wrap .wrapper .mockup-wrap .label-state {
    right: 1vw;
    top: 3vw;
}

.projects-wrap .wrapper .mockup-wrap .label-state .label {
    background-color: #ff8100;
    color: #fff;
}



.projects-wrap .wrapper .mockup-wrap .label-project-type {
    left: 1vw;
    bottom: 4.25vw;
    justify-content: flex-start;
}

.projects-wrap .wrapper .mockup-wrap .label-project-type .label {
    background-color: #d800ff;
    color: #ffffff;
}



.projects-wrap .wrapper .mockup-wrap .label-activity {
    top: 3vw;
    left: 1vw;

    justify-content: flex-start;
}

.projects-wrap .wrapper .mockup-wrap .label-activity .label {
    background-color: #12c868;
    color: #fff;
}




.projects-wrap .wrapper .mockup-wrap .label-features {
    bottom: 3vw;
    right: 1vw;
}

.projects-wrap .wrapper .mockup-wrap .label-features .label {
    background-color: #fff;
    color: #111;
}

















.projects-wrap .wrapper .mockup-wrap .video-label {

    width: 2.5vw;
    height: 2.5vw;

    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;

    background-color: var(--main-color);
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px 0px;
    border-radius: 50%;
    transition: 0.2s;
    position: absolute;
    right: 1.25vw;
    top: -0.5vw;

    z-index: 10;
}

.projects-wrap .wrapper .mockup-wrap .video-label img {
    width: 50%;
    height: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.projects-wrap .wrapper .mockup-wrap .video-label::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background-color: var(--main-color);
    -webkit-animation: pulse_2_small 2s linear infinite;
    animation: pulse_2_small 2s linear infinite;
    z-index: -1;
}

.projects-wrap .wrapper .mockup-wrap .video-label:hover {
    cursor: pointer;
    transform: scale(0.95);
}



















.project-summary-wrap {
    width: 100%;
    padding: 1vw;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 1.5vw;
    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start;
    row-gap: 1vw;
    column-gap: 1vw;
    flex-direction: column;
    flex-wrap: wrap;
}


.project-summary-wrap .details-wrap {
    display: flex;
    justify-content: space-between;
    align-content: flex-start;
    align-items: center;
    row-gap: 1vw;
    column-gap: 1vw;
    width: 100%;
}

.project-summary-wrap .update-date {
    font-size: 0.65vw;
    line-height: 0.65vw;
    font-family: "bold";
    color: #fff;
    letter-spacing: 0.05em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;

    padding: 0.5vw 0.75vw;
    background-color: #12c868;
    border-radius: 2.5vw;
}

.project-summary-wrap .page-count {
    font-size: 1vw;
    line-height: 1.25vw;
    font-family: "regular";
    color: #a7a7a7;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.project-summary-wrap .project-title {
    font-size: 1.15vw;
    line-height: 1.5vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;

    min-height: 3vw;
}

.project-summary-wrap .project-title:hover {
    cursor: pointer;
    transform: scale(0.95);
    color: var(--main-color);
}

.project-summary-wrap .price-wrap {
    width: 100%;
    display: flex;
    gap: 1vw;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: center;
}

.project-summary-wrap .price-wrap .price {
    font-size: 1.55vw;
    line-height: 1.5vw;
    font-family: "regular";
    color: #a7a7a7;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.project-summary-wrap .price-wrap .price:first-child {
    color: var(--main-color);
}

.project-summary-wrap .project-actions-wrap {
    width: 100%;
    display: flex;
    gap: 0.5vw;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: center;
}

.single-project-wrap .project-summary-wrap .project-actions-wrap {
    width: 100%;
    display: flex;
    gap: 0.5vw;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: flex-start;
}

.project-summary-wrap .project-actions-wrap .project-action {
    position: relative;
    overflow: hidden;
        padding: 0.75vw 0;
    border-radius: 2.5vw;
    border: 1px solid var(--main-color);
    font-size: 0.65vw;
    font-family: "bold";
    color: var(--main-color);
    letter-spacing: 0.05em;
    min-width: 11.55vw;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    gap: 0.5vw;
    transition: 0.2s;
}

.project-summary-wrap .project-actions-wrap .project-action:hover {
    cursor: pointer;
    transform: scale(0.95);
}


.project-summary-wrap .project-actions-wrap .project-action-disabled {
    opacity: 0.25;
}

.project-summary-wrap .project-actions-wrap .project-action-disabled:hover {
    cursor: not-allowed;
}

.project-summary-wrap .project-actions-wrap .project-action-accent {
    color: #fff;
    background-color: var(--main-color);
    padding: 0.55vw 0;
}

.projects-wrap .project-summary-wrap .project-actions-wrap .project-action-accent {
    width: 100%;
    padding: 0.55vw 0;
}

.project-summary-wrap .project-actions-wrap .project-action-accent::before {
    margin-left: -30px;
    content: " ";
    width: 1.5rem;
    height: 300px;
    background: #fff;
    -webkit-animation-delay: 0.05s;
    animation-delay: 0.05s;
    position: absolute;
    left: -40px;
    top: -70px;
    animation-timing-function: ease-in-out;
    transition: all 0.1s;
    animation-name: slideme;
    animation-duration: 3.5s;
    animation-iteration-count: infinite;
    transform: rotate(45deg);
    z-index: 5;
}






.project-summary-wrap .project-actions-wrap .project-action .counter-wrap {
    display: flex;
    gap: 0.25vw;
    padding: 0.25vw 0.45vw;
    background-color: #fff;
    border-radius: 1.5vw;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}

.project-summary-wrap .project-actions-wrap .project-action .counter-icon {
    width: 0.75vw;
    height: 0.75vw;

    background-repeat: no-repeat;
    background-position: center center;
    background-image: url('../img/like.svg');
    background-size: cover;
}

.project-summary-wrap .project-actions-wrap .project-action .counter-text {
    font-family: "bold";
    font-size: 0.55vw;
    color: var(--main-color);
    letter-spacing: 0.05em;
}




















.seo-wrap {
    width: 100%;
    padding: 1vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.seo-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    row-gap: 1vw;
    column-gap: 0;
    flex-direction: column;
    flex-wrap: wrap;
}

.seo-wrap .wrapper .seo-title {
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.seo-wrap .wrapper .seo-text {
    font-family: "light";
    font-size: 0.75vw;
    color: #111;
    letter-spacing: 0.05em;
}










.contacts-wrap {
    width: 100%;
    padding: 1vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.contacts-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    row-gap: 1vw;
    column-gap: 0;
    flex-direction: column;
    flex-wrap: wrap;
}


.contacts-wrap .wrapper .contacts-title {
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}





.contacts-wrap .wrapper .contact {
    font-family: "light";
    font-size: 1.25vw;
    color: #111;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.contacts-wrap .wrapper .contact:hover {
    cursor: pointer;
    transform: scale(0.95);
    color: var(--main-color);
}





.contacts-wrap .wrapper .contacts-project-summary-wrap {
    display: flex;
    gap: 1vw;
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}

.contacts-wrap .wrapper .contacts-content-items {
    display: flex;
    gap: 1vw;
    flex-direction: column;
}

.contacts-wrap .wrapper .contacts-content-iframe {
    width: 62vw;
    height: 24vw;
    border-radius: 1vw;
    background-color: rgba(0, 0, 0, 0.05);
    overflow: hidden;
}

.contacts-wrap .wrapper .contacts-content-iframe iframe {
    width: 100%;
    height: 100%;
}













.footer-wrap {
    width: 100%;
    padding: 3vw 0;
    margin-top: 3vw;

    background-color: #313131;
    border-radius: 2vw 2vw 0 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}


.footer-wrap .wrapper {
    display: flex;
    justify-content: space-between;
    align-content: flex-start;
    align-items: center;
    row-gap: 1vw;
    column-gap: 0;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2vw;
}

.footer-wrap .footer-group-wrap {
    display: flex;
    justify-content: space-between;
    align-content: center;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
}

.footer-wrap .wrapper .footer-text p {
    font-family: "light";
    font-size: 0.75vw;
    line-height: 1vw;
    color: #fff;
    letter-spacing: 0.05em;
}









.footer-wrap .wrapper .footer-links-wrap {
    display: flex;
    gap: 0.5vw;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.footer-wrap .wrapper .footer-link {
    font-family: "bold";
    font-size: 0.55vw;
    line-height: 0.75vw;
    color: var(--main-color);
    letter-spacing: 0.05em;

    padding-bottom: 0.15vw;
    border-bottom: 1px solid;
    transition: 0.2s;
}

.footer-wrap .wrapper .footer-link:hover {
    cursor: pointer;
    transform: scale(0.95);
}







.footer-wrap .menu-wrap .menu-item {
    color: #fff;
}

.footer-wrap .slogan {
    color: #fff;
}


.footer-wrap .feedback-wrap .working-hours,
.footer-wrap .feedback-wrap .feedback {
    color: #fff;
}










.footer-wrap .wrapper .copyright {
    font-family: "light";
    font-size: 0.75vw;
    line-height: 1vw;
    color: #fff;
    letter-spacing: 0.05em;
}


















.clients-reviews-wrap {
    width: 100%;
    margin: 1vw 0 3vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.clients-reviews-wrap .wrapper {
    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: center;
    gap: 1vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.titles-wrap .wrapper .clients-reviews-title {
    margin-top: 3vw;
}

.clients-reviews-wrap .wrapper .swiper-container {
    width: 100%;
}

.clients-reviews-wrap .wrapper .swiper-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.clients-reviews-wrap .wrapper .clients-review-wrap {
    width: 16vw;

    display: flex;
    gap: 0.5vw;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    align-content: center;
}

.clients-reviews-wrap .wrapper .clients-review-rating {
    width: 7vw;
    height: 1.5vw;

    background-image: url('../img/rating.svg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.clients-reviews-wrap .wrapper .clients-review-rating-num {
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.1em;
    max-width: 8vw;
    margin-bottom: 0.5vw;
}

.clients-reviews-wrap .wrapper .clients-review-mockup-wrap {
    position: relative;

    width: 100%;
    min-height: 32.5vw;

    background-image: url('../img/phone.png');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;

    transition: 0.2s;
}

.clients-reviews-wrap .wrapper .clients-review-mockup-wrap:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.clients-reviews-wrap .wrapper .clients-review-island {
    position: absolute;
    top: 1vw;
    left: 6.25vw;
    width: 4vw;
    height: 1.25vw;
    background-image: url(../img/island.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.clients-reviews-wrap .wrapper .clients-review-mockup {
    position: absolute;
    left: 0.75vw;
    top: 0.5vw;
    width: 14.75vw;
    height: 31.25vw;
    border-radius: 2vw;
    overflow: hidden;
    background-color: #000000;
}

.clients-reviews-wrap .wrapper .clients-review-mockup img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 10;
}

.clients-reviews-wrap .wrapper .clients-review-date {
    font-size: 0.65vw;
    font-family: "bold";
    color: rgba(0, 0, 0, 0.65);
    letter-spacing: 0.05em;
    max-width: 8vw;
    margin-top: 0.5vw;
}

.clients-reviews-wrap .wrapper .clients-review-region {
    font-size: 0.65vw;
    font-family: "light";
    color: rgba(0, 0, 0, 0.5);
    letter-spacing: 0.05em;
    max-width: 8vw;
}

.clients-reviews-wrap .wrapper .clients-review-client {
    font-size: 0.65vw;
    font-family: "light";
    color: rgba(0, 0, 0, 0.5);
    letter-spacing: 0.05em;
    max-width: 8vw;
}


















.video-reviews-wrap {
    width: 100%;
    margin: 3vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.video-reviews-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.video-reviews-wrap .wrapper .swiper-container {
    width: 100%;
}

.video-reviews-wrap .wrapper .swiper-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.video-reviews-wrap .wrapper .video-review-wrap {
    width: 100%;

    display: flex;
    gap: 0.5vw;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    align-content: center;
}

.video-reviews-wrap .wrapper .video-review-preview {
    position: relative;

    width: 100%;
    height: 30vw;

    border-radius: 2vw;
    overflow: hidden;
    background-color: rgba(0, 0, 0, 0.1);
    transition: 0.2s;
}

.video-reviews-wrap .wrapper .video-review-preview:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-img-wrap {
    position: absolute;
    left: 0;
    top: 0;

    width: 100%;
    height: 100%;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-img-wrap img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
    transition: 0.2s;
}


.video-reviews-wrap .wrapper .video-review-wrap .video-review-blackout {
    position: absolute;
    left: 0;
    top: 0;

    width: 100%;
    height: 100%;

    background-color: rgba(0, 0, 0, 0.24);
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-shadow {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
    background: linear-gradient(to top, rgba(0, 0, 0, 0.75), transparent);
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-play {
    position: absolute;
    top: 12.25vw;
    left: 6.5vw;
    width: 5vw;
    height: 5vw;
    border-radius: 50%;
    background-color: var(--main-color);
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-play img {
    width: 35%;
    height: 35%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-play::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background-color: var(--main-color);
    -webkit-animation: pulse_2_small 2s linear infinite;
    animation: pulse_2_small 2s linear infinite;
    z-index: 0;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 2vw;
    box-sizing: border-box;
    display: flex;
    gap: 1vw;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-text {
    text-align: center;
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "bold";
    color: #fff;
    letter-spacing: 0.05em;
    min-height: 4.5vw;
}

.video-reviews-wrap .wrapper .video-review-wrap .video-review-duration {
    font-size: 0.65vw;
    font-family: "light";
    color: #fff;
    letter-spacing: 0.05em;
    border-radius: 1vw;
    padding: 0.5vw 1vw;
    border: 1px solid #fff;
}

.video-reviews-wrap .wrapper .video-review-date {
    font-size: 0.65vw;
    font-family: "bold";
    color: rgba(0, 0, 0, 0.65);
    letter-spacing: 0.05em;
    max-width: 8vw;
    margin-top: 0.5vw;
}

.video-reviews-wrap .wrapper .video-reviews-initials {
    font-size: 0.65vw;
    font-family: "light";
    color: rgba(0, 0, 0, 0.5);
    letter-spacing: 0.05em;
}


.video-reviews-wrap .wrapper .video-reviews-initials span {}















.thanks-letters-wrap {
    width: 100%;
    margin: 3vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.thanks-letters-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.thanks-letters-wrap .wrapper .swiper-container {
    width: 100%;
}

.thanks-letters-wrap .wrapper .swiper-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.thanks-letters-wrap .wrapper .thanks-letter-wrap {
    width: 100%;
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    gap: 0.5vw;
    flex-direction: column;
    flex-wrap: wrap;
}

.thanks-letters-wrap .wrapper .thanks-letter-mockup {
    width: 100%;
    height: 27vw;
    border-radius: 2vw;
    background-color: rgba(0, 0, 0, 0.1);
    overflow: hidden;
    transition: 0.2s;
}

.thanks-letters-wrap .wrapper .thanks-letter-mockup:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.thanks-letters-wrap .wrapper .thanks-letter-mockup img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 10;
}

.thanks-letters-wrap .wrapper .thanks-letter-date {
    font-size: 0.65vw;
    font-family: "bold";
    color: rgba(0, 0, 0, 0.65);
    letter-spacing: 0.05em;
    max-width: 8vw;
    margin-top: 0.5vw;
}

.thanks-letters-wrap .wrapper .thanks-letter-text {
    font-size: 0.65vw;
    font-family: "light";
    color: rgba(0, 0, 0, 0.5);
    letter-spacing: 0.05em;
    max-width: 12vw;
    text-align: center;
}















.team-members-wrap {
    width: 100%;
    margin: 3vw 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;
    row-gap: 1vw;
    column-gap: 1vw;
}

.team-members-wrap .wrapper {
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    row-gap: 2vw;
    column-gap: 2vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.team-members-wrap .wrapper .swiper-container {
    width: 100%;
}

.team-members-wrap .wrapper .swiper-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.team-members-wrap .wrapper .team-member-wrap {
    width: 100%;

    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: center;
    gap: 0.5vw;
    flex-direction: column;
    flex-wrap: wrap;
}

.team-members-wrap .wrapper .team-member-mockup {
    width: 100%;
    height: 27vw;

    border-radius: 2vw;
    background-color: rgba(0, 0, 0, 0.1);
    overflow: hidden;
    transition: 0.2s;
}

.team-members-wrap .wrapper .team-member-mockup:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.team-members-wrap .wrapper .team-member-mockup img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 10;
}

.team-members-wrap .wrapper .team-member-name {
    font-size: 0.65vw;
    font-family: "bold";
    color: rgba(0, 0, 0, 0.65);
    letter-spacing: 0.05em;

    max-width: 12vw;
    margin-top: 0.5vw;

    text-align: center;
}

.team-members-wrap .wrapper .team-member-text {
    font-size: 0.65vw;
    font-family: "light";
    color: rgba(0, 0, 0, 0.5);
    letter-spacing: 0.05em;
    max-width: 12vw;

    text-align: center;
}


















.video-widget-wrap {
    position: fixed;
    left: 1vw;
    bottom: 1vw;
    width: 6vw;
    height: 9vw;
    border-radius: 0.5vw;
    box-shadow: 0 0 81px 0 #3535354c;
    border: solid 3px #fff;
    background-color: #fff;
    display: block;
    overflow: hidden;
    z-index: 1000;
    transition: 0.2s;
}

.video-widget-wrap:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.video-widget-wrap img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.video-widget-wrap .play {
    position: absolute;
    top: 3.25vw;
    left: 1.9vw;
    width: 2.5vw;
    height: 2.5vw;
    border-radius: 50%;

    background-color: var(--main-color);

    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.video-widget-wrap .play img {
    width: 35%;
    height: 35%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.video-widget-wrap .video-widget-blackout {
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    background-color: rgba(0, 0, 0, 0.24);
}

.video-widget-wrap .play::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background-color: var(--main-color);
    -webkit-animation: pulse_2_small 2s linear infinite;
    animation: pulse_2_small 2s linear infinite;
    z-index: 0;
}


.video-widget-wrap .close {
    position: absolute;
    top: 0.5vw;
    right: 0.5vw;

    width: 0.75vw;
    height: 0.75vw;

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url('../img/close.svg');
}











































.popup {
    color: #000;
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding-top: 2.6041666667vw;
    padding-bottom: 2.6041666667vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    pointer-events: none;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
    font-family: "Gilroy", Arial, sans-serif;
}

.popup.open {
    opacity: 1;
    pointer-events: all;
    visibility: visible;
}

.popup.open .popup__blur {
    overflow-y: scroll;
}

.popup__blur {
    background-color: #000;
    opacity: 0.7;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    cursor: pointer;
}

.popup__container {
    margin: auto;
    z-index: 2;
}

.popup__block {
    position: relative;
    z-index: 2;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    margin: auto;
    position: relative;
    background-color: #f1f1f1;
}

.popup__close {
    position: absolute;
    z-index: 5;
    top: 1.3020833333vw;
    right: 1.5625vw;
    width: 1.3020833333vw;
    height: 1.3020833333vw;
    cursor: pointer;
}

.popup__close img,
.popup__close svg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 1.0416666667vw;
    height: 1.0416666667vw;
    -o-object-fit: contain;
    object-fit: contain;
    color: #9d9d9d;
    fill: #9d9d9d;
}

.popup__close img path,
.popup__close svg path {
    color: #9d9d9d;
    fill: #9d9d9d;
}








.main-popup {
    width: 26.0416666667vw;
    border-radius: 1vw;

    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.main-popup__content {
    padding: 2.8645833333vw 2.0833333333vw 2.8645833333vw 2.0833333333vw;
}

.main-popup__title {
    font-weight: 700;
    font-size: 1.8229166667vw;
    line-height: 2.1354166667vw;
    text-align: center;
    letter-spacing: 0.02em;
    margin-bottom: 1.3020833333vw;
}

.main-popup__text {
    font-weight: 400;
    font-size: 0.9375vw;
    line-height: 1.09375vw;
    text-align: center;
    letter-spacing: 0.03em;
    margin-bottom: 2.0833333333vw;
    color: #707070;
}

.main-popup__form .form-checkbox {
    margin: 0 auto;
}












.md-standart-form.md-popup-form .form-title {
    font-weight: 700;
    font-size: 1.8229166667vw;
    line-height: 2.1354166667vw;
    letter-spacing: 0.02em;
    margin-bottom: 1.0416666667vw;
    padding-right: 2.6041666667vw;
}

.md-standart-form.md-popup-form .form-text {
    padding-left: 2.0833333333vw;
    font-weight: 500;
    font-size: 0.8333333333vw;
    line-height: 1.25vw;
    letter-spacing: 0.04em;
    margin-bottom: 0.5208333333vw;
}

.md-standart-form.md-popup-form .form-container {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    display: flex;
    gap: 0.5vw;
}

.md-standart-form.md-popup-form .form-select {
    margin: 0;
    width: 100%;
    height: 4.1666666667vw;
    margin-bottom: 0.5208333333vw;
}

.md-standart-form.md-popup-form .form-select span.current {
    line-height: 4.1666666667vw;
}

.md-standart-form.md-popup-form .form-select .list .option {
    line-height: 4.1666666667vw;
    min-height: 4.1666666667vw;
}

.md-standart-form.md-popup-form .form-select.open {
    border-top-left-radius: 2.0833333333vw;
    border-top-right-radius: 2.0833333333vw;
}

.md-standart-form.md-popup-form .form-select.open .list {
    border-bottom-left-radius: 2.0833333333vw;
    border-bottom-right-radius: 2.0833333333vw;
}

.md-standart-form.md-popup-form {
    display: flex;
    gap: 1vw;
    flex-direction: column;
}

.md-standart-form.md-popup-form .form-input {
    margin: 0;
    width: 100%;
    padding: 1.5vw 2vw;
    background-color: #fff;
    border-radius: 0.75vw;
    font-size: 1vw;
    line-height: 1.25vw;
}

.md-standart-form.md-popup-form .form-textarea {
    margin: 0;
    width: 100%;
    padding: 1.5vw 2vw;
    margin-bottom: 0.5208333333vw;
    background-color: #fff;
    border-radius: 0.75vw;
    font-size: 1vw;
    line-height: 1.25vw;
}

.md-standart-form.md-popup-form .form-btn {
    width: 100%;
    padding: 1.5vw 2vw;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 0.5vw;
    background-color: var(--main-color);
    border-radius: 0.75vw;
    transition: 0.2s;
}

.md-standart-form.md-popup-form .form-btn:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.md-standart-form.md-popup-form .form-btn span {
    font-size: 1vw;
    line-height: 1.25vw;
    font-weight: 700;
    color: #fff;
}

.md-standart-form.md-popup-form .form-checkbox {
    width: 14.0625vw;
}

.md-standart-form.md-popup-form .form-file {
    width: 100%;
    margin: 0;
    margin-bottom: 0.5208333333vw;
}

.md-standart-form.md-popup-form .form-file>div {
    width: 100%;
    height: 4.1666666667vw;
}

.md-standart-form.md-popup-form .form-file>div img,
.md-standart-form.md-popup-form .form-file>div svg {
    right: 1.5625vw;
}

















































































.single-project-wrap {
    width: 100%;
    margin-top: 2vw;
    margin-bottom: 2vw;

    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.single-project-wrap .wrapper {
    display: flex;
    gap: 4vw;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    align-content: center;
}

.single-project-wrap .single-main-wrap {
    width: 100%;
    display: flex;
    gap: 1vw;
    flex-direction: row;
    align-items: flex-start;
    align-content: center;
    justify-content: space-between;
}
















.single-project-wrap .single-mockup-wrap {
    position: relative;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url(../img/laptop.png);
    width: 42vw;
    height: 23vw;
}

.single-project-wrap .single-mockup-wrap .mockup {
    position: absolute;
    top: 0.5vw;
    left: 3.65vw;
    width: 34.75vw;
    height: 20vw;
    border-radius: 0.5vw;
    overflow: hidden;
    background-color: #020001;
}

.single-project-wrap .single-mockup-wrap .mockup img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 10;
}















.single-project-wrap .single-mockup-wrap .mockup .blackout-wrap {
    position: absolute;
    left: 0;
    top: 0;

    width: 100%;
    height: 100%;
    transition: 0.2s;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-content: center;

    z-index: 1;
}

.single-project-wrap .single-mockup-wrap .mockup .blackout-wrap:hover {
    cursor: pointer;
}

.single-project-wrap .single-mockup-wrap .mockup .blackout-wrap .blackout {
    width: 4vw;
    height: 4vw;
    background-color: rgba(255, 255, 255, 1);
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px 0px;
    border-radius: 50%;
    transition: 0.2s;
    opacity: 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-content: center;
    align-items: center;
}

.single-project-wrap .single-mockup-wrap .mockup .blackout-wrap .blackout img {
    width: 50%;
    height: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
    filter: invert();
}

.single-project-wrap .single-mockup-wrap .mockup .blackout-wrap:hover .blackout {
    opacity: 1;
}















.single-project-wrap .single-mockup-wrap .label-wrap {
    position: absolute;
    display: flex;
    gap: 0.2vw;
    flex-direction: row;
    flex-wrap: wrap;
    max-width: 13vw;
    justify-content: flex-end;
    z-index: 2;
}

.single-project-wrap .single-mockup-wrap .label {
    font-size: 0.75vw;
    line-height: 0.85vw;
    font-family: "bold";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0.5vw 0.75vw;
    background-color: #fff;
    border-radius: 1vw;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px 0px;
    transition: 0.2s;
}


.single-project-wrap .single-mockup-wrap .label:hover {
    cursor: pointer;
    transform: scale(0.95);
}



.single-project-wrap .single-mockup-wrap .label-region {
    bottom: 5vw;
    left: 1vw;
}

.single-project-wrap .single-mockup-wrap .label-region .label {
    background-color: #0072ff;
    color: #fff;
}



.single-project-wrap .single-mockup-wrap .label-state {
    right: 1vw;
    top: 3vw;
}

.single-project-wrap .single-mockup-wrap .label-state .label {
    background-color: #ff8100;
    color: #fff;
}



.single-project-wrap .single-mockup-wrap .label-project-type {
    left: 1vw;
    bottom: 8.25vw;
    justify-content: flex-start;
}

.single-project-wrap .single-mockup-wrap .label-project-type .label {
    background-color: #d800ff;
    color: #ffffff;
}



.single-project-wrap .single-mockup-wrap .label-activity {
    top: 3vw;
    left: 1vw;

    justify-content: flex-start;
}

.single-project-wrap .single-mockup-wrap .label-activity .label {
    background-color: #12c868;
    color: #fff;
}




.single-project-wrap .single-mockup-wrap .label-features {
    bottom: 6.2vw;
    right: 1vw;
}

.single-project-wrap .single-mockup-wrap .label-features .label {
    background-color: #fff;
    color: #111;
}















.single-project-wrap .project-summary-wrap {
    width: 30vw;
    min-height: 3vw;

    padding: 1vw;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 1.5vw;
    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start;
    row-gap: 1vw;
    column-gap: 1vw;
    flex-direction: column;
    flex-wrap: wrap;
}

.single-project-wrap .project-summary-wrap .project-actions-wrap .project-action {
    min-width: 13.45vw;
}










.single-project-wrap .content-wrap {
    display: flex;
    gap: 2vw;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
}

.single-project-wrap .desc-wrap {
    display: flex;
    gap: 1vw;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
}

.single-project-wrap .desc-title {
    font-size: 1.35vw;
    line-height: 2vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.single-project-wrap .desc-text {
    font-size: 0.85vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    max-width: 7vw;
}








































































































































.order-wrap {
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.order-wrap .wrapper {
    width: 70vw;
    margin: 5vw 0;
    
    display: flex;
    justify-content: space-between;
    align-content: flex-start;
    align-items: flex-start;
    gap: 3vw;
    flex-direction: row;
    flex-wrap: wrap;
}







.order-wrap .wrapper .configurator-wrap {
    position: relative;

    width: 100%;
    display: flex;
    justify-content: space-between;
    align-content: flex-start;
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
}













.order-wrap .wrapper .service-groups-wrap {
    position: relative;
    width: 48vw;
    
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 2vw;
}

.order-wrap .wrapper .service-group-wrap {
    width: 100%;

    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1vw;
}

.order-wrap .wrapper .service-title {
    font-size: 0.85vw;
    line-height: 1vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.order-wrap .wrapper .services-wrap {
    width: 100%;
    
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;

    border-radius: 0.5vw;
    overflow: hidden;
}

.order-wrap .wrapper .service-wrap {
    position: relative;
    width: 100%;
    height: 3vw;
    padding: 0 1vw;
    box-sizing: border-box;
    background-color: #fff;
    border-bottom: 1px solid #f1f1f1;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
    gap: 0.75vw;
    transition: 0.2s;
}

.order-wrap .wrapper .service-wrap-img {
    width: 3vw;
    height: 2vw;
    background-color: rgba(0, 0, 0, 0.025);
    border-radius: 0.25vw;
    overflow: hidden;
    transition: 0.2s;
}

.order-wrap .wrapper .service-wrap-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
}

.order-wrap .wrapper .service-wrap-img:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.order-wrap .wrapper .service-wrap-info {
    position: relative;

    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: center;
    align-items: flex-start;
    gap: 0.35vw;
    
    transition: 0.2s;
}

.order-wrap .wrapper .service-wrap p {
    position: relative;
    padding-right: 1vw;
    font-size: 0.6vw;
    line-height: 0.75vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 15vw;
    display: inline-block;
}

.order-wrap .wrapper .service-wrap p:hover {
    cursor: pointer;
}

.order-wrap .wrapper .service-wrap p::before {
    position: absolute;
    right: 0;
    top: 0;
    content: '';
    width: 0.75vw;
    height: 0.75vw;
    overflow: hidden;
    opacity: 0.15;
    background-image: url(../img/question.svg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.order-wrap .wrapper .service-wrap .details-wrap {
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0.35vw;
    z-index: 1;
}

.order-wrap .wrapper .service-wrap .detail-wrap {
    position: relative ;
    padding: 0.3vw 0.35vw;
    background-color: rgba(0, 0, 0, 0.025);
    font-size: 0.5vw;
    line-height: 0.5vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
    border-radius: 0.25vw;
}

.order-wrap .wrapper .service-wrap .detail-wrap-old-sum {
    display: none;
}

.order-wrap .wrapper .service-wrap .detail-wrap-sum-discounted::before {
    content: '';

    position: absolute;
    left: 0;
    top: 0.5vw;

    width: 100%;
    height: 1px;
    background-color: #c7c7c7;
    transform: rotate(348deg);
}







.order-wrap .wrapper .tariffs-wrap {
    position: absolute;
    right: 0;
    top: -4vw;
    width: 30vw;
    height: 100%;
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
}

.order-wrap .wrapper .tariffs-wrap #tariffs-form {
    position: relative;
    width: 100%;
    height: 100%;
}

.order-wrap .wrapper .tariffs-wrap .swiper-container {
    position: relative;
    width: 100%;
    height: 100%;
}

.order-wrap .wrapper .tariffs-wrap .swiper-container .swiper-slide {
    position: relative;
    width: 100%;
    height: 100%;

    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}

.order-wrap .wrapper .tariff-wrap {
    position: relative;
    padding-top: 6vw;

    width: 100%;
    height: 100%;

    display: flex;
    gap: 0.75vw;
    flex-direction: column;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}










.order-wrap .wrapper .tariff-header-wrap {
    position: absolute;
    top: 0;
    width: 100%;

    display: flex;
    align-content: center;
    align-items: center;
    gap: 0.35vw;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.order-wrap .wrapper .tariff-header-fixed {
    position: absolute;
    background-color: #ffffff;
    border-bottom: 1px solid #d4d4d4;
    z-index: 1;
    padding: 1vw 0;
}

.order-wrap .wrapper .slide-left .tariff-header-fixed {
    border-radius:  0 0 0 0.5vw;
    border-left: 1px solid #d4d4d4;
}


.order-wrap .wrapper .tariff-header-name {
    position: relative;
    padding-right: 1vw;

    font-size: 0.75vw;
    line-height: 0.75vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.order-wrap .wrapper .tariff-header-name:hover {
    cursor: pointer;
}

.order-wrap .wrapper .tariff-header-name::before {
    position: absolute;
    right: 0;
    top: 0;
    content: '';

    width: 0.75vw;
    height: 0.75vw;

    overflow: hidden;
    opacity: 0.15;

    background-image: url('../img/question.svg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.order-wrap .wrapper .tariff-header-price {
    font-size: 0.6vw;
    line-height: 0.6vw;
    font-family: "light";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.order-wrap .wrapper .tariff-header-img {
    width: 2.5vw;
    height: 1.175vw;
}

.order-wrap .wrapper .tariff-header-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
}

.order-wrap .wrapper .tariff-header-actions {
    position: relative;

    display: flex;
    flex-direction: row;
    gap: 0;
    align-items: center;
}

.order-wrap .wrapper .tariff-header-actions[discount]::before {
    content: '';
    position: absolute;
    top: 0.35vw;
    right: -1.25vw;
    width: 0.75vw;
    height: 0.75vw;
    background-image: url(../img/present.svg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.order-wrap .wrapper .tariff-header-action {
    padding: 0 0.5vw;
    height: 1.5vw;
    border-radius: 2.5vw;
    box-sizing: border-box;
    border: 1px solid var(--main-color);
    font-size: 0.45vw;
    line-height: 0.45vw;
    font-family: "bold";
    color: var(--main-color);
    letter-spacing: 0.05em;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    gap: 0.5vw;
    transition: 0.2s;
}

.order-wrap .wrapper .tariff-header-action:hover,
.order-wrap .wrapper .tariff-active .tariff-header-action {
    background-color: var(--main-color);
    color: #fff;
}

.order-wrap .wrapper .tariff-header-action:hover {
    box-shadow: .21vw .21vw 1.5vw rgb(213 18 40 / 50%);
    cursor: pointer;
    transform: scale(0.95);
}

.tariff-header-actions:has(.tariff-discount) .tariff-header-action {
    border-radius: 2.5vw 0 0 2.5vw;
}

.order-wrap .wrapper .tariff-discount {
    padding: 0 0.5vw;
    height: 1.5vw;

    overflow: hidden;
    background-color: var(--main-color);
    border-radius: 0 2.5vw 2.5vw 0;

    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;

    font-size: 0.45vw;
    line-height: 0.45vw;
    font-family: "bold";
    color: #fff;
    letter-spacing: 0.05em;
    white-space: nowrap;
}




.order-wrap .wrapper .slider-btn {
    width: 2vw;
    height: 2vw;
    overflow: hidden;
    border-radius: 50%;
    border: 1px solid #cccccc;
    background-color: transparent;
    background-image: url(../img/arrow.svg);
    background-size: 1vw;
    background-repeat: no-repeat;
    background-position: center;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    z-index: 999;
}

.order-wrap .wrapper .slider-btn-fixed {
    background-color: #ffffff;
}

.order-wrap .wrapper .slider-btn:hover {
    cursor: pointer;
}

.order-wrap .wrapper .slider-prev-btn {
    position: absolute;
    top: 1.5vw;
    left: -1vw;
    transform: rotate(90deg);
}

.order-wrap .wrapper .slider-next-btn {
    position: absolute;
    top: 1.5vw;
    right: -1vw;
    transform: rotate(-90deg);
}






















.order-wrap .wrapper .option-groups-wrap {
    width: 100%;
    
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 4vw;
}

.order-wrap .wrapper .option-group-wrap {
    width: 100%;

    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1vw;
}

.order-wrap .wrapper .tariff-active .option-group-wrap {
    background-color: rgba(0, 0, 0, 0.025);
}

.order-wrap .wrapper .option-title {
    min-height: 1.25vw;

    font-size: 0.85vw;
    line-height: 1.15vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.order-wrap .wrapper .options-wrap {
    width: 100%;
    
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
}


.order-wrap .wrapper .option-wrap {
    width: 100%;
    height: 3vw;
    padding: 0 1vw;
    box-sizing: border-box;

    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
}







.order-wrap .wrapper input[type="checkbox"] {
    position: relative;

    width: 1vw;
    height: 1vw;

    border: 1px solid  #ccc;
    border-radius: 0.25vw;
    filter: grayscale(100%);
}

.order-wrap .wrapper .order-input-required::before { 
    content: '';

    position: absolute;
    top: -0.5vw;
    right: -0.5vw;

    width: 0.5vw;
    height: 0.5vw;

    background-image: url('../img/asterisk.svg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.order-wrap .wrapper .tariff-active input[type="checkbox"] {
    filter: grayscale(0%);
}

.order-wrap .wrapper input[type="checkbox"]:hover {
    cursor: pointer;
}

.order-wrap .wrapper input[type="checkbox"]:checked {
    background-image: url('../img/checked.svg');
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 50%;
}
















.order-wrap .wrapper .total-wrap {
    width: 20vw;
    padding: 1vw;
    min-height: 5vw;
    margin-top: 2vw;

    box-sizing: border-box;

    position: sticky;
    top: 1vw;

    display: flex;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start;
    gap: 1vw;
    flex-direction: column;
    flex-wrap: wrap;

    background-color: #fff;
    border-radius: 0.5vw;
}

.order-wrap .wrapper .total-title {
    font-size: 0.85vw;
    line-height: 1vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.order-wrap .wrapper .price-wrap {
    display: flex;
    flex-direction: row;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
    gap: 1vw;
    flex-wrap: wrap;
}

.order-wrap .wrapper .price-wrap .price-sum {
    font-size: 1.5vw;
    line-height: 1.75vw;
    font-family: "regular";
    color: #000;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.order-wrap .wrapper .price-wrap .price-old-sum {
    position: relative;
    font-size: 1.5vw;
    line-height: 1.75vw;
    font-family: "regular";
    color: #d9d9d9;
    letter-spacing: 0.05em;
    transition: 0.2s;
    display: none;
}

.order-wrap .wrapper .price-wrap .price-old-sum::before {
    content: '';
    position: absolute;
    top: 1vw;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #d9d9d9;
    transform: rotate(348deg);
    border-radius: 1vw;
}








.order-wrap .wrapper .total-wrap .details-wrap {
    width: 100%;
    
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0.5vw;

    z-index: 1;
    overflow: hidden;
    transition: 0.4s;
}

.details-wrap.collapsed {
    height: 0.75vw;
}

.order-wrap .wrapper .details-title {
    position: relative;

    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
}

.order-wrap .wrapper .details-title:hover {
    cursor: pointer;
    transform: scale(0.95);
}

.order-wrap .wrapper .details-title::after {
    position: absolute;
    right: -1.25vw;
    top: -0.15vw;
    content: '';
    width: 1vw;
    height: 1vw;

    background-image: url(../img/arrow.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;

    opacity: 0.25;
    transition: 0.2s;
}

.order-wrap .wrapper .details-wrap.collapsed .details-title::after {
    transform: rotate(-180deg);
}

.order-wrap .wrapper .total-wrap .detail-wrap {
    width: 100%;
    display: flex;
    flex-direction: row;
    align-content: flex-end;
    justify-content: space-between;
    align-items: flex-end;
    gap: 0.5vw;
    z-index: 1;
}

.order-wrap .wrapper .total-wrap .detail-key {
    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "light";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.order-wrap .wrapper .total-wrap .detail-separator {
    width: 100%;
    border-bottom: 2px dashed #ebebeb;
}

.order-wrap .wrapper .total-wrap .detail-value {
    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "regular";
    color: #111;
    letter-spacing: 0.05em;
    white-space: nowrap;
}








.order-wrap .wrapper .total-wrap .payments-wrap {
    width: 100%;
    
    display: flex;
    flex-direction: row;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0.5vw;
}

.order-wrap .wrapper .total-wrap .payment-wrap {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0.5vw;
}

.order-wrap .wrapper .total-wrap .payment-date {
    font-size: 0.45vw;
    line-height: 0.45vw;
    font-family: "light";
    color: #aaaaaa;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.order-wrap .wrapper .total-wrap .payment-sum {
    font-size: 0.65vw;
    line-height: 0.65vw;
    font-family: "bold";
    color: #d9d9d9;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.order-wrap .wrapper .total-wrap .payment-separator {
    width: 100%;
    height: 0.2vw;
    background-color: #ebebeb;
    border-radius: 0.5vw;
}

.order-wrap .wrapper .total-wrap .payment-active .payment-date,
.order-wrap .wrapper .total-wrap .payment-active .payment-sum {
    color: #000;
}

.order-wrap .wrapper .total-wrap .payment-active .payment-separator {
    background-color: var(--main-color);
}


.order-wrap .wrapper .total-action {
    font-size: 0.75vw;
    line-height: 1.15vw;
    font-family: bold;
    color: #fff;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;

    padding: 0.65vw 1.5vw;
    border-radius: 3vw;
    background-color: var(--main-color);
    margin: 0 auto;
}

.order-wrap .wrapper .total-action:hover {
    cursor: pointer;
    transform: scale(0.95);
}





































.products-wrap {
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.products-wrap .wrapper {
    width: 70vw;
    margin: 3vw 0;
    display: flex;
    justify-content: center;
    align-content: flex-start;
    align-items: flex-start;
    gap: 2vw;
    flex-direction: row;
    flex-wrap: wrap;
}

.products-wrap .product-wrap {
    width: 22vw;
    padding: 2vw;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    gap: 1.5vw;
    flex-direction: column;
    flex-wrap: nowrap;
    background-color: #fff;
    border-radius: 1.5vw;
    overflow: hidden;
    transition: 0.2s;
}

.products-wrap .product-title {
    font-size: 1.35vw;
    line-height: 1.65vw;
    font-family: "bold";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    text-align: center;
}

.products-wrap .product-price {
    font-size: 1.35vw;
    line-height: 1.65vw;
    font-family: "regular";
    color: #000;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.products-wrap .product-text {
    font-size: 1vw;
    line-height: 1.25vw;
    font-family: "light";
    color: #1e1e1e;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.products-wrap .product-actions {
    display: flex;
    gap: 1vw;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}

.products-wrap .product-action {
    font-size: 0.75vw;
    line-height: 1.15vw;
    font-family: "bold";
    color: var(--main-color);
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;

    padding: 0.65vw 1.5vw;
    border-radius: 3vw;
    border: 1px solid  var(--main-color);
    background-color: transparent;
}

.products-wrap .product-wrap:hover .product-action:hover {
    border: 1px solid transparent;
    background-color: var(--main-color);
    color: #fff;
    cursor: pointer;
    transform: scale(0.95);
}

.products-wrap .product-action[href="#"] {
    opacity: 0.25;
}

.products-wrap .product-img {
    width: 3vw;
    height: 3vw;
}

.products-wrap .product-img img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover;
    pointer-events: none;
    z-index: 1;
}

.products-wrap .product-tariffs {
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: flex-start;
    gap: 0.25vw;
}

.products-wrap .product-tariffs-title {
    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "bold";
    color: #000;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.products-wrap .product-tariff {
    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "light";
    color: #000;
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;
}

.products-wrap .product-examples {
    font-size: 0.55vw;
    line-height: 0.75vw;
    font-family: "bold";
    color: var(--main-color);
    letter-spacing: 0.05em;
    transition: 0.2s;
    text-align: center;

    padding-bottom: 0.25vw;
    border-bottom: 1px dashed var(--main-color);
}
