.contact-form--container {
    padding: 48px 16px 0;
    position: relative;
}

@media screen and (min-width: 1024px) {
    .contact-form--container {
        display: flex;
        flex-direction: row-reverse;
        align-items: flex-start;
        gap: 120px;
        padding-bottom: 80px;
    }
}

@media screen and (min-width: 1280px) {
    .contact-form--container {
        padding: 80px 80px 120px;
    }
}

.contact-form--header {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 40px;
}

@media screen and (min-width: 1024px) {
    .contact-form--header {
        margin-bottom: 48px;
    }
}

.contact-form--aside {
    position: relative;
    padding: 64px 0 64px;
    margin-top: 64px;
}

@media screen and (min-width: 1024px) {
    .contact-form--aside {
        padding: 0;
        margin-top: 0;
    }
}

.contact-form--aside aside {
    background: #272d30;
    border: 1px solid var(--grey);
}

@media screen and (min-width: 1024px) {
    .contact-form--aside aside {
        width: 360px;
        flex-shrink: 0;
    }
}

.contact-form--aside .header {
    padding: 40px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    text-align: center;
    z-index: 1;
}

.contact-form--aside .header .title {
    font-size: 2rem;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
}

.contact-form--aside .header .desc {
    font-size: 0.875rem;
    font-style: normal;
    font-weight: 400;
    line-height: 180%;
}

.contact-form--aside .header .contact {
    padding-left: 84px;
    position: relative;
    text-align: left;
}

.contact-form--aside .header .contact::before {
    content: '';
    width: 52px;
    height: 52px;
    border: 1px dashed var(--yellow);
    border-radius: 50%;
    background: url("../images/user-user.svg") no-repeat center;
    background-size: 24px 24px;
    position: absolute;
    left: 0;
    top: calc(50% - 26px);
}

.contact-form--aside .header .contact span {
    font-size: 0.875rem;
    font-style: normal;
    font-weight: 400;
    line-height: 180%;
    display: block;
}

.contact-form--aside .header .contact .name {
    font-family: var(--bebas);
    font-size: 1.25rem;
}

.contact-form--aside .tel-number {
    text-align: center;
    pointer-events: none;
    border-bottom: 1px solid var(--grey);
}

.contact-form--aside .tel-number a {
    padding: 56px 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    font-family: var(--bebas);
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    transition: all .4s;
}

.contact-form--aside .tel-number a::before {
    content: '';
    width: 24px;
    height: 24px;
    -webkit-mask: url("../images/icon-phone.svg") no-repeat center;
    mask: url("../images/icon-phone.svg") no-repeat center;
    -webkit-mask-size: contain;
    mask-size: contain;
    background: var(--yellow);
}

.contact-form--aside .tel-number a:hover {
    color: var(--yellow);
}

.contact-form--aside .hiring {
    padding: 40px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    position: relative;
    z-index: 1;
    border-bottom: 1px solid var(--grey);
}

.contact-form--aside .hiring img{
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    width: 100%;
    height: 100%;
    filter: grayscale(100%);
    z-index: -2;
}

.contact-form--aside .hiring::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
    background: linear-gradient(180deg, rgba(39, 45, 48, 0) 71.35%, #272D30 100%), linear-gradient(0deg, rgba(39, 45, 48, 0.88) 0%, rgba(39, 45, 48, 0.88) 100%);
    background-blend-mode: normal, normal, luminosity;
    z-index: -1;
}

.contact-form--aside .hiring span {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
    color: var(--yellow);
}

.contact-form--aside .hiring span::after {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--yellow);
}

.contact-form--aside .hiring .title {
    font-size: 2rem;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
}

.contact-form--aside .social {
    display: flex;
}

.contact-form--aside .social a {
    flex: 1;
    height: 166px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    justify-content: center;
    font-family: var(--bebas);
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    transition: all .4s;
}

.contact-form--aside .social a:first-child {
    border-right: 1px solid var(--grey);
}

.contact-form--aside .social a::before {
    content: '';
    width: 16px;
    height: 16px;
    background: var(--yellow);
    transition: all .4s;
}

.contact-form--aside .social a.linkedin::before {
    -webkit-mask: url("../images/icon-linkedin.svg") no-repeat center;
    mask: url("../images/icon-linkedin.svg") no-repeat center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

.contact-form--aside .social a.youtube::before {
    -webkit-mask: url("../images/icon-youtube.svg") no-repeat center;
    mask: url("../images/icon-youtube.svg") no-repeat center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

.contact-form--aside .social a:hover {
    color: var(--black);
    background: var(--yellow);
}

.contact-form--aside .social a:hover::before {
    background: var(--black);
}

.contact-form .mobile-line {
    width: 80px;
    height: 100%;
    background: var(--yellow);
    position: absolute;
    top: 0;
    left: -16px;
    z-index: -1;
}

@media screen and (min-width: 1024px) {
    .contact-form .mobile-line {
        display: none;
    }
}

.contact-form .desktop-line {
    display: none;
}

@media screen and (min-width: 1024px) {
    .contact-form .desktop-line {
        display: block;
        width: 160px;
        height: 100%;
        position: absolute;
        left: 0;
        top: 0;
        background: var(--yellow);
        z-index: -1;
    }
}