body {
    background-image: url(./images/bg-intro-mobile.png);
    background-color: var(--color-primary);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;

    @media screen and (min-width: 768px) {
        & {
            background-image: url(./images/bg-intro-desktop.png);
        }
    }
}

.main {
    width: 100%;
    padding: 40px 24px;
    display: flex;
    flex-direction: column;
    gap: 64px;

    @media screen and (min-width: 768px) {
        & {
            padding-top: 0px;
            max-width: 560px;    
        }
    }

    @media screen and (min-width: 1024px) {
        & {
            max-width: 1200px;
            flex-direction: row;    
        }
    }
}

.header {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    color: var(--color-white);
    text-align: center;

    & .header_title {
        font-size: clamp(28px, 6.5vw, 50px);
        font-weight: bold;
        line-height: 130%;
        letter-spacing: -0.3px;
    }

    & .header_description {
        font-size: 16px;
        font-weight: 500;
        line-height: 165%;
        letter-spacing: 0px;
    }

    @media screen and (min-width: 1024px) {
        & {
            align-self: center;
            text-align: start;    
        }
    }
}

.form_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.offer_banner {
    font-size: 15px;
    text-align: center;
    padding: 18px 66px;
    background-color: var(--color-purple-700);
    border: 1px solid transparent;
    border-radius: 12px;
    color: var(--color-white);
    box-shadow: 0px 5px 1.5px var(--shadow-general);

    & > span {
        font-weight: bold;
        line-height: 175%;
        letter-spacing: 0.25px;
    }
}

.form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    background-color: var(--color-white);
    padding: 24px;
    border-radius: 10px;
    box-shadow: 0px 5px 1.5px var(--shadow-general);
}

.inputs_fields {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.form__group {
    width: 100%;
    position: relative;
}

.form__group-input {
    width: 100%;
    position: relative;
}

.form__input {
    width: 100%;
    padding: 16px 40px 16px 22px;
    border: 2.5px solid var(--color-gray-200);
    border-radius: 4px;
    transition: border 0.3s ease;
}

.form__input:focus{
    border: 2.5px solid var(--color-purple-350);
    outline: none;
}

.form__validation-status {
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 10px;
    opacity: 0;
    font-size: 20px;
    color: var(--color-primary);
    transition: opacity 0.4s ease-in-out
}

.form__input-error {
    text-align: right;
    margin-top: 10px;
    font-size: 11px;
    color: var(--color-primary);
    line-height: 155%;
    letter-spacing: 0px;
    display: none;
}

.form__input-error-active{
    display: block;
}


.submit_section {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.submit_button {
    width: 100%;
    padding: 15px 24px;
    font-family: var(--poppins-font);
    font-size: 15px;
    font-weight: 700;
    line-height: 175%;
    letter-spacing: 2px;
    color: var(--color-white);
    background-color: var(--color-green-400);
    border: 1px solid transparent;
    border-radius: 8px;
    box-shadow: 0px 5px 1.5px var(--shadow-button);
    cursor: pointer;
}

.terms_conditions {
    font-size: 11px;
    line-height: 190%;
    color: var(--color-purple-350);
    text-align: center;
    font-weight: 500;
}

.terms_conditions > span {
    color: var(--color-primary);
    font-weight: bold;
}

/* Styles validation */

.form__group-incorrect .form__label {
    color: var(--color-primary);
}

.form__group-incorrect .form__validation-status {
    opacity: 1;
}

.form__group-incorrect .form__input{
    border: 2px solid var(--color-primary);
}