@font-face {
    font-family: 'Lastica';
    src: url('../fonts/lastica.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

html, body{
    text-shadow: 0.5px 0 0 currentcolor !important;
}


.app-animated-canvas[data-v-ee4df370] {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    z-index: 10
}

.app-animated-canvas canvas[data-v-ee4df370] {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1
}

.app-button {
    padding: .4rem 1rem;
    border: 2px solid var(--main-color-100);
    border-radius: 1rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: .88rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--main-color-100);
    background: #fff;
    cursor: pointer;
    transition: all ease-in-out .25s
}

.app-button:hover {
    background: var(--main-color-100);
    color: #fff
}

.app-button.round {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 50%
}

.app-button.dark {
    background: var(--main-color-100);
    color: #fff;
    border: 1px solid white
}

.app-button.small {
    font-size: .7rem
}

.app-footer {
    display: flex;
    flex-direction: column
}

.app-footer .cta {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 116px 80px 115px;
    border-top: solid var(--main-color-100) 2px;
    background-color: #f8f9ff;
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px
}

.app-footer .cta .lego {
    position: absolute;
    top: calc(50% - 180px);
    right: 120px;
    display: var(--display-desktop);
    width: 500px
}

.app-footer .cta h2 {
    display: inline-flex;
    margin: 30px 0 20px;
    font-size: 4.5rem;
    font-weight: 700;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    background-color: #fff;
    border-radius: 100px
}

.app-footer .cta p {
    padding: 6px 0;
    font-size: 1.1rem;
    font-weight: 400;
    background-color: #fff
}

.app-footer .cta .email {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 10px;
    margin-top: 20px
}

.app-footer .cta .email span {
    margin-top: 60px;
    margin-bottom: 30px;
    font-size: 1rem;
    font-weight: 400;
    background-color: #fff
}

.app-footer .footer {
    position: relative;
    padding: 100px;
    color: #fff;
    background: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-position: bottom center;
    background-size: cover
}

.app-footer .footer h3 {
    position: relative;
    margin-bottom: 0;
    font-size: 3.5rem;
    font-weight: 300;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif
}

.app-footer .footer h3 .icons {
    position: absolute;
    top: 0;
    right: 0;
    display: var(--display-desktop);
    gap: 100px
}

.app-footer .footer form {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    margin: 20px 0 150px;
    padding: .5rem 0;
    border-bottom: 1px solid white
}

.app-footer .footer form input {
    padding: .2rem 0;
    min-width: 350px;
    background: transparent;
    border: 0;
    color: #fff;
    font-size: 1.1rem;
    font-family: Roboto Mono, monospace;
    font-weight: 300
}

.app-footer .footer form input::placeholder {
    color: #fff
}

.app-footer .footer form input:focus {
    outline: 0
}

.app-footer .footer form button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: .2rem;
    padding-bottom: .2rem;
    font-family: Roboto Mono, monospace;
    font-size: 1.8rem;
    line-height: .8;
    color: var(--main-color-100);
    background: #fff;
    border-radius: 50%;
    border: 0
}

.app-footer .footer .links {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 1rem
}

.app-footer .footer .links h4 {
    margin-bottom: 20px;
    font-weight: 300
}

.app-footer .footer .links>div {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    padding: .4rem
}

.app-footer .footer .legals {
    margin: 100px 0 0;
    text-align: center;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif
}

@media screen and (max-width: 960px) {
    .app-footer .cta {
        padding: 20px
    }
    .app-footer .footer {
        padding: 100px 20px
    }
    .app-footer .footer form input {
        min-width: 200px
    }
}

.app-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    padding-top: 15px;
    z-index: 100
}

.app-header .logo {
    margin-top: 0px;
    transform: translate(-2px)
}

.app-header .menu-mobile {
    display: none
}

.app-header .left {
    position: fixed;
    top: 50%;
    left: 38px;
    display: var(--display-desktop);
    padding: 1px 6px;
    font-size: .77rem;
    font-weight: 400;
    transform: translate(-50%) translateY(-50%) rotate(-90deg);
    background: #fffffff2;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 10px
}

.app-header .right {
    position: fixed;
    top: 50%;
    right: 38px;
    display: var(--display-desktop);
    padding: 1px 6px;
    font-size: .77rem;
    font-weight: 400;
    transform: translate(50%) translateY(50%) rotate(90deg);
    background: #fffffff2;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 10px
}

.app-header .bottom-left {
    position: fixed;
    bottom: 17px;
    left: 11px;
    display: var(--display-desktop);
    padding: 3px 5px;
    font-size: .75rem;
    font-weight: 400;
    background: #fffffff2;
    border-radius: 10px
}

.app-header .bottom-right {
    position: fixed;
    bottom: 20px;
    right: 18px;
    display: var(--display-desktop);
    flex-direction: column;
    gap: 10px;
    font-size: .8rem;
    font-weight: 400
}

.app-header .navbar {
    display: flex;
    justify-content: space-between;
    padding: 0 5px 0 15px;
    width: 100%
}

.app-header .navbar .links {
    display: flex;
    align-items: center;
    gap: 30px;
    padding: 0 20px;
    background: #fffffff2;
    border-radius: 20px;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.app-header .navbar .links .mobile {
    display: none
}

.app-header .navbar .links a {
    text-transform: uppercase;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: .88rem;
    position: relative;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Desktop hover effect */
@media screen and (min-width: 961px) {
    .app-header .navbar .links a:not(.app-button):not([target="_blank"]):before {
        content: '';
        position: absolute;
        bottom: -5px;
        left: 0;
        width: 0;
        height: 3px;
        background: linear-gradient(90deg, var(--main-color-100), var(--main-color-70));
        transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        border-radius: 2px;
        box-shadow: 0 2px 8px rgba(67, 97, 238, 0.4);
    }
    
    .app-header .navbar .links a:not(.app-button):not([target="_blank"]):hover {
        color: var(--main-color-100);
        transform: translateY(-2px);
    }
    
    .app-header .navbar .links a:not(.app-button):not([target="_blank"]):hover:before {
        width: 100%;
    }
}

.app-header .navbar .links .contact {
    box-shadow: 0 2px 6px var(--main-color-80)
}

@media screen and (max-width: 960px) {
    .app-header .navbar .menu-mobile {
        position: absolute;
        top: 24px;
        right: 20px;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 46px;
        height: 46px;
        padding: 0 0 4px;
        font-size: 28px;
        line-height: 10px;
        background: transparent;
        border: 2px solid var(--main-color-100);
        border-radius: 50%;
        color: var(--main-color-100);
        background: #fff;
        box-shadow: .5px 2px 0 var(--main-color-100);
        z-index: 30
    }
    .app-header .navbar .menu-mobile.open {
        background: var(--main-color-100);
        border-color: #fff;
        box-shadow: .5px 2px #fff;
        color: #fff
    }
    .app-header .navbar .links {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 100%;
        height: 100vh;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        gap: 5vh;
        background: var(--main-color-100);
        border-radius: 0;
        z-index: 20;
        transform: translateY(0);
        transition: all ease-in-out .7s
    }
    .app-header .navbar .links .mobile {
        display: block
    }
    .app-header .navbar .links.open {
        transform: translateY(100%)
    }
    .app-header .navbar .links a {
        font-size: 1.4rem;
        color: #fff
    }
    .app-header .navbar .links .app-button {
        margin-top: 40px;
        padding: 14px 40px;
        font-size: 1.2rem;
        border-radius: 40px;
        color: #fff;
        border-color: #fff;
        background: var(--main-color-100)
    }
}

.app-marquee {
    display: flex;
    align-items: center;
    overflow: hidden;
    position: relative
}

.app-marquee .marquee-content {
    display: flex;
    flex-shrink: 0;
    gap: 2rem;
    padding: 1rem 1rem 2rem;
    animation: marquee 50s linear infinite
}

.app-marquee .marquee-content>* {
    flex-shrink: 0
}

.app-marquee.reverse .marquee-content {
    animation: marquee-reverse 80s linear infinite
}

@keyframes marquee {
    0% {
        transform: translate(0)
    }
    to {
        transform: translate(-100%)
    }
}

@keyframes marquee-reverse {
    0% {
        transform: translate(-100%)
    }
    to {
        transform: translate(0)
    }
}

.app-mask-image {
    background-size: cover;
    background-position: center center;
    overflow: hidden
}

.app-mask-image img {
    display: block;
    max-width: 600px
}

.app-richtext h1 {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3rem
}

.app-richtext h2 {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 2rem
}

.app-richtext p,
.app-richtext li {
    font-size: 1rem
}

.app-richtext ul {
    padding-left: 16px
}

.app-richtext ul li {
    margin: 20px 0
}

.app-richtext hr {
    margin: 3rem 0;
    border-top: 1px dashed var(--main-color-100)
}

.app-tag {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: .9rem;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100)
}

.app-tag.dark {
    background: var(--main-color-100);
    color: #fff;
    border-color: #fff;
    box-shadow: 0 4px #fff
}

.app-tag.small {
    padding: .3rem .7rem;
    font-size: .6rem;
    box-shadow: 0 2px 0 var(--main-color-100)
}

.app-tag.square {
    border-radius: 0;
    box-shadow: none
}

.app-video {
    background: var(--main-color-100)
}

.app-word {
    display: inline-flex
}

.app-word~.app-word {
    margin-left: 20px
}

.app-word>span {
    position: relative;
    display: inline-block;
    animation: 10s letters infinite;
    transform-origin: bottom;
    transform-style: preserve-3d
}

.app-word>span>span {
    backface-visibility: hidden;
    line-height: 1
}

.app-word>span>span.front {
    transform-origin: bottom
}

.app-word>span>span.back {
    position: absolute;
    left: 0;
    opacity: .8;
    animation: 10s melt;
    transform-origin: bottom center;
    transform: rotateX(90deg) translateZ(52px)
}

@keyframes letters {
    0% {
        transform: rotateX(-90deg) translateY(-5px)
    }
    5% {
        transform: rotateX(0) translateY(0)
    }
    80% {
        transform: rotateX(0) translateY(0)
    }
}

@keyframes melt {
    0% {
        opacity: 1
    }
    5% {
        opacity: .2
    }
    80% {
        opacity: .2
    }
}

.block-blueprint {
    display: flex;
    align-items: center;
    gap: 80px;
    padding: 50px 150px 150px
}

.block-blueprint div h3 {
    margin: 40px 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 300;
    font-size: 4rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.block-blueprint div p {
    font-size: 1rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.block-blueprint div .actions {
    display: flex;
    margin: 50px 0 0
}

.block-blueprint div img {
    margin-top: -20px;
    max-width: 480px
}

.block-how-we-work .how {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 40px;
    padding: 100px var(--page-side-padding) 50px;
    background-image: url(target.svg);
    background-size: 30px;
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.block-how-we-work .how .head {
    position: relative;
    padding: 70px 10px 100px
}

.block-how-we-work .how .head>div {
    position: sticky;
    top: 180px;
    min-height: 280px
}

.block-how-we-work .how .head small {
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid var(--main-color-100);
    background: #fff
}

.block-how-we-work .how .head h2 {
    margin: 20px 0;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.block-how-we-work .how .head p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.block-how-we-work .how .steps {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding: 60px 0 160px
}

.block-how-we-work .how .steps .card {
    position: sticky;
    top: 180px;
    padding-bottom: 6px;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-80);
    overflow: hidden
}

.block-how-we-work .how .steps .card>div {
    padding: 60px 60px 60px 220px;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.block-how-we-work .how .steps .card>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 20px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.block-how-we-work .how .steps .card>div strong {
    position: absolute;
    left: -40px;
    top: 30px;
    display: inline-flex;
    margin-bottom: 20px;
    font-weight: 500;
    font-size: 12.5rem;
    color: #fff;
    -webkit-text-stroke: 1.5px var(--main-color-100);
    text-shadow: 2px 6px 0 var(--main-color-100)
}

.block-how-we-work .how .steps .card>div h3 {
    margin: 0;
    font-size: 2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.block-how-we-work .how .steps .card>div .app-image {
    margin: 30px 0 10px;
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px dashed var(--main-color-100);
    border-radius: 20px
}

.block-how-we-work .how .steps .card>div .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.block-how-we-work .how .steps .card.small>div {
    display: flex;
    align-items: center;
    gap: 10px
}

.block-how-we-work .how .steps .card.small small {
    margin: -10px 0 10px
}

.block-how-we-work .how .steps .card.small .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    width: 60px;
    height: 60px;
    font-size: 2.5rem;
    font-weight: 100;
    line-height: 1;
    border: 1px solid var(--main-color-100);
    border-radius: 50%
}

@media screen and (max-width: 960px) {
    .block-how-we-work .how .head {
        padding-bottom: 0
    }
    .block-how-we-work .how .head h2 {
        font-size: 3rem
    }
    .block-how-we-work .how .steps {
        padding-top: 0
    }
    .block-how-we-work .how .steps .card {
        top: 100px
    }
    .block-how-we-work .how .steps .card>div {
        padding-left: 40px
    }
    .block-how-we-work .how .steps .card>div strong {
        position: relative;
        left: 0
    }
}

.block-projects {
    padding: 100px var(--page-side-padding) 110px
}

.block-projects h2 {
    margin: 20px 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3.8rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.block-projects .grid {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 40px;
    margin-top: 60px
}

.block-projects .project {
    padding: 0;
    border-radius: 20px;
    box-shadow: 0 10px 40px var(--main-color-90)
}

.block-projects .project>div {
    padding: 60px;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 6px 0 var(--main-color-100)
}

.block-projects .project .content {
    display: flex;
    flex-direction: var(--flex-direction);
    justify-content: space-between;
    gap: 30px
}

.block-projects .project .number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    font-size: 1.5rem;
    font-weight: 300;
    border: 2px solid var(--main-color-100);
    border-radius: 50%;
    text-align: center;
    background: var(--main-color-100);
    color: #fff;
    box-shadow: 4px 4px 10px var(--main-color-90)
}

.block-projects .project h3 {
    margin: 20px 0 0;
    font-size: 3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif
}

.block-projects .project .image {
    margin: 20px 0;
    max-height: 120px;
    background: var(--main-color-100);
    overflow: hidden;
    border: 1px solid var(--main-color-100)
}

.block-projects .project .app-mask-image {
    transform: translate(20px) translateY(-20px)
}

.block-projects .project .app-mask-image img {
    max-width: 230px
}

.block-projects .project .tags {
    display: flex;
    gap: .4rem;
    margin: 30px 0;
    font-weight: 600;
    font-size: .8rem
}

.block-projects .project .references {
    display: flex;
    gap: .4rem;
    margin-top: 30px;
    font-weight: 600;
    font-size: .65rem
}

.block-projects .project .references>* {
    padding: .3rem .7rem;
    border: 1px solid var(--main-color-100)
}

.block-projects .project p {
    margin: 10px 0;
    min-height: 90px;
    font-size: .95rem
}

.block-projects .project .actions {
    display: flex;
    justify-content: right
}

.block-projects .project .actions .app-button {
    box-shadow: 4px 4px 10px var(--main-color-90)
}

@media screen and (max-width: 960px) {
    .block-projects .project>div {
        padding: 40px
    }
    .block-projects .project .app-mask-image {
        transform: translate(0)
    }
    .block-projects .project .app-mask-image img {
        max-width: 100%
    }
}

.logo[data-v-8bad50df] {
    height: 6em;
    padding: 1.5em;
    will-change: filter
}

.logo[data-v-8bad50df]:hover {
    filter: drop-shadow(0 0 2em #646cffaa)
}

.logo.vue[data-v-8bad50df]:hover {
    filter: drop-shadow(0 0 2em #42b883aa)
}

.home .hero {
    padding: 15px var(--page-side-padding) 0
}

.home .hero>div {
    border-radius: 20px;
    box-shadow: 0 10px 30px var(--main-color-90);
    background: #fff;
    transform: scale(.85) translateY(50px);
    animation: home-grow .25s ease-in-out forwards
}

.home .hero canvas {
    border-radius: 20px
}

.home .hero .grid {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    margin-bottom: 6px;
    padding: 40px var(--home-grid-padding);
    min-height: calc(100vh - 140px);
    border: solid var(--main-color-100) 2px;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.home .hero .grid>div {
    display: flex;
    flex-direction: column;
    align-items: flex-end
}

.home .hero .grid h3 {
    margin: 0;
    padding: 10px;
    font-weight: 200;
    font-size: .8rem;
    background-color: #ffffffd9
}

.home .hero .grid h1 {
    margin-top: 20px;
    font-size: 3.5rem;
    line-height: 4rem;
    font-weight: 300;
    text-align: right;
    font-family:AmpleSoft !important;
}

.home .hero .grid h1 mark {
    color: var(--main-color-100);
    background: #fff
}

.home .hero .grid img {
    width: 100%;
    max-width: 640px
}

.home .hero .grid .actions {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 15px
}

.home .hero .grid .actions a {
    transition: transform ease-in-out .2s
}

.home .hero .grid .actions a:hover {
    transform: scale(1.05)
}

.home .work {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 150px var(--page-side-padding);
    border-top: solid 1px var(--main-color-100);
    border-bottom: solid 1px var(--main-color-100);
    background: linear-gradient(45deg, var(--main-color-80) .5%, #fff .5%, #fff 49.5%, var(--main-color-80) 49.5%, var(--main-color-80) 51%, #fff 51%, #fff 99.5%, var(--main-color-80) 99.5%);
    background-size: 50px 50px;
    background-position: 50px 50px
}

.home .work>h2 {
    margin: 20px 0 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3.6rem;
    font-weight: 700;
    background: #ffffffd9
}

.home .work>p {
    margin-bottom: 100px;
    max-width: 500px;
    background: #ffffffd9
}

.home .work .illu {
    position: absolute;
    top: 100px;
    right: 100px;
    display: var(--display-desktop);
    width: 540px
}

.home .work .line {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 40px;
    margin-bottom: 60px;
    width: 100%
}

.home .work .line:nth-child(odd) {
    flex-direction: var(--flex-direction-reverse);
    justify-content: flex-end
}

.home .work .line:nth-child(odd) .legend {
    transform: rotate(-2deg)
}

.home .work .project {
    position: relative;
    display: flex;
    flex: 1;
    align-items: center;
    padding: 0;
    width: 33%;
    background: #fff;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 2px 6px 10px var(--main-color-60);
    transition: all ease-in-out .15s
}

.home .work .project:hover {
    transform: scale(1.01)
}

.home .work .project>div {
    display: flex;
    justify-content: center;
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
}

.home .work .project>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 15px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.home .work .project>div .tags {
    position: absolute;
    left: 20px;
    top: 20px;
    display: flex;
    gap: 10px;
    font-size: .75rem;
    font-weight: 400
}

.home .work .project>div .references {
    position: absolute;
    right: 20px;
    bottom: 20px;
    display: flex;
    gap: 10px;
    font-size: .75rem;
    font-weight: 400
}

.home .work .project>div .references>* {
    padding: 2px 8px;
    border: 1px solid var(--main-color-100)
}

.home .work .project>div .app-mask-image {
    display: inline-flex;
    margin: 40px 0 40px 5px
}

.home .work .project>div .app-mask-image>img {
    max-width: 400px
}

.home .work .project>div .number {
    position: absolute;
    left: 10px;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    color: #fff;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 4.85rem;
    line-height: 1;
    font-weight: 700;
    -webkit-text-stroke: 1.5px var(--main-color-100);
    text-shadow: 0 4px 0 var(--main-color-100)
}

.home .work .project>div:hover>img.cover {
    opacity: 0
}

.home .work .legend {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2rem;
    border-radius: 20px;
    box-shadow: 0 8px 20px var(--main-color-90);
    transform: rotate(2deg)
}

.home .work .legend>div {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 40px;
    padding: 30px;
    width: 300px;
    height: 100%;
    background: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100)
}

.home .work .legend>div:before {
    content: "";
    position: absolute;
    top: -30px;
    right: -10px;
    width: 46px;
    height: 66px;
    background: transparent url(pin.svg) no-repeat center center;
    background-size: cover
}

.home .work .legend a {
    position: relative
}

.home .work .legend .number {
    position: absolute;
    top: 8px;
    left: -6px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    color: var(--main-color-100);
    border-radius: 50%;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: .85rem;
    line-height: 1;
    font-weight: 700;
    background: #fff;
    border: 1px solid var(--main-color-100)
}

.home .work .legend h3 {
    margin: 0;
    padding-left: 40px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 2.2rem;
    font-weight: 700;
    background: #fff
}

.home .work .legend p {
    margin: 0;
    padding-left: 40px;
    font-size: .7rem;
    font-weight: 400;
    background: #fff
}

.home .work .action {
    margin-top: 60px;
    padding: 0 40px;
    text-align: right
}

.home .work .action .app-button {
    transform: scale(1.2)
}

.home .customers {
    margin-top: 100px;
    padding: 50px 0;
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100);
    background: linear-gradient(-45deg, var(--main-color-80) .5%, #fff .5%, #fff 49.5%, var(--main-color-80) 49.5%, var(--main-color-80) 51%, #fff 51%, #fff 99.5%, var(--main-color-80) 99.5%);
    background-size: 50px 50px;
    background-position: 50px 50px
}

.home .customers .head {
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 50px var(--page-side-padding) 0
}

.home .customers .head h2 {
    margin: 40px 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3rem;
    font-weight: 700
}

.home .customers .head h2 mark {
    color: var(--main-color-100);
    background: #fff
}

.home .customers .head p {
    background: #fff
}

.home .customers .companies {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 30px 0
}

.home .customers .companies .company {
    display: flex;
    border-radius: 20px;
    box-shadow: 0 4px 10px var(--main-color-80);
    transition: all ease-in-out .15s
}

.home .customers .companies .company:nth-child(3n) {
    transform: rotate(-3deg)
}

.home .customers .companies .company:nth-child(3n+1) {
    transform: rotate(3deg)
}

.home .customers .companies .company>span {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    width: 150px;
    height: 150px;
    background: #fff;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 0 4px 0 var(--main-color-100)
}

.home .customers .companies .company img {
    display: block;
    max-width: 100%;
    max-height: 50%;
    transition: transform ease-in-out .2s
}

.home .customers .companies .company:hover {
    transform: scale(1.05)
}

.home .customers .companies .company:hover:nth-child(3n) {
    transform: scale(1.05) rotate(3deg)
}

.home .customers .companies .company:hover:nth-child(3n+1) {
    transform: scale(1.05) rotate(-3deg)
}

.home .how {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 100px var(--page-side-padding) 150px;
    border-bottom: 1px solid var(--main-color-100);
    background: #fff
}

.home .how .head {
    position: var(--position-sticky);
    top: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center
}

.home .how .head h2 {
    position: relative;
    margin: 30px 0 10px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3.6rem;
    font-weight: 700;
    background: #fff
}

.home .how .head h2:after {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;
    width: 26px;
    height: 26px;
    background: transparent url(oh.svg) no-repeat center center;
    background-size: cover
}

.home .how .head h2:before {
    content: "";
    position: absolute;
    top: -40px;
    left: -40px;
    width: 26px;
    height: 26px;
    background: transparent url(oh.svg) no-repeat center center;
    background-size: cover;
    transform: rotate(-40deg)
}

.home .how .steps {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 80px;
    margin-top: 60px
}

.home .how .steps .card {
    position: var(--position-sticky);
    top: 330px;
    padding-bottom: 6px;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-90)
}

.home .how .steps .card>div {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: start;
    justify-content: center;
    padding: 60px;
    padding-left: var(--card-padding);
    min-height: 380px;
    background: #fff;
    background-image: url(target.svg);
    background-size: 40px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    overflow: hidden
}

.home .how .steps .card>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 20px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.home .how .steps .card>div:before {
    content: "";
    position: absolute;
    bottom: 20px;
    right: 20px;
    width: 24px;
    height: 32px;
    background: transparent url(thunder.svg) no-repeat center center;
    background-size: cover
}

.home .how .steps .card>div strong {
    position: var(--card-position);
    left: -30px;
    top: 50px;
    display: inline-flex;
    margin-bottom: 20px;
    font-weight: 500;
    font-size: 14rem;
    color: #fff;
    -webkit-text-stroke: 1.5px var(--main-color-100);
    text-shadow: 0 6px 0 var(--main-color-100);
    transform: rotate(-15deg);
    transition: all ease-in-out .2s
}

.home .how .steps .card>div h3 {
    margin: 10px 0;
    font-size: 2.3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.home .how .steps .card>div p {
    margin: 10px 0;
    font-size: 1.1rem;
    background: #fff
}

.home .how .steps .card>div p:last-child {
    margin-top: 20px;
    font-size: .8rem;
    font-weight: 500
}

.home .how .steps .card>div .app-image {
    margin: 30px 0 10px;
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px dashed var(--main-color-100);
    border-radius: 20px
}

.home .how .steps .card>div .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.home .how .steps .card.small>div {
    display: flex;
    align-items: center;
    gap: 10px
}

.home .how .steps .card.small small {
    margin: -10px 0 10px
}

.home .how .steps .card.small .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    width: 60px;
    height: 60px;
    font-size: 2.5rem;
    font-weight: 100;
    line-height: 1;
    border: 1px solid var(--main-color-100);
    border-radius: 50%
}

.home .how .steps .card:hover>div strong {
    transform: scale(1.05) rotate(-15deg)
}

.home .features {
    padding: 150px var(--page-side-padding) 100px;
    background-image: url(footer-background.svg)
}

.home .features>h2 {
    margin: 15px 0 20px;
    font-size: 4rem;
    line-height: 1;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
   
}

.home .features>div {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
    margin-top: 100px
}

.home .features>div>div {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 40px
}

.home .features>div>div .title {
    display: flex;
    align-items: center;
    padding: 10px 0 15px 10px;
    color: #fff;
    background: var(--main-color-100)
}

.home .features>div>div .title p {
    margin: 0;
    font-size: 1.15rem
}

.home .features>div>div .card {
    position: relative;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-40);
    transition: all ease-in-out .15s
}

.home .features>div>div .card:nth-child(odd) {
    transform: rotate(2deg)
}

.home .features>div>div .card>div {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 40px 40px 30px 60px;
    height: 100%;
    background: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.home .features>div>div .card>div:before {
    content: "";
    position: absolute;
    top: 30px;
    left: -22px;
    height: 230px;
    width: 60px;
    background: transparent;
    background-image: url(book.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-y;
    background-size: 43px 45px, auto
}

.home .features>div>div .card h3 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0 0 10px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 1.4rem;
    text-wrap: balance;
    background: #fff
}

.home .features>div>div .card .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.home .features>div>div .card p {
    margin: 0;
    font-size: .85rem;
    background: #fff
}

.home .features>div>div .card:hover {
    transform: scale(1.02)
}

.home .features>div>div .card:hover:nth-child(odd) {
    transform: scale(1.02) rotate(2deg)
}

.home .features .actions {
    display: flex;
    justify-content: center;
    margin-top: 100px
}

.home .features .actions .app-button {
    box-shadow: 0 5px 10px var(--main-color-40);
    transform: scale(1.2)
}

.home .techs {
    display: grid;
    grid-template-columns: 34% 64%;
    gap: 20px;
    padding: 180px var(--page-side-padding) 180px;
    color: #fff;
    background: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-size: cover
}

.home .techs .list {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 80px 80px;
    padding-top: 60px;
    padding-right: 80px
}

.home .techs>div:first-child {
    display: block;
    padding-top: 0;
    padding-right: 30px
}

.home .techs>div:first-child>small {
    display: inline-block;
    margin: 0 0 20px;
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid white
}

.home .techs>div:first-child>h2 {
    margin: 35px 0 20px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    background: var(--main-color-100);
    font-weight: 700
}

.home .techs>div:first-child p {
    background: var(--main-color-100)
}

.home .techs .card {
    display: flex;
    flex-direction: column;
    align-items: start
}

.home .techs .card h3 {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--main-color-100)
}

.home .techs .card h3 img {
    max-height: 50px
}

.home .techs .card p {
    font-size: .9rem;
    background: var(--main-color-100)
}

.home .techs .card .app-button {
    margin-top: 10px;
    transform: scale(.8);
    transform-origin: left center
}

.home .techs .card a {
    transition: all ease-in .15s
}

.home .techs .card a:hover {
    transform: scale(1.07)
}

.home .techs .action {
    padding: 40px 0 0
}

.home .techs .action .app-button {
    transform: scale(1)
}

.home .sectors {
    position: relative;
    min-height: 100px;
    transform: rotate(-.5deg), translate(-40px);
    z-index: 20
}

.home .sectors .app-marquee {
    position: absolute;
    left: 0;
    right: 0;
    background: #fff;
    border: 2px dashed var(--main-color-100);
    box-shadow: 0 10px 20px var(--main-color-40)
}

.home .sectors .app-marquee .marquee-content {
    padding: 1rem
}

.home .sectors .sector {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 10px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.home .sectors .sector .code {
    display: inline-flex;
    padding: 4px 10px;
    font-size: 1rem;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    text-transform: uppercase
}

.home .ia {
    display: flex;
    justify-content: center;
    margin-top: 100px;
    padding: 100px var(--page-side-padding) 100px;
    background: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-size: cover;
    color: #fff
}

.home .ia .container {
    position: relative;
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    justify-content: space-between;
    max-width: 1200px
}

.home .ia .container img {
    max-height: 300px
}

.home .ia .container .badge {
    position: absolute;
    top: 50px;
    right: 0;
    width: 100px
}

.home .ia h2 {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin: 15px 0 30px;
    font-size: 3rem;
    line-height: 1.2;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    color: #fff;
    text-wrap: balance
}

.home .ia h2 em {
    font-weight: 300;
    font-size: 60%
}

.home .ia p,
.home .ia ul {
    padding: 10px 0;
    max-width: 700px;
    line-height: 1.4;
    text-wrap: balance
}

.home .ia p li,
.home .ia ul li {
    margin: 16px 0;
    text-wrap: balance
}

.home .ia p strong,
.home .ia ul strong {
    font-weight: 700
}

.home .ia ul {
    padding-top: 0;
    padding-left: 16px
}

@media screen and (max-width: 960px) {
    .home .hero .grid {
        background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
        background-size: 20px 20px;
        background-position: -1px -1px
    }
    .home .hero .grid>div {
        align-items: start;
        padding: 10px
    }
    .home .hero .grid>img {
        width: 400px
    }
    .home .hero .grid h3 {
        margin-top: 20px;
        padding: 0;
        font-size: .75rem;
        line-height: 2;
        text-wrap: balance
    }
    .home .hero .grid h3 strong {
        font-size: 1rem
    }
    .home .hero .grid h1 {
        text-align: left;
        font-size: 2.8rem;
        line-height: 1.2
    }
    .home .hero .grid .actions {
        width: 100%
    }
    .home .ia .container .badge {
        position: relative
    }
    .home .ia .container img {
        margin-top: 30px
    }
    .home .app-animated-canvas {
        overflow: visible !important
    }
    .home .app-animated-canvas canvas {
        display: none
    }
    .home .how .head h2 {
        font-size: 3rem
    }
    .home .how .steps .card {
        top: 100px
    }
    .home .how .steps .card>div strong {
        transform: rotate(0)
    }
    .home .work .project {
        width: 100%
    }
    .home .work .project>div .tags {
        font-size: .5rem
    }
    .home .work .legend>div {
        width: 100%
    }
    .home .techs {
        grid-template-columns: repeat(1, 1fr)
    }
}

@keyframes home-grow {
    0% {
        transform: scale(.85) translateY(50px);
        opacity: 0
    }
    to {
        transform: scale(1) translateY(0)
    }
}

.articles .hero {
    position: relative;
    margin: 15px var(--page-side-padding) 0px;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.articles .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 100px var(--home-grid-padding) 80px;
    padding-right: 700px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.articles .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.articles .hero>div>div:after {
    content: "";
    position: absolute;
    top: 30px;
    right: 100px;
    bottom: 30px;
    width: 500px;
    background-image: url(wca-media.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.articles .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.articles .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.articles .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px;
    text-wrap: balance
}

.articles .content {
    display: flex;
    flex-direction: column;
    align-items: start;
    margin-top: 80px;
    padding: 100px var(--page-side-padding) 140px;
    background-image: url(footer-background.svg)
}

.articles .content>h2 {
    margin: 40px 0 5px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    color: #fff
}

.articles .content>p {
    color: #fff
}

.articles .list {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px;
    margin-top: 60px
}

.articles .list .card {
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    background: #fff;
    box-shadow: 4px 10px 20px var(--main-color-40)
}

.articles .list .card>div {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 50px 40px;
    height: 100%;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.articles .list .card>div .date {
    font-size: .6rem;
    font-weight: 500
}

.articles .list .card>div h3 {
    margin: 0;
    font-size: 1.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.articles .list .card>div p {
    margin: 0;
    min-height: 120px;
    font-size: .85rem
}

.articles .list .card>div .tags {
    display: flex;
    gap: 1rem;
    margin: 0 0 2rem
}

.articles .list .card>div .tags>span {
    font-weight: 700;
    font-size: .8rem;
    text-transform: uppercase
}

.articles .list .card>div .tags>span:before {
    content: "•";
    display: inline-flex;
    padding-right: .2rem
}

@media screen and (max-width: 960px) {
    .articles .hero>div>div {
        padding: 420px 20px 20px
    }
    .articles .hero>div>div:after {
        right: 0;
        left: -80px;
        bottom: 460px;
        width: 480px
    }
}

.article {
    display: flex;
    justify-content: center;
    padding: 100px 0
}

.article .content {
    position: relative;
    max-width: 900px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 10px 10px 20px var(--main-color-70)
}

.article .content>div {
    padding: 100px;
    border-radius: 20px;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 6px 0 var(--main-color-100)
}

.article .content:before {
    content: "";
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 50px;
    background: transparent;
    background-image: url(carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 42px 40px, auto;
    z-index: 10
}

.article .content .tags {
    display: flex;
    gap: 10px
}

.article .content h1 {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3rem
}

.article .content h2 {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 2rem
}

.article .content p {
    font-size: 1rem;
    text-wrap: pretty
}

.article .content a {
    font-weight: 500;
    text-decoration: underline
}

.article .content hr {
    margin: 100px 0;
    border: 1px dashed var(--main-color-100)
}

@media screen and (max-width: 960px) {
    .article {
        padding: 40px 30px 100px
    }
    .article .content>div {
        padding: 50px 40px
    }
}

.cities .hero {
    position: relative;
    margin: 15px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.cities .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 100px var(--home-grid-padding) 80px;
    padding-right: 400px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.cities .hero>div>div:after {
    content: "";
    position: absolute;
    top: 10px;
    right: 50px;
    bottom: 10px;
    width: 560px;
    background-image: url(wca-agency.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.cities .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.cities .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.cities .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.cities .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.cities .content {
    display: flex;
    flex-direction: column;
    align-items: start;
    margin-top: 100px;
    padding: 100px var(--page-side-padding) 140px;
    background-image: url(footer-background.svg)
}

.cities .content>h2 {
    margin: 40px 0 5px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    color: #fff
}

.cities .content>p {
    color: #fff
}

.cities .list {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px;
    margin-top: 60px
}

.cities .list .card {
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    background: #fff;
    box-shadow: 4px 10px 20px var(--main-color-40)
}

.cities .list .card>div {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 50px 40px;
    height: 100%;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.cities .list .card>div h3 {
    margin: 0;
    font-size: 1.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.cities .list .card>div p {
    margin: 0;
    min-height: 40px;
    font-size: .85rem
}

.cities .list .card>div .tags {
    display: flex;
    gap: 1rem;
    margin: 0 0 10px
}

.cities .list .card>div .tags>span {
    font-weight: 700;
    font-size: .8rem
}

.cities .list .card>div .tags>span:before {
    content: "•";
    display: inline-flex;
    padding-right: .2rem
}

@media screen and (max-width: 960px) {
    .cities .hero>div>div {
        padding-top: 400px;
        padding-right: 20px
    }
    .cities .hero>div>div h1 {
        font-size: 3rem
    }
    .cities .hero>div>div:after {
        right: 0;
        left: -60px;
        bottom: 350px;
        width: 450px
    }
    .cities .list {
        width: 100%
    }
}

.agency-web-mobile .hero {
    padding: 10px var(--page-side-padding) 0
}

.agency-web-mobile .hero>div {
    border-radius: 20px;
    box-shadow: 0 10px 30px var(--main-color-90)
}

.agency-web-mobile .hero .grid {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    justify-content: space-between;
    padding: 40px var(--home-grid-padding);
    min-height: calc(100vh - 140px);
    border: solid var(--main-color-100) 2px;
    border-radius: 20px;
    background-color: #f8f9ff;
    background: linear-gradient(transparent 63px, var(--main-color-80) 63px), linear-gradient(90deg, white 63px, var(--main-color-80) 63px);
    background-size: 64px 64px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.agency-web-mobile .hero .grid>img {
    max-width: 600px
}

.agency-web-mobile .hero .grid>div {
    display: flex;
    flex-direction: column;
    align-items: flex-end
}

.agency-web-mobile .hero .grid h3 {
    margin: 0;
    padding: 10px;
    font-weight: 200;
    font-size: 1.3rem;
    background-color: #fff
}

.agency-web-mobile .hero .grid h1 {
    margin-top: 40px;
    font-size: 5.2rem;
    line-height: 6rem;
    font-weight: 300;
    text-align: right
}

.agency-web-mobile .hero .grid h1 mark {
    color: var(--main-color-100);
    background: #fff
}

.agency-web-mobile .hero .grid h1 span {
    font-size: 3.2rem
}

.agency-web-mobile .hero .grid .actions {
    display: flex;
    gap: 15px
}

.agency-web-mobile .customers {
    margin-top: 100px;
    padding: 50px 0;
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100);
    background: linear-gradient(-45deg, var(--main-color-80) .5%, #fff .5%, #fff 49.5%, var(--main-color-80) 49.5%, var(--main-color-80) 51%, #fff 51%, #fff 99.5%, var(--main-color-80) 99.5%);
    background-size: 50px 50px;
    background-position: 50px 50px
}

.agency-web-mobile .customers .head {
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 50px var(--page-side-padding) 0
}

.agency-web-mobile .customers .head h2 {
    margin: 50px 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3rem;
    font-weight: 700;
    background: #fff
}

.agency-web-mobile .customers .head p {
    background: #fff
}

.agency-web-mobile .customers .companies {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 30px 0
}

.agency-web-mobile .customers .companies .company {
    display: flex;
    border-radius: 20px;
    box-shadow: 0 4px 10px var(--main-color-80)
}

.agency-web-mobile .customers .companies .company>span {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    width: 150px;
    height: 150px;
    background: #fff;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 0 4px 0 var(--main-color-100)
}

.agency-web-mobile .customers .companies .company img {
    display: block;
    max-width: 100%;
    max-height: 50%
}

.agency-web-mobile .how {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 100px var(--page-side-padding) 150px;
    border-bottom: 1px solid var(--main-color-100);
    background: #fff
}

.agency-web-mobile .how .head {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center
}

.agency-web-mobile .how .head h2 {
    position: relative;
    margin: 30px 0 10px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3.6rem;
    font-weight: 700;
    background: #fff
}

.agency-web-mobile .how .head h2:after {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;
    width: 26px;
    height: 26px;
    background: transparent url(oh.svg) no-repeat center center;
    background-size: cover
}

.agency-web-mobile .how .head h2:before {
    content: "";
    position: absolute;
    top: -40px;
    left: -40px;
    width: 26px;
    height: 26px;
    background: transparent url(oh.svg) no-repeat center center;
    background-size: cover;
    transform: rotate(-40deg)
}

.agency-web-mobile .how .steps {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 80px;
    margin-top: 60px
}

.agency-web-mobile .how .steps .card {
    position: sticky;
    top: 330px;
    padding-bottom: 6px;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-90)
}

.agency-web-mobile .how .steps .card>div {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 60px;
    padding-left: var(--card-padding);
    min-height: 300px;
    background: #fff;
    background-image: url(target.svg);
    background-size: 40px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    overflow: hidden
}

.agency-web-mobile .how .steps .card>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 20px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.agency-web-mobile .how .steps .card>div:before {
    content: "";
    position: absolute;
    bottom: 20px;
    right: 20px;
    width: 24px;
    height: 32px;
    background: transparent url(thunder.svg) no-repeat center center;
    background-size: cover
}

.agency-web-mobile .how .steps .card>div strong {
    position: var(--card-position);
    left: -30px;
    top: 20px;
    display: inline-flex;
    margin-bottom: 20px;
    font-weight: 500;
    font-size: 14rem;
    color: #fff;
    -webkit-text-stroke: 1.5px var(--main-color-100);
    text-shadow: 0 6px 0 var(--main-color-100)
}

.agency-web-mobile .how .steps .card>div h3 {
    margin: 5px 0 0;
    font-size: 2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.agency-web-mobile .how .steps .card>div p {
    background: #fff
}

.agency-web-mobile .how .steps .card>div .app-image {
    margin: 30px 0 10px;
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px dashed var(--main-color-100);
    border-radius: 20px
}

.agency-web-mobile .how .steps .card>div .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.agency-web-mobile .how .steps .card.small>div {
    display: flex;
    align-items: center;
    gap: 10px
}

.agency-web-mobile .how .steps .card.small small {
    margin: -10px 0 10px
}

.agency-web-mobile .how .steps .card.small .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    width: 60px;
    height: 60px;
    font-size: 2.5rem;
    font-weight: 100;
    line-height: 1;
    border: 1px solid var(--main-color-100);
    border-radius: 50%
}

.agency-web-mobile .features {
    padding: 150px var(--page-side-padding) 100px;
    background: linear-gradient(45deg, var(--main-color-80) .5%, #fff .5%, #fff 49.5%, var(--main-color-80) 49.5%, var(--main-color-80) 51%, #fff 51%, #fff 99.5%, var(--main-color-80) 99.5%);
    background-size: 50px 50px;
    background-position: 50px 50px
}

.agency-web-mobile .features>h2 {
    margin: 15px 0 20px;
    font-size: 4rem;
    line-height: 1;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.agency-web-mobile .features>div {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
    margin-top: 100px
}

.agency-web-mobile .features>div>div {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 40px
}

.agency-web-mobile .features>div>div .title {
    display: flex;
    align-items: center;
    padding: 10px 0 15px 10px
}

.agency-web-mobile .features>div>div .title p {
    margin: 0;
    font-size: 1.15rem;
    background: #fff
}

.agency-web-mobile .features>div>div .card {
    position: relative;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-40);
    transition: all ease-in-out .15s
}

.agency-web-mobile .features>div>div .card:nth-child(odd) {
    transform: rotate(2deg)
}

.agency-web-mobile .features>div>div .card>div {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 40px 40px 30px 60px;
    height: 100%;
    background: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.agency-web-mobile .features>div>div .card>div:before {
    content: "";
    position: absolute;
    top: 30px;
    left: -22px;
    height: 230px;
    width: 60px;
    background: transparent;
    background-image: url(book.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-y;
    background-size: 43px 45px, auto
}

.agency-web-mobile .features>div>div .card h3 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0 0 10px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 1.4rem;
    text-wrap: balance;
    background: #fff
}

.agency-web-mobile .features>div>div .card .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.agency-web-mobile .features>div>div .card p {
    margin: 0;
    font-size: .85rem;
    background: #fff
}

.agency-web-mobile .features>div>div .card:hover {
    transform: scale(1.02)
}

.agency-web-mobile .features>div>div .card:hover:nth-child(odd) {
    transform: scale(1.02) rotate(2deg)
}

.agency-web-mobile .features .actions {
    display: flex;
    justify-content: center;
    margin-top: 100px
}

.agency-web-mobile .features .actions .app-button {
    box-shadow: 0 5px 10px var(--main-color-40);
    transform: scale(1.2)
}

.agency-web-mobile .techs {
    padding: 150px var(--page-side-padding) 180px;
    background: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-size: cover
}

.agency-web-mobile .techs>div.grid {
    display: grid;
    grid-template-columns: 34% 64%;
    gap: 20px;
    color: #fff
}

.agency-web-mobile .techs>div.grid .list {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 80px 80px;
    padding-top: 60px;
    padding-right: 80px
}

.agency-web-mobile .techs>div.grid>div:first-child {
    display: block;
    padding-top: 0;
    padding-right: 30px;
    background: var(--main-color-100)
}

.agency-web-mobile .techs>div.grid>div:first-child>small {
    display: inline-block;
    margin: 0 0 20px;
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid white
}

.agency-web-mobile .techs>div.grid>div:first-child>h2 {
    margin: 35px 0 20px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.agency-web-mobile .techs>div.grid .card {
    display: flex;
    flex-direction: column;
    align-items: start
}

.agency-web-mobile .techs>div.grid .card h3 {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 1.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--main-color-100)
}

.agency-web-mobile .techs>div.grid .card h3 img {
    max-height: 50px
}

.agency-web-mobile .techs>div.grid .card p {
    font-size: .9rem;
    background: var(--main-color-100)
}

.agency-web-mobile .techs>div.grid .card .app-button {
    margin-top: 10px;
    transform: scale(.8);
    transform-origin: left center
}

.agency-web-mobile .techs>div.grid .action {
    padding: 40px 0 0
}

.agency-web-mobile .techs>div.grid .action .app-button {
    transform: scale(1)
}

.agency-web-mobile .city {
    padding: 150px var(--page-side-padding) 120px;
    background: var(--main-color-100)
}

.agency-web-mobile .city>h2 {
    margin: 40px 0 80px;
    font-size: 3.2rem;
    line-height: 1;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    color: #fff
}

.agency-web-mobile .city>div {
    position: relative;
    margin: 0 auto;
    padding: 70px 80px 60px;
    max-width: 1080px;
    border-radius: 20px;
    border: 1px dashed var(--main-color-100);
    box-shadow: 0 0 30px var(--main-color-40);
    background-color: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px
}

.agency-web-mobile .city>div:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 60px;
    background: transparent;
    background-image: url(carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 63px 50px, auto
}

.agency-web-mobile .city p {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 1.4rem;
    line-height: 1.5;
    font-weight: 300;
    text-align: justify;
    background: #fff
}

@media screen and (max-width: 960px) {
    .agency-web-mobile .hero .grid>div {
        align-items: start;
        padding: 10px
    }
    .agency-web-mobile .hero .grid>img {
        max-width: 400px
    }
    .agency-web-mobile .hero .grid h3 {
        margin-top: 20px;
        padding: 0;
        font-size: .8rem;
        line-height: 2;
        text-wrap: balance
    }
    .agency-web-mobile .hero .grid h3 strong {
        font-size: 1.2rem
    }
    .agency-web-mobile .hero .grid h1 {
        text-align: left;
        font-size: 2.8rem;
        line-height: 1.2
    }
    .agency-web-mobile .hero .grid .actions {
        width: 100%
    }
    .agency-web-mobile .how .head h2 {
        font-size: 3rem
    }
    .agency-web-mobile .how .steps .card {
        top: 100px
    }
    .agency-web-mobile .work .project {
        width: 100%
    }
    .agency-web-mobile .work .project>div .tags {
        font-size: .5rem
    }
    .agency-web-mobile .work .legend>div {
        width: 100%
    }
    .agency-web-mobile .techs>div.grid {
        grid-template-columns: repeat(1, 1fr)
    }
    .agency-web-mobile .city>div {
        padding-left: 40px;
        padding-right: 40px
    }
}

.technologies .hero {
    position: relative;
    margin: 15px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.technologies .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 100px var(--home-grid-padding) 80px;
    padding-right: 400px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.technologies .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.technologies .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.technologies .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.technologies .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.technologies .content {
    display: flex;
    flex-direction: column;
    align-items: start;
    margin-top: 100px;
    padding: 100px var(--page-side-padding) 140px;
    background-image: url(footer-background.svg)
}

.technologies .content>h2 {
    margin: 40px 0 5px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    color: #fff
}

.technologies .content>p {
    color: #fff
}

.technologies .list {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px;
    margin-top: 60px
}

.technologies .list .card {
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    background: #fff;
    box-shadow: 4px 10px 20px var(--main-color-40)
}

.technologies .list .card>div {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 50px 40px;
    height: 100%;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.technologies .list .card>div h3 {
    margin: 0;
    font-size: 1.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.technologies .list .card>div p {
    margin: 0;
    min-height: 120px;
    font-size: .85rem
}

.technologies .list .card>div .tags {
    display: flex;
    gap: 1rem;
    margin: 0 0 2rem
}

.technologies .list .card>div .tags>span {
    font-weight: 700;
    font-size: .8rem
}

.technologies .list .card>div .tags>span:before {
    content: "•";
    display: inline-flex;
    padding-right: .2rem
}

@media screen and (max-width: 960px) {
    .technologies .hero>div>div {
        padding-top: 200px;
        padding-right: 20px
    }
    .technologies .hero>div>div h1 {
        font-size: 3rem
    }
}

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

.technology .hero {
    position: relative;
    display: flex;
    align-items: center;
    margin-top: -100px;
    min-height: calc(100vh + 20px);
    padding: 0 var(--page-side-padding) 300px;
    background-image: url(target.svg);
    background-size: 40px;
    border-bottom: 1px solid var(--main-color-100);
    overflow: hidden
}

.technology .hero>div {
    position: absolute;
    top: 150px;
    left: 100px;
    z-index: 1
}

.technology .hero .code {
    padding: .5rem 1rem;
    border: 1px solid var(--main-color-100);
    background: #fff
}

.technology .hero h1 {
    margin: 2rem 0;
    padding: .2rem 0;
    max-width: 80%;
    font-size: 5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-40);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.technology .hero p {
    max-width: 450px;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    font-weight: 300
}

.technology .hero .back {
    position: absolute;
    bottom: -80px;
    right: 0;
    font-size: 24rem;
    font-weight: 500;
    color: #fff;
    -webkit-text-stroke: 1px var(--main-color-100);
    z-index: 0
}

.technology .intro {
    background-color: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-size: cover;
    color: #fff
}

.technology .intro>div {
    margin: 150px auto;
    padding: 40px var(--home-grid-padding);
    max-width: 1000px;
    font-size: 1.4rem;
    background: var(--main-color-100);
    border-radius: 20px;
    border: dashed 1px white;
    box-shadow: 0 10px 20px var(--main-color-40)
}

.technology .block {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 20px;
    align-items: center;
    padding: 100px 120px
}

.technology .block h2 {
    margin: 30px 0;
    font-size: 3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70)
}

.technology .block p {
    line-height: 1.5;
    background: var(--white-color-70)
}

.technology .block li {
    line-height: 1.5
}

.technology .block img {
    margin: 50px;
    max-width: 450px
}

@media screen and (max-width: 960px) {
    .technology .hero {
        margin-top: 0;
        padding-top: 60px;
        padding-bottom: 60px
    }
    .technology .hero>div {
        position: relative;
        top: auto;
        left: auto
    }
    .technology .hero h1 {
        font-size: 3rem
    }
    .technology .intro {
        padding: 20px
    }
    .technology .block {
        padding: 50px 20px
    }
}

.expertises .hero {
    position: relative;
    margin: 15px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.expertises .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: var(--flex-direction);
    padding: 100px var(--page-block-padding) 80px;
    padding-right: 620px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(../images/hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.expertises .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(../images/clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.expertises .hero>div>div:after {
    content: "";
    position: absolute;
    top: 10px;
    right: 50px;
    bottom: 10px;
    width: 560px;
    background-image: url(../images/wca-approach.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.expertises .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.expertises .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.expertises .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px;
    text-wrap: balance
}

.expertises .how {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 40px;
    margin: 80px 0 100px;
    padding: 50px var(--page-side-padding);
    background-image: url(..images/target.svg);
    background-size: 40px;
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.expertises .how .head {
    position: relative;
    padding: 100px 10px;
    min-width: 360px
}

.expertises .how .head>div {
    position: sticky;
    top: 180px;
    min-height: 280px
}

.expertises .how .head small {
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid var(--main-color-100);
    background: #fff
}

.expertises .how .head h2 {
    margin: 20px 0;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.expertises .how .head p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.expertises .how .steps {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding: 60px 0 160px
}

.expertises .how .steps .card {
    position: sticky;
    top: 180px;
    padding-bottom: 6px;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-80);
    overflow: hidden
}

.expertises .how .steps .card>div {
    padding: 60px;
    padding-left: var(--card-padding);
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 40px 40px;
    background-position: -1px -1px
}

.expertises .how .steps .card>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 20px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.expertises .how .steps .card>div strong {
    position: var(--card-position);
    left: -60px;
    top: -5px;
    display: inline-flex;
    margin-bottom: 20px;
    font-weight: 500;
    font-size: 15rem;
    color: #fff;
    -webkit-text-stroke: 1.5px var(--main-color-100);
    text-shadow: 0 6px 0 var(--main-color-100)
}

.expertises .how .steps .card>div h3 {
    margin: 0;
    font-size: 2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.expertises .how .steps .card>div p {
    background: #fff
}

.expertises .how .steps .card>div p:last-child {
    font-size: 90%;
    font-weight: 500
}

.expertises .how .steps .card>div .app-image {
    margin: 30px 0 10px;
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px dashed var(--main-color-100);
    border-radius: 20px
}

.expertises .how .steps .card>div .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.expertises .how .steps .card.small>div {
    display: flex;
    align-items: center;
    gap: 10px
}

.expertises .how .steps .card.small small {
    margin: -10px 0 10px
}

.expertises .how .steps .card.small .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    width: 60px;
    height: 60px;
    font-size: 2.5rem;
    font-weight: 100;
    line-height: 1;
    border: 1px solid var(--main-color-100);
    border-radius: 50%
}

.expertises .list {
    margin: 60px var(--page-side-padding) 100px;
    background-image: url(../images/wca-needs.svg);
    background-size: 550px auto;
    background-position: top 0 right 40px;
    background-repeat: no-repeat
}

.expertises .list .head {
    padding: 50px 10px 60px
}

.expertises .list .head>* {
    max-width: 40%
}

.expertises .list .head h2 {
    margin: 20px 0 10px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.expertises .list .head p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.expertises .list .content {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 40px
}

.expertises .list .content>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 40px
}

.expertises .list .content>div .card {
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-70)
}

.expertises .list .content>div .card:first-child {
    transform: rotate(1deg)
}

.expertises .list .content>div .card:last-child {
    transform: rotate(-1deg)
}

.expertises .list .content>div .card>a {
    display: block;
    padding: 60px;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.expertises .list .content>div .card>a h3 {
    margin: 0;
    font-size: 2.2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.expertises .list .content>div .card>a .app-image {
    margin: 30px 0 10px;
    padding: 10px;
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px dashed var(--main-color-100);
    border-radius: 20px
}

.expertises .list .content>div .card>a .action {
    display: flex;
    justify-content: right;
    margin-top: 30px
}

.expertises .list .content>div .card.small>a {
    display: flex;
    align-items: center;
    gap: 10px
}

.expertises .list .content>div .card.small small {
    margin: -10px 0 10px
}

.expertises .list .content>div .card.small .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
    width: 60px;
    height: 60px;
    font-size: 2.5rem;
    font-weight: 100;
    line-height: 1;
    border: 1px solid var(--main-color-100);
    border-radius: 50%
}

@media screen and (max-width: 960px) {
    .expertises .hero>div>div {
        padding: 400px 20px 20px
    }
    .expertises .hero>div>div:after {
        right: 0;
        left: -60px;
        bottom: 300px;
        width: 450px
    }
    .expertises .hero>div>div h1 {
        font-size: 3.2rem
    }
    .expertises .how .steps .card>div strong {
        left: 0
    }
    .expertises .list {
        background-image: none
    }
    .expertises .list .head>* {
        max-width: 100%
    }
    .expertises .list .content>div .card>a {
        padding: 40px 30px
    }
}

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

.expertise .hero {
    position: relative;
    display: flex;
    align-items: center;
    margin-top: -100px;
    min-height: calc(100vh + 20px);
    background-image: url(../images/target.svg);
    background-size: 40px;
    border-bottom: 1px solid var(--main-color-100);
    overflow: hidden
}

.expertise .hero .content {
    position: absolute;
    top: calc(50% - 240px);
    left: 60px;
    padding: 50px 40px;
    max-width: 600px;
    z-index: 1;
    background: var(--white-color-40);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.expertise .hero .picto {
    position: absolute;
    top: calc(50% - 180px);
    right: 100px;
    display: var(--display-desktop);
    width: 540px;
    max-height: 450px;
    object-fit: contain;
    z-index: 2
}

.expertise .hero .code {
    padding: .5rem 1rem;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100);
    background: #fff
}

.expertise .hero h1 {
    margin: 2rem 0;
    padding: .2rem 0;
    font-size: 5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.expertise .hero p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    font-size: 1.4rem;
    font-weight: 400
}

.expertise .hero .back {
    position: absolute;
    bottom: -80px;
    right: -80px;
    font-size: 24rem;
    font-weight: 500;
    color: #fff;
    -webkit-text-stroke: .5px var(--main-color-100);
    z-index: 0
}

.expertise h2.center {
    text-align: center;
    font-size: 3.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    color: inherit;
    text-wrap: balance
}

.expertise .app-tag.center {
    margin: 0 auto
}

.expertise .intro {
    display: flex;
    flex-direction: column;
    margin-bottom: 50px;
    padding: 130px 30px;
    background: var(--main-color-100);
    color: #fff;
    background-image: url(../images/footer-background.svg);
    background-size: cover
}

.expertise .intro>div {
    margin: 60px auto 0;
    padding: var(--page-side-padding);
    max-width: 1000px;
    font-size: 1.4rem;
    border-radius: 20px;
    box-shadow: 12px 14px 0 var(--main-color-40);
    border: solid 1px white;
    background: linear-gradient(135deg, var(--main-color-100), var(--main-color-50))
}

.expertise .intro p {
    line-height: 1.4
}

.expertise .block {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 50px;
    align-items: stretch;
    justify-content: space-between;
    margin: 40px var(--page-side-padding) 50px;
    padding: 0 50px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 4px 8px 0 var(--main-color-100);
    background: var(--white-color-70)
}

.expertise .block .app-tag {
    display: inline-block;
    margin-bottom: 35px
}

.expertise .block h2 {
    background: var(--white-color-70)
}

.expertise .block h3 {
    margin: 0 0 15px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 2rem
}

.expertise .block p {
    margin-bottom: 30px;
    line-height: 1.4;
    font-size: .95rem;
    background: var(--white-color-70)
}

.expertise .block>div:last-child {
    padding: 50px 0 50px 50px;
    border-left: 1px solid var(--main-color-100)
}

.expertise .block .app-mask-image {
    margin: 100px 0 0
}

.expertise .block .app-mask-image img {
    max-width: 400px
}

.expertise .why {
    margin: 100px 0 0;
    padding: 100px 20px 150px;
    background-image: url(../images/footer-background.svg);
    background-size: cover
}

@media screen and (max-width: 960px) {
    .expertise .hero h1 {
        font-size: 3rem
    }
    .expertise .hero .content {
        position: relative;
        top: auto;
        left: auto
    }
    .expertise .block {
        padding: 20px
    }
    .expertise .block>div:last-child {
        padding: 20px;
        border: 0
    }
}

.jobs {
    display: flex;
    flex-direction: column;
    justify-content: center
}

.jobs .block-left {
    margin-top: 10px;
    padding: 0 0 0 var(--page-side-padding);
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.jobs .block-right {
    margin-top: 100px;
    padding: 0 var(--page-side-padding) 0 0;
    border-bottom: 1px solid var(--main-color-100);
    border-top: 1px solid var(--main-color-100)
}

.jobs .intro {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    padding: 20px 0 40px var(--home-grid-padding);
    border-left: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.jobs .intro .app-mask-image {
    display: var(--display-desktop);
    margin: 30px 80px 0
}

.jobs .intro .app-mask-image img {
    max-width: 450px
}

.jobs .intro h1 {
    margin: 40px 0;
    font-size: 5rem;
    line-height: 100%;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.jobs .intro p {
    font-size: 1rem;
    line-height: 140%
}

.jobs .intro .view {
    position: relative
}

.jobs .intro .view .thunder {
    position: absolute;
    top: 40px;
    right: 100px;
    display: var(--display-desktop)
}

.jobs .intro .view .water {
    position: absolute;
    bottom: 50px;
    left: 120px;
    transform: rotate(25deg);
    display: var(--display-desktop)
}

.jobs .what {
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 100px var(--page-side-padding) 150px;
    background: linear-gradient(transparent 33px, var(--main-color-90) 33px), linear-gradient(90deg, white 33px, var(--main-color-90) 33px);
    background-size: 34px 34px;
    border-bottom: 1px solid var(--main-color-100)
}

.jobs .what h2 {
    margin: 20px 0 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    background: #fff
}

.jobs .what>p {
    background: #fff
}

.jobs .what>div {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px;
    margin-top: 60px
}

.jobs .what>div>div {
    position: relative;
    border-radius: 20px;
    box-shadow: 0 5px 20px var(--main-color-70)
}

.jobs .what>div>div:first-child {
    transform: rotate(-2deg)
}

.jobs .what>div>div:last-child {
    transform: rotate(2deg)
}

.jobs .what>div>div>div {
    display: flex;
    flex-direction: column;
    padding: 20px 30px;
    height: 100%;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100)
}

.jobs .what>div>div>div p {
    line-height: 130%
}

.jobs .what>div>div>div img {
    position: absolute;
    top: -10px;
    right: 20px;
    width: 60px;
    transform: rotate(190deg)
}

.jobs .what>div>div>div>span {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 4rem
}

.jobs .missions {
    display: flex;
    flex-direction: column;
    align-items: start;
    padding: 100px var(--page-side-padding)
}

.jobs .missions h2 {
    margin: 20px 0 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    background: #fff
}

.jobs .missions>p {
    background: #fff
}

.jobs .missions>div {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    margin-top: 60px
}

.jobs .missions>div>div {
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 20px 60px var(--main-color-80)
}

.jobs .missions>div>div>div {
    padding: 30px 50px;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-80)
}

.jobs .missions>div>div h3 {
    font-size: 1.35rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.jobs .missions>div>div p {
    font-size: .8rem;
    line-height: 160%
}

.jobs .missions>div>div .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 30px
}

.jobs .missions>div>div .tags>span {
    padding: 5px 10px;
    border: 1px solid var(--main-color-100);
    font-size: .7rem;
    font-weight: 500
}

.jobs .charte {
    padding: 140px var(--page-side-padding) 180px;
    background: var(--main-color-100);
    background-image: url(../images/footer-background.svg)
}

.jobs .charte h2 {
    margin: 0 0 40px;
    font-family: DepartureMono, monospace;
    font-size: 2.7rem;
    font-weight: 400;
    color: #fff;
    text-align: center
}

.jobs .charte>p {
    color: #fff;
    text-align: center
}

.jobs .charte>div {
    margin: 60px auto 0;
    padding: 0 46px;
    max-width: 1050px;
    background: var(--main-color-100);
    border: 1px solid var(--main-color-100);
    box-shadow: 0 20px 60px var(--main-color-40);
    background-image: radial-gradient(8px, transparent 98%, white), linear-gradient(#fff 0, #fff 0);
    background-repeat: round, no-repeat;
    background-position: -48px 0px, 50%;
    background-size: 48px 48px, calc(100% - 80px) 100%
}

.jobs .charte>div>div {
    padding: 40px var(--home-grid-padding) 60px;
    background: #fff;
    border-left: 1px solid var(--main-color-100);
    border-right: 1px solid var(--main-color-100)
}

.jobs .charte>div p {
    line-height: 150%
}

.jobs .charte>div li {
    margin: 20px 0 0;
    line-height: 150%
}

@media screen and (max-width: 960px) {
    .jobs .intro h1 {
        font-size: 3.5rem
    }
}

.projects .hero {
    position: relative;
    margin: 15px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.projects .hero>div>div {
    display: flex;
    align-items: start;
    flex-direction: var(--flex-direction);
    padding: 100px var(--home-grid-padding) 80px;
    padding-right: 600px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(../images/hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.projects .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(../images/clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.projects .hero>div>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 50px;
    bottom: 20px;
    width: 540px;
    background-image: url(../images/wca-projects.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.projects .hero>div>div .code {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: 1rem;
    border: 1px solid var(--main-color-100);
    background: #fff
}

.projects .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.projects .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.projects .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px;
    text-wrap: balance
}

.projects .list {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 40px;
    margin: 80px 0 0;
    padding: 50px var(--page-side-padding);
    background-image: url(../images/target.svg);
    background-size: 40px;
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.projects .list .head {
    position: relative;
    padding: 65px 10px 100px
}

.projects .list .head>div {
    position: sticky;
    top: 120px;
    min-height: 280px
}

.projects .list .head small {
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid var(--main-color-100);
    background: #fff
}

.projects .list .head h2 {
    margin: 20px 0;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.projects .list .head p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.projects .list .works {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 120px;
    padding: 60px 0 160px
}

.projects .list .works .card {
    position: sticky;
    top: 120px;
    padding-bottom: 6px;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-80);
    overflow: hidden
}

.projects .list .works .card>div {
    display: flex;
    flex-direction: var(--flex-direction);
    justify-content: center;
    align-items: center;
    padding: 40px var(--home-grid-padding) 40px;
    min-height: 550px;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.projects .list .works .card>div:after {
    content: "";
    position: absolute;
    top: 20px;
    right: 20px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1px solid var(--main-color-100);
    box-shadow: inset 2px 3px 0 var(--main-color-100)
}

.projects .list .works .card>div .content {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 20px
}

.projects .list .works .card>div .content .oh {
    position: absolute;
    top: -50px;
    left: 0;
    width: 40px;
    transform: rotate(-30deg)
}

.projects .list .works .card>div .view {
    position: relative
}

.projects .list .works .card>div .view .word {
    position: absolute;
    padding: 6px 14px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 0 4px 0 var(--main-color-100);
    background: #fff
}

.projects .list .works .card>div .view .word:nth-child(3) {
    top: 300px;
    right: 20px;
    transform: rotate(-4deg)
}

.projects .list .works .card>div .view .word:nth-child(2) {
    top: 30px;
    left: 70px;
    transform: rotate(4deg)
}

.projects .list .works .card>div .view .thunder {
    position: absolute;
    width: 25px;
    top: 0;
    right: 14px
}

.projects .list .works .card>div .view .water {
    position: absolute;
    bottom: 0;
    left: 65px;
    transform: rotate(25deg)
}

.projects .list .works .card>div h3 {
    margin: 0 0 10px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.projects .list .works .card>div .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.projects .list .works .card>div .tags>span {
    padding: 4px 10px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    font-size: .7rem;
    font-weight: 400
}

.projects .list .works .card>div .app-mask-image {
    transform: translate(20px)
}

.projects .list .works .card>div .app-mask-image img {
    max-width: 400px
}

.projects .testimonials {
    padding: 150px var(--page-side-padding);
    color: #fff;
    background: var(--main-color-100);
    background-image: url(../images/footer-background.svg);
    background-size: cover
}

.projects .testimonials>h2 {
    margin: 30px 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3.3rem;
    font-weight: 700
}

.projects .testimonials>div {
    margin-top: 60px
}

.projects .testimonials>div>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 1rem;
    padding: 3rem 3rem 1.5rem
}

.projects .testimonials>div>div p {
    padding: 0 20% 0 0;
    font-size: 1.9rem;
    line-height: 3rem;
    font-weight: 300;
    background: var(--main-color-100)
}

.projects .testimonials>div>div p strong {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 3.3rem;
    line-height: 3rem;
    font-weight: 700
}

.projects .testimonials>div>div .label {
    position: relative;
    display: flex;
    gap: 1rem;
    font-size: 1rem;
    background: var(--main-color-100)
}

.projects .testimonials>div>div .label img {
    width: 50px;
    height: 50px;
    object-fit: cover;
    border-radius: 50%
}

.projects .testimonials>div>div .label>span {
    display: flex;
    flex-direction: column;
    gap: .2rem
}

.projects .testimonials>div>div .label>span span {
    font-family: AmpleSoft, Arial, Helvetica, sans-serif
}

.projects .testimonials>div>div:nth-child(odd) {
    align-items: end
}

.projects .testimonials>div>div:nth-child(odd) p {
    padding: 0 0 0 20%;
    text-align: right
}

.projects .testimonials>div>div:nth-child(odd) .label {
    flex-direction: row-reverse
}

.projects .testimonials>div>div:nth-child(odd) .label>span {
    align-items: flex-end
}

@media screen and (max-width: 960px) {
    .projects .hero>div>div {
        padding: 400px 20px 20px
    }
    .projects .hero>div>div:after {
        right: 0;
        left: -60px;
        bottom: 480px;
        width: 450px
    }
    .projects .list .head {
        padding-bottom: 20px
    }
    .projects .list .head>div {
        min-height: 0px
    }
    .projects .list .works .card>div {
        padding: 60px 30px
    }
    .projects .list .works .card>div .app-mask-image {
        margin-top: 50px;
        transform: translate(0)
    }
    .projects .list .works .card>div .app-mask-image img {
        max-width: 300px
    }
}

.project {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 10px 0
}

.project .hero {
    padding: 0 80px 0 0;
    border-bottom: 1px solid var(--main-color-100)
}

.project .intro {
    display: flex;
    align-items: center;
    padding: 30px 0 100px 20px
}

.project .intro .content {
    display: flex;
    flex-direction: column;
    gap: 10px
}

.project .intro .app-video {
    margin: 30px 60px 0;
    border-radius: 20px;
    border: solid 2px var(--main-color-100);
    box-shadow: 0 10px 30px var(--main-color-70)
}

.project .intro .app-video>video {
    min-width: 48vw;
    border-radius: 20px;
    box-shadow: 0 10px 0 var(--main-color-100)
}

.project .intro .code {
    padding: .2rem .5rem;
    font-family: Roboto Mono, monospace;
    font-size: .7rem;
    border: 1px solid var(--main-color-100)
}

.project .intro .code~.code {
    margin-left: 10px
}

.project .intro h1 {
    margin: 1rem 0;
    font-size: 3.2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.project .intro h2 {
    text-transform: uppercase;
    font-weight: 300
}

.project .intro p {
    font-size: 1rem
}

.project .intro .description {
    background: #fff
}

.project .intro .app-image {
    margin: 40px 100px 0 50px;
    max-width: 600px
}

.project .intro .app-mask-image {
    margin: 0 30px 0 0
}

.project .intro .app-mask-image img {
    max-width: 730px
}

.project .review {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    padding: 80px 80px 40px;
    background: #fff
}

.project .review.dark {
    padding-bottom: 100px;
    background: var(--main-color-100);
    color: #fff
}

.project .review.dark>div:last-child {
    box-shadow: 4px 15px 20px var(--main-color-40)
}

.project .review.reverse {
    flex-direction: row-reverse
}

.project .review.reverse>div:first-child {
    align-items: flex-end
}

.project .review.reverse>div:first-child h2 {
    text-align: right
}

.project .review.reverse>div:first-child .illu {
    transform: scaleX(-1)
}

.project .review>div:first-child {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.project .review>div:first-child h2 {
    margin: 30px 0 10px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3.6rem
}

.project .review>div:first-child .illu {
    margin-top: 30px;
    max-width: 160px;
    max-height: 180px
}

.project .review>div:last-child {
    position: relative;
    margin-top: 60px;
    background: #fff;
    color: var(--main-color-100);
    border-radius: 20px;
    box-shadow: 4px 15px 20px var(--main-color-80)
}

.project .review>div:last-child:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 60px;
    background: transparent;
    background-image: url(../images/carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 52px 48px, auto
}

.project .review .app-richtext {
    padding: 70px 60px 50px;
    height: 100%;
    width: 800px;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 0 6px 0 var(--main-color-100)
}

.project .review .app-richtext p,
.project .review .app-richtext li,
.project .review .app-richtext ul {
    font-size: 1.1rem
}

.project .screens {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-top: 100px;
    padding: 120px 100px 150px;
    border-top: solid 1px var(--main-color-100);
    border-bottom: solid 1px var(--main-color-100);
    background-color: #f8f9ff;
    background: linear-gradient(transparent 33px, var(--main-color-90) 33px), linear-gradient(90deg, white 33px, var(--main-color-90) 33px);
    background-size: 34px 34px
}

.project .screens>div {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 60px;
    justify-content: space-around;
    margin-top: 40px
}

.project .screens h2 {
    margin: 20px 0 0;
    display: inline-flex;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3.6rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.project .screens>p {
    background: var(--white-color-70)
}

.project .screens .image {
    border-radius: 20px;
    box-shadow: 4px 12px 20px var(--main-color-70)
}

.project .screens .image>div {
    height: 100%;
    border-radius: 20px;
    border: solid 2px var(--main-color-100);
    box-shadow: 0 6px 0 var(--main-color-100)
}

.project .screens .app-image {
    display: block;
    width: 100%;
    min-height: 100%;
    object-fit: cover;
    border-radius: 18px
}

@media screen and (max-width: 960px) {
    .project .hero {
        padding: 0
    }
    .project .intro {
        flex-direction: column-reverse;
        padding: 0 20px 20px
    }
    .project .intro h1 {
        margin: 30px 0;
        font-size: 2.5rem
    }
    .project .intro h2 {
        padding-left: 10px;
        font-size: 1.1rem;
        border-left: 4px solid var(--main-color-100)
    }
    .project .intro .app-video {
        margin: 40px 0
    }
    .project .intro .app-video video {
        width: 100%
    }
    .project .review {
        flex-direction: column;
        padding: 80px 20px
    }
    .project .review.reverse {
        flex-direction: column
    }
    .project .review .app-richtext {
        width: auto
    }
    .project .review h2 {
        font-size: 2.6rem !important
    }
    .project .screens {
        padding: 20px
    }
}

.sectors .hero {
    position: relative;
    margin: 15px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.sectors .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 100px var(--home-grid-padding) 80px;
    padding-right: 400px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(../images/hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.sectors .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(../images/clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.sectors .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.sectors .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.sectors .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.sectors .content {
    display: flex;
    flex-direction: column;
    align-items: start;
    margin-top: 100px;
    padding: 100px var(--page-side-padding) 140px;
    background-image: url(../images/footer-background.svg)
}

.sectors .content>h2 {
    margin: 40px 0 5px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem;
    color: #fff
}

.sectors .content>p {
    color: #fff
}

.sectors .list {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px;
    margin-top: 60px
}

.sectors .list .card {
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    background: #fff;
    box-shadow: 4px 10px 20px var(--main-color-40)
}

.sectors .list .card>div {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 50px 40px;
    height: 100%;
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.sectors .list .card>div h3 {
    margin: 0;
    font-size: 1.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.sectors .list .card>div p {
    margin: 0;
    min-height: 40px;
    font-size: .85rem
}

.sectors .list .card>div .tags {
    display: flex;
    gap: 1rem;
    margin: 0 0 10px
}

.sectors .list .card>div .tags>span {
    font-weight: 700;
    font-size: .8rem
}

.sectors .list .card>div .tags>span:before {
    content: "•";
    display: inline-flex;
    padding-right: .2rem
}

@media screen and (max-width: 960px) {
    .sectors .hero>div>div {
        padding-right: 20px
    }
    .sectors .hero>div>div h1 {
        font-size: 3rem;
        background: #fff
    }
}

.sector {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 10px 0
}

.sector .block-left {
    padding: 0 0 0 var(--page-side-padding);
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.sector .block-right {
    margin-top: 100px;
    padding: 0 var(--page-side-padding) 0 0;
    border-bottom: 1px solid var(--main-color-100);
    border-top: 1px solid var(--main-color-100)
}

.sector .intro {
    display: flex;
    padding: 60px 0 60px var(--page-side-padding);
    border-left: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.sector .intro .app-mask-image {
    display: var(--display-desktop);
    margin: 30px 80px 0
}

.sector .intro .app-mask-image img {
    max-width: 500px
}

.sector .intro h1 {
    margin: 1rem 0;
    font-size: 4.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.sector .intro h1 span {
    position: relative
}

.sector .intro h1 span:after {
    content: "";
    position: absolute;
    top: 50%;
    left: calc(100% + 330px);
    width: 200px;
    height: 34px;
    background: transparent url(../images/dotted-line.svg);
    background-size: cover;
    z-index: 10
}

.sector .intro p {
    font-size: 1rem;
    line-height: 140%
}

.sector .intro .view {
    position: relative
}

.sector .intro .view .thunder {
    position: absolute;
    top: 40px;
    right: 100px;
    display: var(--display-desktop)
}

.sector .intro .view .water {
    position: absolute;
    bottom: 50px;
    left: 120px;
    transform: rotate(25deg);
    display: var(--display-desktop)
}

.sector .tools {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    padding: 120px var(--page-side-padding) 120px 0;
    border-right: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.sector .tools h2 {
    font-size: 3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.sector .tools p {
    margin-top: 30px;
    line-height: 140%
}

.sector .tools .app-mask-image {
    margin: 0 100px 0 160px
}

.sector .tools .app-mask-image img {
    max-width: 310px
}

@media screen and (max-width: 960px) {
    .sector .tools {
        align-items: flex-start;
        gap: 40px;
        padding-left: 20px
    }
    .sector .tools .app-mask-image {
        margin: 0
    }
    .sector .tools .app-mask-image img {
        max-width: 260px
    }
}

.services .hero {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    gap: 30px;
    padding: 30px var(--page-side-padding) 20px
}

.services .hero .title {
    position: relative;
    min-width: 55vw;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.services .hero .title .thunder {
    position: absolute;
    bottom: -20px;
    right: 120px;
    width: 20px;
    transform: rotate(120deg)
}

.services .hero .content {
    display: flex;
    flex-direction: column;
    gap: 30px;
    padding-top: 20px
}

.services .hero h1 {
    margin: 0;
    padding: 20px 0;
    font-size: 6rem;
    line-height: 1;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.services .hero .actions {
    display: flex;
    flex-direction: var(--flex-direction);
    gap: 20px
}

.services .list {
    margin: 50px 0;
    padding: 100px var(--page-side-padding);
    border-top: solid 1px var(--main-color-100);
    border-bottom: solid 1px var(--main-color-100);
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px
}

.services .list .actions {
    display: flex;
    flex-direction: var(--flex-direction);
    justify-content: center;
    gap: 20px;
    padding: 100px 0 0
}

.services .list .content {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 40px
}

.services .list .content>a:nth-child(3n) {
    transform: rotate(3deg)
}

.services .list .content>a:nth-child(6n+1) {
    transform: rotate(-3deg)
}

.services .list .content .card {
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-70)
}

.services .list .content .card>div {
    padding: 40px;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.services .list .content .card>div .tags {
    display: flex;
    gap: 10px
}

.services .list .content .card>div .app-tag {
    padding: 5px 10px;
    font-size: .55rem;
    box-shadow: none;
    text-transform: uppercase;
    border-width: 1px;
    font-weight: 600
}

.services .list .content .card>div h3 {
    margin: 20px 0 0;
    font-size: 1.65rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.services .list .content .card>div p {
    font-size: .8rem
}

.services .list .content .card>div .app-button {
    margin-top: 10px
}

.services .solution {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 100px var(--page-side-padding);
    background-image: url(../images/wca-experts.svg);
    background-position: calc(100% - 40px) 0px;
    background-repeat: no-repeat;
    background-size: 340px 340px
}

.services .solution>small {
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.services .solution>h2 {
    margin: 20px 0 10px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.services .solution>p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.services .solution>div {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 40px;
    margin-top: 50px
}

.services .solution>div>div {
    display: flex;
    flex-direction: column;
    gap: 40px
}

.services .solution>div>div .card {
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-70)
}

.services .solution>div>div .card.dark>div {
    background: linear-gradient(45deg, var(--main-color-100), var(--main-color-40));
    color: #fff
}

.services .solution>div>div .card>div {
    position: relative;
    padding: 40px;
    background: linear-gradient(45deg, white 70%, var(--main-color-95));
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    overflow: hidden
}

.services .solution>div>div .card>div>img {
    position: absolute;
    right: 0;
    bottom: -40px;
    max-width: 80%;
    border: 1px solid var(--main-color-70);
    border-radius: 5px 0 0
}

.services .solution>div>div .card>div h3 {
    margin: 0;
    font-size: 2.2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.services .solution>div>div .card>div p {
    margin: 10px 0 240px;
    font-size: 1rem
}

.services .platform {
    display: grid;
    grid-template-columns: calc(36% + -0px) calc(32% - 30px) calc(32% - 30px);
    gap: 30px;
    padding: 150px var(--page-side-padding);
    color: #fff;
    background: var(--main-color-100);
    background-image: radial-gradient(white .5px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px
}

.services .platform>div {
    display: flex;
    flex-direction: column;
    gap: 30px;
    padding-top: 40px
}

.services .platform>div:first-child {
    display: block;
    padding-top: 0;
    padding-right: 30px
}

.services .platform>div:first-child>small {
    display: inline-block;
    margin: 0 0 20px;
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid white
}

.services .platform>div:first-child>h2 {
    margin: 25px 0 10px;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--main-color-100);
    text-wrap: balance
}

.services .platform>div:first-child p {
    background: var(--main-color-100);
    text-wrap: balance
}

.services .platform .card h3 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
    background: var(--main-color-100)
}

.services .platform .card h3 img {
    max-height: 80px
}

.services .platform .card p {
    background: var(--main-color-100)
}

@media screen and (max-width: 960px) {
    .services .hero h1 {
        font-size: 4rem
    }
    .services .solution>h2 {
        font-size: 3rem
    }
    .services .solution>div>div .card>div p {
        margin-bottom: 140px
    }
    .services .platform {
        grid-template-columns: repeat(1, 1fr)
    }
}

.service {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 10px 0
}

.service .block-left {
    padding: 0 0 0 var(--page-side-padding);
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.service .block-right {
    padding: 0 var(--page-side-padding) 0 0;
    border-bottom: 1px solid var(--main-color-100)
}

.service .intro {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    padding: 40px 0 40px var(--page-side-padding);
    border-left: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .intro .view {
    position: relative
}

.service .intro .view .word {
    position: absolute;
    padding: 6px 14px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 20px;
    border: 1px solid var(--main-color-100);
    box-shadow: 0 4px 0 var(--main-color-100);
    background: #fff
}

.service .intro .view .word:nth-child(3) {
    top: 390px;
    right: 130px;
    transform: rotate(-4deg)
}

.service .intro .view .word:nth-child(2) {
    top: 60px;
    left: 130px;
    transform: rotate(4deg)
}

.service .intro .view .thunder {
    position: absolute;
    top: 40px;
    right: 100px;
    display: var(--display-desktop)
}

.service .intro .view .water {
    position: absolute;
    bottom: 50px;
    left: 120px;
    transform: rotate(25deg);
    display: var(--display-desktop)
}

.service .intro .app-mask-image {
    display: var(--display-desktop);
    margin: 20px 80px 0
}

.service .intro .app-mask-image img {
    max-width: 500px
}

.service .intro .code {
    position: relative;
    padding: 6px 14px;
    font-family: Roboto Mono, monospace;
    font-size: 1rem;
    font-weight: 600;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100)
}

.service .intro .code .oh {
    position: absolute;
    top: -60px;
    right: -40px
}

.service .intro h1 {
    margin: 1.5rem 0 .5rem;
    font-size: 5.5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.service .intro .description {
    font-size: 1.2rem;
    line-height: 1.5
}

.service .intro .rate {
    display: flex;
    gap: 10px;
    margin-top: 40px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: .7rem
}

.service .intro .rate strong {
    font-size: 110%
}

.service .intro .app-image {
    margin: 20px 100px 0 50px;
    max-width: 540px
}

.service .tools {
    display: flex;
    align-items: center;
    padding: 120px var(--page-side-padding) 120px 0;
    border-right: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .tools h2 {
    margin: 10px 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 300;
    font-size: 2.8rem
}

.service .tools img {
    margin: 40px 80px 0 120px;
    max-width: 420px
}

.service .tools .examples>div {
    position: relative;
    padding: 80px 60px;
    font-size: 1.4rem;
    border: dashed 1px var(--main-color-100);
    border-top: solid 1px var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 10px 40px var(--main-color-90)
}

.service .tools .examples>div:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 50px;
    background: transparent;
    background-image: url(../images/carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 55px 50px, auto
}

.service .context {
    display: flex;
    flex-direction: column;
    padding: 0 var(--page-side-padding);
    gap: 40px;
    border-bottom: solid 1px var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px
}

.service .context img {
    margin: 0 0 30px;
    max-height: 140px
}

.service .context h2 {
    margin: 0 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 300;
    font-size: 2.8rem
}

.service .context>div {
    flex: 1;
    margin: 110px auto;
    padding: 60px;
    font-size: 1.4rem;
    border: dashed 1px var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 20px 60px var(--main-color-80);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .solution {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 80px var(--page-side-padding) 150px;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px
}

.service .solution>small {
    padding: 6px 10px;
    text-transform: uppercase;
    border: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .solution>h2 {
    margin: 10px 0;
    font-size: 3.6rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .solution>p {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.service .solution>div {
    display: grid;
    grid-template-columns: var(--grid-template-2-blocks);
    gap: 40px;
    margin-top: 50px
}

.service .solution>div>div {
    display: flex;
    flex-direction: column;
    gap: 40px
}

.service .solution>div>div .card {
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-70)
}

.service .solution>div>div .card.dark>div {
    background: linear-gradient(45deg, var(--main-color-100), var(--main-color-40));
    color: #fff;
    box-shadow: 0 6px 0 var(--main-color-50)
}

.service .solution>div>div .card>div {
    position: relative;
    padding: 40px;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    overflow: hidden
}

.service .solution>div>div .card>div>img {
    position: absolute;
    right: 0;
    bottom: -30px;
    max-width: 80%;
    border: 1px solid var(--main-color-70);
    border-radius: 5px 0 0
}

.service .solution>div>div .card>div h3 {
    margin: 0;
    font-size: 2.2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.service .solution>div>div .card>div p {
    margin: 10px 0 45%;
    font-size: 1rem
}

.service .features {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
    padding: 150px var(--page-side-padding);
    background: linear-gradient(45deg, var(--main-color-100), var(--main-color-45));
    background-image: url(../images/footer-background.svg)
}

.service .features>div {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 40px
}

.service .features>div .title {
    padding: 40px;
    color: #fff
}

.service .features>div .title h2 {
    margin: 0;
    font-size: 3.2rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.service .features>div .title p {
    margin: 0
}

.service .features>div .card {
    position: relative;
    border-radius: 20px;
    box-shadow: 0 10px 20px var(--main-color-40)
}

.service .features>div .card>div {
    padding: 40px;
    height: 100%;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 6px 0 var(--main-color-100);
    overflow: hidden
}

.service .features>div .card h3 {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0 0 10px;
    font-size: 1.2rem
}

.service .features>div .card h3 img {
    margin-top: 5px
}

.service .features>div .card p {
    margin: 0;
    font-size: .85rem
}

@media screen and (max-width: 960px) {
    .service .intro h1 {
        font-size: 3rem
    }
    .service .solution>h2 {
        font-size: 3rem
    }
    .service .solution>div>div .card>div>img {
        position: relative;
        width: 100%;
        max-width: 100%;
        border-radius: 20px;
        margin-bottom: 20px
    }
    .service .solution>div>div .card>div p {
        margin-bottom: 20px
    }
}

.studio {
    display: flex;
    flex-direction: column;
    justify-content: center
}

.studio .block-left {
    margin-top: 10px;
    padding: 0 0 0 var(--page-side-padding);
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.studio .block-right {
    margin-top: 100px;
    padding: 0 var(--page-side-padding) 0 0;
    border-bottom: 1px solid var(--main-color-100);
    border-top: 1px solid var(--main-color-100)
}

.studio .intro {
    display: flex;
    align-items: center;
    padding: 30px 0 40px var(--home-grid-padding);
    border-left: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.studio .intro .app-mask-image {
    display: var(--display-desktop);
    margin: 30px 80px 0
}

.studio .intro .app-mask-image img {
    max-width: 450px
}

.studio .intro h1 {
    position: relative;
    margin: 40px 0;
    font-size: 5rem;
    line-height: 100%;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.studio .intro h1:before {
    content: "";
    position: absolute;
    top: -25px;
    left: 0;
    right: 0;
    display: var(--display-desktop);
    height: 50px;
    background: transparent;
    background-image: url(../images/oh.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 55px 50px, auto;
    transform: rotate(15deg)
}

.studio .intro p {
    font-size: 1rem;
    line-height: 140%
}

.studio .intro .view {
    position: relative
}

.studio .intro .view .thunder {
    position: absolute;
    top: 40px;
    right: 100px;
    display: var(--display-desktop)
}

.studio .intro .view .water {
    position: absolute;
    bottom: 50px;
    left: 120px;
    transform: rotate(25deg);
    display: var(--display-desktop)
}

.studio .numbers {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    gap: 20px;
    padding: 80px var(--page-side-padding) 140px;
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px;
    border-bottom: 1px solid var(--main-color-100)
}

.studio .numbers .code {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: .9rem;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100)
}

.studio .numbers>h2 {
    margin: 0;
    font-size: 3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.studio .numbers p {
    margin: 0;
    background: #fff
}

.studio .numbers>div {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 60px;
    margin-top: 60px;
    padding: 0 20px;
    width: 100%
}

.studio .numbers>div>div {
    position: relative;
    display: flex;
    box-shadow: 0 5px 20px var(--main-color-70);
    border-radius: 20px
}

.studio .numbers>div>div>div {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex: 1;
    gap: 5px;
    padding: 30px;
    min-height: 140px;
    font-size: 1.1rem;
    font-weight: 400;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100);
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem
}

.studio .numbers>div>div:first-child {
    transform: rotate(-2deg) translate(-10px, -10px)
}

.studio .numbers>div>div img {
    max-width: 120px
}

.studio .numbers>div>div img.theme {
    position: absolute;
    top: -10px;
    right: 20px;
    width: 60px;
    transform: rotate(190deg)
}

.studio .numbers>div>div img.theme.scotch {
    width: 70px;
    top: -30px;
    right: -15px;
    transform: rotate(-40deg)
}

.studio .numbers>div>div small {
    font-family: Roboto Mono, monospace;
    font-weight: 400;
    font-size: 1rem
}

.studio .team {
    min-height: 100vh;
    padding: 100px var(--page-side-padding) 150px;
    color: #fff;
    background-image: url(../images/vision0.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-bottom: 1px solid var(--main-color-100)
}

.studio .team .code {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: .9rem;
    color: #fff;
    border: 1px solid white;
    border-radius: 20px;
    box-shadow: 0 4px #fff
}

.studio .team h2 {
    margin: 24px 0 20px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 600;
    font-size: 4rem;
    color: #fff
}

.studio .team>div {
    display: flex;
    align-items: center;
    justify-content: right;
    margin-top: 60px
}

.studio .team>div .card {
    max-width: 850px;
    background: #fff;
    color: var(--main-color-100);
    border: 1px solid var(--main-color-100);
    border-radius: 10px 10px 20px 20px;
    box-shadow: 8px 12px 20px var(--main-color-70)
}

.studio .team>div .card>div {
    position: relative;
    border-radius: 10px 10px 20px 20px;
    box-shadow: 0 8px 0 var(--main-color-100)
}

.studio .team>div .card>div:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 60px;
    background: transparent;
    background-image: url(../images/carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 63px 50px, auto
}

.studio .team>div .card .content {
    padding: 80px 50px 40px
}

.studio .team>div .card .content .grid {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 20px
}

.studio .team>div .card .content .grid>span {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: flex-start;
    align-items: center;
    padding: 20px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    text-wrap: balance
}

.studio .team>div .card .content .grid>span img {
    max-height: 140px
}

.studio .team>div .card .content .grid>span strong {
    font-size: 3rem
}

.studio .rse {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    gap: 100px;
    min-height: 100vh;
    padding: 100px var(--page-side-padding) 160px;
    border-bottom: 1px solid var(--main-color-100);
    background-image: url(../images/back-earth.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover
}

.studio .rse>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 20px
}

.studio .rse>div>h2 {
    margin: 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 4rem;
    background: #fff
}

.studio .rse>div>p {
    max-width: 620px;
    background: #fff
}

.studio .rse>div .grid {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 30px;
    margin-top: 40px;
    max-width: 800px
}

.studio .rse>div .grid>div {
    position: relative;
    display: flex;
    border-radius: 20px;
    box-shadow: 0 5px 20px var(--main-color-80)
}

.studio .rse>div .grid>div>span {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 30px;
    font-size: .85rem;
    font-weight: 400;
    text-align: center;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100);
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px
}

.studio .rse>div .grid>div>span img {
    max-width: 120px
}

.studio .rse>div .grid>div>span span {
    background: #fff
}

.studio .impact {
    padding: 140px var(--page-side-padding) 180px;
    background: var(--main-color-100);
    background-image: url(../images/footer-background.svg);
    background-size: cover
}

.studio .impact h2 {
    margin: 40px 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 600;
    font-size: 3.4rem;
    color: #fff
}

.studio .impact p {
    color: #fff
}

.studio .impact>div {
    margin: 80px auto 0;
    padding: 0 46px;
    background: var(--main-color-100);
    border: 1px solid var(--main-color-100);
    box-shadow: 0 20px 60px var(--main-color-40);
    background-image: radial-gradient(8px, transparent 98%, white), linear-gradient(#fff 0, #fff 0);
    background-repeat: round, no-repeat;
    background-position: -48px 0px, 50%;
    background-size: 48px 48px, calc(100% - 80px) 100%
}

.studio .impact>div>div {
    padding: 60px var(--home-grid-padding) 80px;
    background: #fff;
    border-left: 1px solid var(--main-color-100);
    border-right: 1px solid var(--main-color-100)
}

.studio .impact>div li {
    margin: 20px 0 0
}

.studio .contacts {
    position: relative;
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    gap: 100px;
    min-height: 100vh;
    padding: 140px var(--page-side-padding) 300px;
    border-bottom: 1px solid var(--main-color-100);
    background-image: url(../images/hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: 75%;
    background-color: #fff
}

.studio .contacts:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 500px;
    background-image: url(../images/nantes-reverse.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: 100% auto;
    z-index: 0;
    transition: all ease-in 3s
}

.studio .contacts:hover:before {
    opacity: .7
}

.studio .contacts>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 20px
}

.studio .contacts>div>h2 {
    margin: 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 4rem
}

.studio .contacts>div>p {
    max-width: 620px
}

.studio .contacts>div .grid {
    display: grid;
    grid-template-columns: var(--grid-template-5-blocks);
    gap: 30px;
    margin-top: 20px;
    width: 100%
}

.studio .contacts>div .grid>div {
    position: relative;
    display: flex;
    flex: 1;
    border-radius: 20px;
    box-shadow: 0 5px 20px var(--main-color-80);
    transition: all ease-in-out .2s
}

.studio .contacts>div .grid>div:hover {
    transform: scale(1.03)
}

.studio .contacts>div .grid>div>span {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    gap: 20px;
    padding: 30px 25px;
    background-color: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100)
}

.studio .contacts>div .grid>div>span .avatar {
    max-width: 180px;
    border-radius: 50%;
    border: 5px solid white
}

.studio .contacts>div .grid>div>span span {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: .9rem;
    background-color: #fff
}

.studio .contacts>div .grid>div>span span strong {
    font-size: 90%
}

@media screen and (max-width: 960px) {
    .studio .rse>div {
        width: 100%
    }
    .studio .rse>div>h2 {
        font-size: 3rem;
        background: #fff
    }
    .studio .rse>div>p {
        background: #fff
    }
}

.contact {
    display: flex;
    flex-direction: column;
    justify-content: center
}

.contact .block-left {
    margin-top: 10px;
    padding: 0 0 0 var(--page-side-padding);
    border-top: 1px solid var(--main-color-100);
    border-bottom: 1px solid var(--main-color-100)
}

.contact .block-right {
    margin-top: 100px;
    padding: 0 var(--page-side-padding) 0 0;
    border-bottom: 1px solid var(--main-color-100);
    border-top: 1px solid var(--main-color-100)
}

.contact .intro {
    display: flex;
    align-items: center;
    padding: 30px 0 40px var(--home-grid-padding);
    border-left: 1px solid var(--main-color-100);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.contact .intro .app-mask-image {
    display: var(--display-desktop);
    margin: 30px 80px 0
}

.contact .intro .app-mask-image img {
    max-width: 450px
}

.contact .intro h1 {
    position: relative;
    margin: 40px 0;
    font-size: 5rem;
    line-height: 100%;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.contact .intro h1:before {
    content: "";
    position: absolute;
    top: -25px;
    left: 350px;
    right: 0;
    display: var(--display-desktop);
    height: 50px;
    background: transparent;
    background-image: url(oh.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 55px 50px, auto;
    transform: rotate(15deg)
}

.contact .intro p {
    font-size: 1rem;
    line-height: 140%
}

.contact .intro p strong {
    font-weight: 700
}

.contact .intro .view {
    position: relative
}

.contact .intro .view .thunder {
    position: absolute;
    top: 40px;
    right: 100px;
    display: var(--display-desktop)
}

.contact .intro .view .water {
    position: absolute;
    bottom: 50px;
    left: 120px;
    transform: rotate(25deg);
    display: var(--display-desktop)
}

.contact .numbers {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    gap: 20px;
    padding: 80px var(--page-side-padding) 140px;
    background: linear-gradient(transparent 33px, var(--main-color-80) 33px), linear-gradient(90deg, white 33px, var(--main-color-80) 33px);
    background-size: 34px 34px;
    border-bottom: 1px solid var(--main-color-100)
}

.contact .numbers .code {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: .9rem;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 4px 0 var(--main-color-100)
}

.contact .numbers>h2 {
    margin: 0;
    font-size: 3rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    background: #fff
}

.contact .numbers p {
    margin: 0;
    background: #fff
}

.contact .numbers>div {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 60px;
    margin-top: 60px;
    padding: 0 20px;
    width: 100%
}

.contact .numbers>div>div {
    position: relative;
    display: flex;
    box-shadow: 0 5px 20px var(--main-color-70);
    border-radius: 20px
}

.contact .numbers>div>div>div {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex: 1;
    gap: 5px;
    padding: 30px;
    min-height: 140px;
    font-size: 1.1rem;
    font-weight: 400;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100);
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 3rem
}

.contact .numbers>div>div:first-child {
    transform: rotate(-2deg) translate(-10px, -10px)
}

.contact .numbers>div>div img {
    max-width: 120px
}

.contact .numbers>div>div img.theme {
    position: absolute;
    top: -10px;
    right: 20px;
    width: 60px;
    transform: rotate(190deg)
}

.contact .numbers>div>div img.theme.scotch {
    width: 70px;
    top: -30px;
    right: -15px;
    transform: rotate(-40deg)
}

.contact .numbers>div>div small {
    font-family: Roboto Mono, monospace;
    font-weight: 400;
    font-size: 1rem
}

.contact .team {
    min-height: 100vh;
    padding: 100px var(--page-side-padding) 150px;
    color: #fff;
    background-image: url(vision0.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-bottom: 1px solid var(--main-color-100)
}

.contact .team .code {
    padding: .4rem 1rem;
    font-family: Roboto Mono, monospace;
    font-size: .9rem;
    color: #fff;
    border: 1px solid white;
    border-radius: 20px;
    box-shadow: 0 4px #fff
}

.contact .team h2 {
    margin: 24px 0 20px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 600;
    font-size: 4rem;
    color: #fff
}

.contact .team>div {
    display: flex;
    align-items: center;
    justify-content: right;
    margin-top: 60px
}

.contact .team>div .card {
    max-width: 850px;
    background: #fff;
    color: var(--main-color-100);
    border: 1px solid var(--main-color-100);
    border-radius: 10px 10px 20px 20px;
    box-shadow: 8px 12px 20px var(--main-color-70)
}

.contact .team>div .card>div {
    position: relative;
    border-radius: 10px 10px 20px 20px;
    box-shadow: 0 8px 0 var(--main-color-100)
}

.contact .team>div .card>div:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 60px;
    background: transparent;
    background-image: url(carnet.svg), linear-gradient(transparent 0 0);
    background-position: top center;
    background-repeat: repeat-x;
    background-size: 63px 50px, auto
}

.contact .team>div .card .content {
    padding: 80px 50px 40px;
    min-width: 60vw
}

.contact .team>div .card .content ul {
    display: flex;
    flex-direction: column;
    gap: 10px
}

.contact .team>div .card .content ul li {
    padding: 10px 0
}

.contact .team>div .card .content strong {
    font-weight: 700
}

.contact .team>div .card .content .grid {
    display: grid;
    grid-template-columns: var(--grid-template-4-blocks);
    gap: 20px
}

.contact .team>div .card .content .grid>span {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: flex-start;
    align-items: center;
    padding: 20px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    text-wrap: balance
}

.contact .team>div .card .content .grid>span img {
    max-height: 140px
}

.contact .team>div .card .content .grid>span strong {
    font-size: 3rem
}

.contact .rse {
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    gap: 100px;
    min-height: 100vh;
    padding: 100px var(--page-side-padding) 160px;
    border-bottom: 1px solid var(--main-color-100);
    background-image: url(back-earth.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover
}

.contact .rse>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 20px
}

.contact .rse>div>h2 {
    margin: 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 4rem;
    background: #fff
}

.contact .rse>div>p {
    max-width: 620px;
    background: #fff
}

.contact .rse>div .grid {
    display: grid;
    grid-template-columns: var(--grid-template-3-blocks);
    gap: 30px;
    margin-top: 40px;
    max-width: 800px
}

.contact .rse>div .grid>div {
    position: relative;
    display: flex;
    border-radius: 20px;
    box-shadow: 0 5px 20px var(--main-color-80)
}

.contact .rse>div .grid>div>span {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 30px;
    font-size: .85rem;
    font-weight: 400;
    text-align: center;
    background: #fff;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100);
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px
}

.contact .rse>div .grid>div>span img {
    max-width: 120px
}

.contact .rse>div .grid>div>span span {
    background: #fff
}

.contact .impact {
    padding: 140px var(--page-side-padding) 180px;
    background: var(--main-color-100);
    background-image: url(footer-background.svg);
    background-size: cover
}

.contact .impact h2 {
    margin: 40px 0 30px;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 600;
    font-size: 3.4rem;
    color: #fff
}

.contact .impact p {
    color: #fff
}

.contact .impact>div {
    margin: 80px auto 0;
    padding: 0 46px;
    background: var(--main-color-100);
    border: 1px solid var(--main-color-100);
    box-shadow: 0 20px 60px var(--main-color-40);
    background-image: radial-gradient(8px, transparent 98%, white), linear-gradient(#fff 0, #fff 0);
    background-repeat: round, no-repeat;
    background-position: -48px 0px, 50%;
    background-size: 48px 48px, calc(100% - 80px) 100%
}

.contact .impact>div>div {
    padding: 60px var(--home-grid-padding) 80px;
    background: #fff;
    border-left: 1px solid var(--main-color-100);
    border-right: 1px solid var(--main-color-100)
}

.contact .impact>div li {
    margin: 20px 0 0
}

.contact .contacts {
    position: relative;
    display: flex;
    flex-direction: var(--flex-direction);
    align-items: center;
    gap: 100px;
    min-height: 100vh;
    padding: 140px var(--page-side-padding) 300px;
    border-bottom: 1px solid var(--main-color-100);
    background-image: url(hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: 75%;
    background-color: #fff
}

.contact .contacts:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 500px;
    background-image: url(nantes-reverse.svg);
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: 100% auto;
    z-index: 0;
    transition: all ease-in 3s
}

.contact .contacts:hover:before {
    opacity: .7
}

.contact .contacts>div {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 20px
}

.contact .contacts>div>h2 {
    margin: 0;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700;
    font-size: 4rem
}

.contact .contacts>div>p {
    max-width: 620px
}

.contact .contacts>div .grid {
    display: grid;
    grid-template-columns: var(--grid-template-5-blocks);
    gap: 30px;
    margin-top: 20px;
    width: 100%
}

.contact .contacts>div .grid>div {
    position: relative;
    display: flex;
    flex: 1;
    border-radius: 20px;
    box-shadow: 0 5px 20px var(--main-color-80);
    transition: all ease-in-out .2s
}

.contact .contacts>div .grid>div:hover {
    transform: scale(1.03)
}

.contact .contacts>div .grid>div>span {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    gap: 20px;
    padding: 30px 25px;
    background-color: #fff;
    background-image: radial-gradient(var(--main-color-100) 1px, transparent 0);
    background-size: 20px 20px;
    background-position: -1px -1px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    box-shadow: 0 5px 0 var(--main-color-100)
}

.contact .contacts>div .grid>div>span .avatar {
    max-width: 180px;
    border-radius: 50%;
    border: 5px solid white
}

.contact .contacts>div .grid>div>span span {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: .9rem;
    background-color: #fff
}

.contact .contacts>div .grid>div>span span strong {
    font-size: 90%
}

@media screen and (max-width: 960px) {
    .contact .rse>div {
        width: 100%
    }
    .contact .rse>div>h2 {
        font-size: 3rem;
        background: #fff
    }
    .contact .rse>div>p {
        background: #fff
    }
}

.error .hero {
    position: relative;
    margin: 20px var(--page-side-padding);
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    box-shadow: 0 10px 20px var(--main-color-80);
    border-radius: 20px
}

.error .hero>div>div {
    display: flex;
    justify-content: center;
    flex-direction: var(--flex-direction);
    min-height: 80vh;
    padding: 100px var(--page-block-padding) 80px;
    padding-right: 620px;
    border: 1px solid var(--main-color-100);
    border-radius: 20px;
    background-image: url(hash.svg);
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: 0 6px 0 var(--main-color-100)
}

.error .hero>div>div:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 50px;
    height: 60px;
    width: 65px;
    background: transparent;
    background-image: url(clip.svg), linear-gradient(transparent 0 0);
    background-position: top left;
    background-repeat: no-repeat;
    background-size: 65px 60px, auto;
    transform: rotate(-10deg);
    transform-origin: center right
}

.error .hero>div>div:after {
    content: "";
    position: absolute;
    top: 10px;
    right: 50px;
    bottom: 10px;
    width: 560px;
    background-image: url(wca-questions.svg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.error .hero>div>div h1 {
    margin: 3rem 0 2rem;
    font-size: 5rem;
    font-family: AmpleSoft, Arial, Helvetica, sans-serif;
    font-weight: 700
}

.error .hero>div>div h1 span {
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px
}

.error .hero>div>div p {
    font-size: 1.2rem;
    background: var(--white-color-70);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 20px;
    text-wrap: balance
}

@media(max-width:576px){
    .projects .testimonials>div>div p{
        font-size: 1.1rem !important;
        line-height: 2rem !important;
    }
}