* {
    margin: 0;
    padding: 0;
    color: #000000;
    flex-direction: column;
    box-sizing: border-box;
    scroll-behavior: smooth;
    font-family: 'Roboto', sans-serif;
}

*::selection {
    background-color: #008CD2;
}

body {
    display: flex;
    background: #ffffff;
}

.button-whatsapp {
    right: 2%;
    bottom: 4%;
    width: 5em;
    z-index: 1;
    padding: 1em;
    display: flex;
    position: fixed;
    border-radius: 50%;
    background-color: #25d366;
}

.button-whatsapp>.icon {
    width: 100%;
    fill: #FFFFFF;
}

header {
    z-index: 1;
    width: 100%;
    display: flex;
    padding: 2em 9em;
    position: absolute;
    align-items: center;
    flex-direction: row;
}

header>.logo {
    width: 5em;
}

header>.options {
    gap: 2em;
    display: flex;
    list-style: none;
    margin-left: auto;
    flex-direction: row;
}

header>.options>li>.option {
    font-size: 1.2em;
    color: #FFFFFF;
    font-weight: 500;
    text-decoration: none;
}

main {
    display: flex;
    min-height: 93.4vh;
}

main>.initial {
    display: flex;
    position: relative;
    margin-bottom: 8em;
}

main>.initial>.texts {
    width: 45%;
    display: flex;
    margin-top: 12em;
    margin-left: 9em;
}

main>.initial>.texts>.title {
    font-size: 3em;
}

main>.initial>.texts>.title>.highlighted {
    color: #008CD2;
}

main>.initial>.texts>.description {
    font-size: 2em;
    margin-top: 0.5em;
}

main>.initial>.button {
    padding: 1em;
    display: flex;
    margin-left: 6em;
    color: #FFFFFF;
    font-size: 1.5em;
    margin-top: 2.5em;
    border-radius: 5px;
    text-decoration: none;
    align-self: flex-start;
    transition-duration: 0.15s;
    background-color: #008CD2;
    transition-timing-function: linear;
}

main>.initial>.button:hover {
    transform: scale(1.08);
}

main>.initial>.photo {
    width: 100%;
    z-index: -1;
    height: 48em;
    object-fit: cover;
    position: absolute;
}

main>.initial>.photo.mobile {
    display: none;
}

main>.services {
    display: flex;
    margin-top: 15vh;
    align-items: center;
}

main>.services>.subtitle {
    color: #F4CA1E;
    font-size: 1.2em;
    font-weight: bold;
    text-align: center;
}

main>.services>.title {
    width: 95%;
    font-size: 2em;
    text-align: center;
}

main>.services>.title>.highlighted {
    color: #008CD2;
}

main>.services>.description {
    max-width: 40em;
    font-size: 1.2em;
    margin-top: 0.5em;
    text-align: center;
}

main>.services>.list {
    gap: 2em;
    width: 100%;
    display: flex;
    margin-top: 3em;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: space-evenly;
}

main>.services>.list>.service {
    width: 85%;
    display: flex;
    padding: 1.5em;
    max-width: 40em;
    border-radius: 10px;
    border-top: 3px solid #F4CA1E;
    box-shadow: 0px 5px 10px 5px rgba(0, 0, 0, 0.1);
}

main>.services>.list>.service>.icon {
    width: 3.5em;
    fill: #F4CA1E;
}

main>.services>.list>.service>.title {
    font-size: 1.2em;
    margin-top: 0.5em;
    font-weight: bold;
}

main>.services>.list>.service>.description {
    font-size: 1.2em;
    margin-top: 1.5em;
    margin-bottom: 2em;
}

main>.services>.list>.service>.button {
    display: flex;
    font-size: 1em;
    color: #FFFFFF;
    margin-top: auto;
    padding: 1em 3em;
    border-radius: 5px;
    text-decoration: none;
    align-self: flex-start;
    transition-duration: 0.15s;
    background-color: #008CD2;
    transition-timing-function: linear;
}

main>.services>.list>.service>.button:hover {
    transform: scale(1.08);
}

main>.about {
    display: flex;
    margin-top: 5em;
    align-items: center;
    background-color: #008CD2;
}

main>.about>.subtitle {
    color: #F4CA1E;
    margin-top: 3em;
    font-size: 1.2em;
    font-weight: bold;
    text-align: center;
}

main>.about>.title {
    width: 95%;
    font-size: 2em;
    text-align: center;
}

main>.about>.description {
    max-width: 40em;
    font-size: 1.2em;
    color: #FFFFFF;
    font-weight: 300;
    margin-top: 0.5em;
    text-align: center;
}

main>.about>.description>.highlighted {
    color: #FFFFFF;
    font-weight: bold;
}

main>.about>.focuses {
    gap: 2em;
    width: 100%;
    display: flex;
    margin-top: 3em;
    flex-wrap: wrap;
    margin-bottom: 5em;
    flex-direction: row;
    justify-content: space-evenly;
}

main>.about>.focuses>.focus {
    width: 85%;
    display: flex;
    padding: 1.5em;
    max-width: 30em;
    border-radius: 10px;
    box-shadow: 0px 2px 15px 8px rgba(0, 0, 0, 0.1);
}

main>.about>.focuses>.focus>.icon {
    width: 3.5em;
    fill: #F4CA1E;
}

main>.about>.focuses>.focus>.title {
    font-size: 1.5em;
    font-weight: bold;
}

main>.about>.focuses>.focus>.description {
    font-size: 1em;
    margin-top: 1em;
    color: #FFFFFF;
}

main>.optimize {
    height: 25em;
    display: flex;
    position: relative;
}

main>.optimize>.content {
    width: 35%;
    display: flex;
    margin-top: auto;
    margin-left: auto;
    margin-right: 10em;
    margin-bottom: auto;
    background-color: reed;
}

main>.optimize>.content>.title {
    color: #FFFFFF;
    font-size: 2.5em;
}

main>.optimize>.content>.title>.highlighted {
    color: #F4CA1E;
}

main>.optimize>.content>.description {
    color: #FFFFFF;
    font-size: 1.2em;
}

main>.optimize>.content>.button {
    display: flex;
    font-size: 1em;
    margin-top: 2em;
    color: #FFFFFF;
    padding: 1em 2em;
    font-weight: bold;
    border-radius: 5px;
    text-decoration: none;
    align-self: flex-start;
    transition-duration: 0.15s;
    background-color: #008CD2;
    transition-timing-function: linear;
}

main>.optimize>.content>.button:hover {
    transform: scale(1.08);
}

main>.optimize>.photo {
    width: 100%;
    z-index: -1;
    height: 100%;
    object-fit: cover;
    position: absolute;
}

main>.optimize>.photo.mobile {
    display: none;
}

main>.contact {
    display: flex;
}

main>.contact>#form {
    width: 90%;
    padding: 1em;
    display: flex;
    margin-top: 5em;
    max-width: 35em;
    align-self: center;
    border-radius: 5px;
    flex-direction: column;
    background-color: #E3F3FF;
}

main>.contact>#form>.title {
    font-size: 2em;
    margin: 0.5em 0;
    text-align: center;
}

main>.contact>#form>input, main>.contact>#form>textarea {
    border: none;
    margin-top: 1em;
    border-radius: 5px;
    padding: 1em 0.5em;
}

main>.contact>#form>input:focus, main>.contact>#form>textarea:focus {
    outline: none;
}

main>.contact>#form>input::placeholder, main>.contact>#form>textarea::placeholder {
    color: #000000;
}

main>.contact>#form>textarea {
    resize: vertical;
}

main>.contact>#form>button {
    border: none;
    display: flex;
    font-size: 1em;
    cursor: pointer;
    margin-top: 3em;
    color: #FFFFFF;
    padding: 1em 4em;
    font-weight: bold;
    border-radius: 5px;
    align-self: center;
    transition-duration: 0.15s;
    background-color: #008CD2;
    transition-timing-function: linear;
}

main>.contact>#form>button:hover {
    transform: scale(1.08);
}

footer {
    gap: 3em;
    width: 85%;
    display: flex;
    margin: 2em 0;
    padding: 2em 5em;
    align-self: center;
    border-radius: 5px;
    align-items: center;
    flex-direction: row;
    background-color: #E3F3FF;
    justify-content: space-between;
}

footer>.content {
    gap: 1em;
    display: flex;
    align-items: center;
    flex-direction: row;
}

footer>.content>.logo {
    width: 8em;
}

footer>.content>.text {
    width: 18em;
    margin-left: 1em;
}

footer>.powered {
    gap: 1em;
    display: flex;
    align-items: center;
}

footer>.powered>.text {
    font-size: 1em;
}

footer>.powered>.logo {
    width: 6em;
}

@media screen and (max-width: 900px) {
    .button-whatsapp {
        width: 4em;
    }

    header {
        padding: 1em 1.5em;
        flex-direction: column;
    }

    header>.options {
        gap: 0.5em;
        margin: auto;
        margin-top: 1em;
    }

    header>.options>li>.option {
        font-size: 0.8em;
    }

    main>.initial>.texts {
        width: 65%;
        margin-top: 10.5em;
        margin-left: 1.5em;
    }

    main>.initial>.texts>.title {
        font-size: 1.8em;
    }

    main>.initial>.texts>.description {
        width: 80%;
        font-size: 1.2em;
    }

    main>.initial>.button {
        font-size: 1em;
        margin-left: 0;
        margin-top: 2em;
        align-self: center;
    }

    main>.initial>.photo {
        height: 35em;
    }

    main>.initial>.photo.mobile {
        display: block;
    }

    main>.initial>.photo.desktop {
        display: none;
    }

    main>.services {
        margin-top: 0;
    }

    main>.services>.title {
        width: 90%;
        font-size: 1.7em;
    }

    main>.services>.description {
        width: 90%;
    }

    main>.services>.list>.service>.button {
        align-self: center;
    }

    main>.about>.title {
        width: 90%;
        font-size: 1.8em;
        text-align: center;
    }
    
    main>.about>.description {
        font-size: 1em;
        max-width: 90%;
    }

    main>.about>.focuses>.focus>.title {
        font-size: 1.2em;
    }

    main>.about>.focuses>.focus>.description {
        font-size: 0.8em;
    }

    main>.optimize>.content {
        width: 90%;
        margin-top: 5em;
        margin-right: auto;
    }

    main>.optimize>.content>.title, main>.optimize>.content>.description {
        text-align: center;
    }

    main>.optimize>.content>.button {
        margin-top: 10em;
        align-self: center;
    }

    main>.optimize>.photo {
        height: 35em;
    }

    main>.optimize>.photo.mobile {
        display: block;
    }

    main>.optimize>.photo.desktop {
        display: none;
    }

    main>.contact>#form {
        margin-top: 15em;
    }

    main>.contact>#form>.title {
        font-size: 1.5em;
        align-self: center;
    }

    main>.contact>#form>button {
        align-self: center;
    }

    footer {
        padding: 3em 0;
        flex-direction: column;
    }

    footer>.content {
        flex-direction: column;
    }
    
    footer>.content>.logo {
        width: 5em;
    }
    
    footer>.content>.text {
        width: 90%;
        margin-left: 0;
        max-width: 18em;
        text-align: center;
    }
}