/* ==========================================================================
   Author's custom styles
   ========================================================================== */
@font-face {
    font-family: 'Satoshi-Bold';
    src: url('../fonts/Satoshi-Bold.woff2') format('woff2'),
    url('../fonts/Satoshi-Bold.woff') format('woff'),
    url('../fonts/Satoshi-Bold.ttf') format('truetype');
    font-weight: 700;
    font-display: swap;
    font-style: normal;
}

* {
    box-sizing: border-box;
}

.satoshi-bold {
    font-family: 'Satoshi-Bold', sans-serif;
}

.figtree {
    font-family: 'Figtree', serif;
    font-optical-sizing: auto;
    font-style: normal;
}

::-webkit-scrollbar-button {
    width: 3px;
    height: 0
}

::-webkit-scrollbar-track {
    background-color: #32312e;
    box-shadow: 0 0 3px #fff inset;
}

::-webkit-scrollbar-thumb {
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #DA7703;
    box-shadow: 0 1px 1px #fff inset;
}

::-webkit-resizer {
    width: 3px;
    height: 0
}

::-webkit-scrollbar {
    width: 3px;
    height: 3px
}
h1, h2, h3, h4 {
    font-weight: inherit;
    margin: 0;
    padding: 0;
}

img {
    width: 100%;
    max-width: 100%;
    transition: all 400ms ease;
}

a {
    color: #303030;
}

@keyframes blink {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: .5;
    }
}

#hellopreloader_preload {
    position: fixed;
    z-index: 99999;
    width: 100%;
    height: 100%;
    background: #ffffff;
}

#hellopreloader_preload img {
    width: 200px;
    animation: blink 1s infinite;
}

html {
    box-sizing: border-box;
    font-size: 20px;
    scroll-behavior: smooth;
}

body {
    font-family: "Figtree", serif;
    line-height: 1.4;
    font-weight: 400;
    color: #000000;
    text-wrap: balance;
    margin: 0;
    padding: 0;
    background: #ffffff;
}

main {
    overflow: hidden;
}

.flex {
    display: flex;
}

.flex-column {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.items-center {
    align-items: center;
}

.justify-center {
    justify-content: center;
}

.justify-between{
    justify-content: space-between;
}

.text-center {
    text-align: center;
}

.trigger-menu {
    display: none;
    position: relative;
    z-index: 99;
    width: 35px;
    height: 30px;
    padding: 0;
    outline: none;
    border: none;
    background: none;
    cursor: pointer;
    -webkit-appearence: none;
    -webkit-tap-highlight-color: transparent;
}
.trigger-menu svg {
    width: 35px;
    height: 30px;
    top: -6px;
    left: -14px;
    stroke: #000;
    stroke-width: 2px;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    display: block;
    position: absolute;
}
.trigger-menu svg path {
    transition: stroke-dasharray var(--duration, 0.85s) var(--easing, ease) var(--delay, 0s),
    stroke-dashoffset var(--duration, 0.85s) var(--easing, ease) var(--delay, 0s);
    stroke-dasharray: var(--array-1, 26px) var(--array-2, 100px);
    stroke-dashoffset: var(--offset, 126px);
    transform: translateZ(0);
}
.trigger-menu svg path:nth-child(2) {
    --duration: .7s;
    --easing: ease-in;
    --offset: 100px;
    --array-2: 74px;
}
.trigger-menu svg path:nth-child(3) {
    --offset: 133px;
    --array-2: 107px;
}
.trigger-menu.menu-open svg path {
    --offset: 57px;
}
.trigger-menu.menu-open svg path:nth-child(1),
.trigger-menu.menu-open svg path:nth-child(3) {
    --delay: .15s;
    --easing: cubic-bezier(.2, .4, .2, 1.1);
}
.trigger-menu.menu-open svg path:nth-child(2) {
    --duration: .4s;
    --offset: 2px;
    --array-1: 1px;
}
.trigger-menu.menu-open svg path:nth-child(3) {
    --offset: 58px;
}

.container {
    width: 100%;
    max-width: 1350px;
    padding: 0 15px;
    margin: 0 auto;
}

.preview {
    position: relative;
    min-height: 832px;
}

.preview .container {
    position: relative;
}

.header {
    position: fixed;
    z-index: 1;
    top: 28px;
    left: 0;
    width: 100%;
}

.header-content {
    position: relative;
    gap: 111px;
    padding: 16px 44px;
    background: rgba(242, 242, 242, 0.9);
    border-radius: 60px;
}

.header-content .logo {
    width: 136px;
}

.header-content .logo img {
    display: block;
}

.header-content .menu {
    gap: 24px;
    transition: all 500ms ease-in;
}

.menu-link {
    font-size: .9rem;
    line-height: 1;
    font-weight: 600;
    color: #303030;
    cursor: pointer;
}

.preview-content {
    max-width: 50%;
}

.proven {
    gap: 6px;
    margin-bottom: 10px;
}

.proven-icons img {
    width: 42px;
    aspect-ratio: 1 / 1;
}

.proven-icons img:not(:first-of-type) {
    margin-left: -12px;
}

.proven-title {
    font-size: .7rem;
    color: #7D7979;
}

.circle {
    position: absolute;
    right: 70px;
    top: 100%;
    width: 143px;
    height: 143px;
    border: 1px solid #000000;
    padding: 12px;
    border-radius: 50%;
}

.circle:before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 55%;
    height: 55%;
    border: 1px solid #000000;
    border-radius: 50%;
    transform: translateX(-50%) translateY(-50%);
}

.c-svg {
    position: absolute;
    top: 50%;
    left: 50%;
    cursor: pointer;
    transform: translateX(-50%) translateY(-50%);
}

.c-svg svg {
    display: block;
}

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.circle img {
    animation: rotate 20s linear infinite;
}

h1 {
    font-family: 'Satoshi-Bold', sans-serif;
    font-size: 4rem;
    line-height: 1;
    margin-bottom: 30px;
}

.preview-content h4 {
    margin-bottom: 68px;
}

h2 {
    font-family: 'Satoshi-Bold', sans-serif;
    font-size: 2.9rem;
    line-height: 1;
    margin-bottom: 12px;
}

h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 6px;
}

h4 {
    font-size: .9rem;
    color: #747474;
}

.c-button {
    cursor: pointer;
    font-family: 'Satoshi-Bold', sans-serif;
    font-size: .9rem;
    line-height: 1;
    color: #ffffff;
    border: 1px solid #000000;
    box-shadow: none;
    padding: 16px 22px;
    background: #000000;
    border-radius: 60px;
    transition: all .4s ease;
}

.c-button:hover {
    color: #000000;
    background: transparent;
}

.about {
    overflow: hidden;
    padding: 20px 0 60px;
}

.about-title {
    flex: 0 0 auto;
    max-width: 437px;
    margin-bottom: 40px;
}

.about-list {
    flex: 0 0 auto;
    gap: 35px;
    max-width: 765px;
}

.about-list--el {
    flex: 0 0 365px;
    width: 365px;
    height: 445px;
    background: #F8F9FA;
    border-radius: 16px;
}

.about-list--el-img {
    height: 209px;
}

.about-list--el-img img {
    display: block;
    width: inherit;
    margin: 0 auto;
}

.about-list--el-description {
    padding: 0 16px;
}

.clients {
    padding: 90px 0;
}

.clients-content {
    flex: 0 0 auto;
    max-width: 552px;
}

.c-marquee {
    margin-top: 70px;
}

.js-marquee {
    display: flex;
    gap: 30px;
}

.js-marquee-wrapper {
    display: flex;
    gap: 30px;
}

.marquee-wrapper {
    overflow: hidden;
    width: 100%;
    gap: 25px;
    margin-bottom: 25px;
}

.c-marquee--el {
    flex-shrink: 0;
    gap: 18px;
}

.c-marquee--el img {
    width: 64px;
    aspect-ratio: 1 / 1;
}

.client-name {
    font-family: 'Satoshi-Bold', sans-serif;
    font-size: 1.7rem;
    line-height: 1;
}

.touch {
    padding: 76px 0;
}

.touch .touch-content {
    position: relative;
    padding: 52px 0 42px;
}

.touch .touch-content:before {
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: -40px;
    width: calc(100% + 80px);
    height: 100%;
    border: 1px solid #D8D8D8;
    border-radius: 16px;
}

.touch-form {
    max-width: 510px;
}

.c-form {
    position: relative;
    margin: 35px 0 88px;
}

.c-form input {
    width: 100%;
    font-size: 1.1rem;
    line-height: 1;
    color: #A1A1A1;
    border: none;
    outline: none;
    padding: 20px 60px 20px 22px;
    border-radius: 16px;
    background: #F8F8F8;
}

.c-form input:focus {
    border: none;
}

.button-submit {
    position: absolute;
    right: 32px;
    top: 52%;
    opacity: .8;
    cursor: pointer;
    border: none;
    padding: 0;
    margin: 0;
    background: none;
    transform: translateY(-50%);
}

.button-submit:hover {
    opacity: 1;
}

.button-submit.disabled {
    cursor: not-allowed;
}

.button-submit svg {
    display: block;
}

footer {
    padding: 62px 0 50px;
}

.footer-logo {
    max-width: 296px;
    margin-right: 156px;
}

footer .menu {
    gap: 60px;
}

.copyright {
    font-size: .9rem;
    color: #747474;
    margin-top: 120px;
}

.copyright-privacy {
    color: #747474;
    text-decoration: none;
}

.c-modal {
    max-width: 1000px;
}




@media screen and (max-width: 539px) {
    .trigger-menu {
        display: block;
    }
    .preview .container {
        display: block;
    }
    .header {
        top: 14px;
    }
    .header-content {
        width: 100%;
        justify-content: space-between;
        padding: 14px 28px;
    }
    .header-content .menu {
        position: fixed;
        z-index: 9;
        top: 0;
        left: 0;
        overflow: hidden;
        flex-direction: column;
        height: 100vh;
        width: 80%;
        padding: 70px 20px;
        background: rgba(242, 242, 242, 0.9);
        transform: translateX(-100%);
    }
    .header-content .menu.menu-open {
        transform: translateX(0);
    }
    .header-content .logo {
        max-width: 135px;
    }
    .menu-link {
        width: 100%;
    }
    .preview-content {
        max-width: 100%;
    }
    .proven-icons img {
        width: 32px;
    }
    .proven-title {
        flex: 1 1 auto;
        width: 100%;
        font-size: .6rem;
        text-align: center;
        margin-bottom: 20px;
    }
    h1 {
        font-size: 2.3rem;
        margin-bottom: 18px;
    }
    h2 {
        font-size: 1.7rem;
        text-align: center;
        margin-bottom: 12px;
    }
    h3 {
      font-size: .9rem;
    }
    h4 {
        font-size: .8rem;
    }
    .preview-content h4 {
        margin-bottom: 40px;
    }
    .c-button {
        font-size: .8rem;
    }
    .circle {
        position: relative;
        right: inherit;
        top: inherit;
        margin: 90px auto 0;
    }
    .about-title {
        flex: 1 1 auto;
        max-width: 100%;
        margin-bottom: 44px;
    }
    .about-title h4 {
        text-align: center;
    }
    .about-list {
        flex: 1 1 auto;
        gap: 35px;
        max-width: 100%;
    }
    .about-list--el {
        flex: 1 1 auto;
        width: 100%;
        height: auto;
        padding-bottom: 40px;
    }
    .clients {
        padding: 0;
    }
    .clients-content {
        flex: 1 1 auto;
        max-width: 100%;
    }
    .c-marquee--el img {
        width: 42px;
    }
    .client-name {
        font-size: 1.2rem;
    }
    .marquee-wrapper {
        margin-bottom: 5px;
    }
    .touch {
        padding-bottom: 0;
    }
    .touch .touch-content {
        padding: 40px 15px;
    }
    .touch .touch-content:before {
        left: 0;
        width: 100%;
    }
    .c-form {
        margin-bottom: 32px;
    }
    .c-form input {
        font-size: 1rem;
    }
    .button-submit {
        right: 15px;
    }
    footer {
        padding: 62px 0 10px;
    }
    .footer-logo {
        max-width: 260px;
        margin: 0 0 40px;
    }
    footer .menu {
        flex-wrap: wrap;
        gap: 16px;
    }
    footer .menu .menu-link {
        flex: 1 1 auto;
        width: 100%;
    }
    .copyright {
        font-size: .7rem;
        margin-top: 64px;
    }
    .copyright-privacy {
        order: -1;
        margin-bottom: 12px;
    }
}