:root {
    --pg-clr1: black;
    --pg-clr2: white;
    --pg-clr3: #1F1FFF;
    --pg-clr4: #46d8e5;
    --pg-clr5: #1e1e1e;
    --pg-clr5: #151725;

    --pg-clr6: aliceblue;
}

.s1 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.s1-r1 {
    width: 90%;
    max-width: 80rem;
    margin-inline: auto;
}

.s1-r1-b1 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    text-align: center;
}

.s1-r1-b1--h1-c1 {
    padding: 1rem 0;
}

.s1-r1-b1--p-c1 {
    font-size: 1.125rem;
    color: var(--pg-clr5);
}

.s1-r1-b1--a-c1 {
    font-size: 1.125rem;
    height: 2.75rem;
    display: inline-block;
    align-content: center;
    text-decoration: underline;
    text-decoration-color: var(--h1-clr5);
    text-underline-offset: 7px;
}

@media (min-width:48rem) {
    .s1-r1-b1--p-c1 {
        font-size: 1.2rem;
    }

    .s1-r1-b1--a-c1 {
        font-size: 1.2rem;
    }
}

/*  */

.s2-r1 {
    width: 90%;
    max-width: 80rem;
    margin-inline: auto;
}

.s2-r1-b1 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    padding-bottom: 3rem;
}

@media (min-width:48rem) {
    .s2 {
        padding-bottom: 3rem;
    }
}

/* * */

.s3 {
    background-color: var(--pg-clr6);
    padding-top: 2rem;
    padding-bottom: 5rem;
}

.s3-r1 {
    width: 90%;
    max-width: 80rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

.s3-r1-b1--h2-c1 {
    padding-bottom: 2rem;
    font-weight: 400;
}

.s3-r1-b1--div-c1 {
    padding: 2rem;
    background-color: var(--pg-clr5);
    border-radius: 20px;
}

.s3-r1-b1--p-c1 {
    color: var(--pg-clr2);
    padding: .5rem;
    font-size: 1.125rem;
}

.s3-r1-b1--p-c2 {
    color: var(--pg-clr2);
    padding-bottom: 1rem;
    font-size: 1.125rem;
    /* text-transform: uppercase; */
    letter-spacing: 1px;
}

/*  */

.s3-r1-b2--h2-c1 {
    padding-bottom: 2rem;
    font-weight: 400;
}

.s3-r1-b2--div-c1 {
    display: grid;
    grid-template-columns: 1fr 1.4rem;
    grid-template-areas: "a b"
        "c c";
    margin-bottom: 1rem;
    cursor: pointer;
    background-color: var(--pg-clr2);
    border-radius: 20px;
    margin: 5px;
    padding: 1rem;
}

.s3-r1-b2--div-c2 {
    background-color: var(--pg-clr2);
    border-radius: 20px;
    margin: 0;
}

.s3-r1-b2--h3-c1 {
    grid-area: a;
    font-weight: 500;
    color: var(--pg-clr3);
    padding-right: 3rem;
    font-size: 1.125rem;
}

.s3-r1-b2--p-c1 {
    grid-area: b;
    color: var(--pg-clr4);
    font-size: 1.4rem;
}

.s3-r1-b2--p-c3 {
    grid-area: c;
    font-size: 1.125rem;
    padding-top: 1rem;
    color: var(--pg-clr5);
}

.s3-r1-b2--p-c2 {
    display: none;
}

.s3-r1-b2--p-c4 {
    display: none;
}

/*  */

.s3-r2 {
    width: 90%;
    max-width: 80rem;
    margin-inline: auto;
    margin-top: 3rem;
}

.s3-r2-b1 {
    display: grid;
    grid-template-columns: 1fr;
}

.s3-r2-b1--a-c1 {
    justify-self: center;
    background-color: var(--pg-clr3);
    color: var(--pg-clr2);
    padding: 1rem 1rem;
    font-size: 1rem;
    font-weight: 500;
    border-radius: 1.5rem;
    line-height: 1.25;
    letter-spacing: 0.5px;
    text-transform: capitalize;
}

.s3-r2-b1--a-c1:hover {
    background-color: var(--pg-clr4);
}

@media (min-width:48rem) {
    .s3-r1 {
        grid-template-columns: 1fr 1fr;
    }

    .s3-r2-b1--a-c1 {
        padding: 1rem 2rem;
        font-size: 1.125rem;
    }
}

/* * */

/* -------contact form--------- */


#contactform {

    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-template-areas: "a"
        "aa"
        "b"
        "bb"
        "c"
        "cc"
        "d"
        "dd"
        "e"
        "f"
        "ff"
        "g";

    grid-gap: 1rem;
    /* margin-bottom: 2rem; */
    padding: 2rem 2rem;
    border: 1px solid #1abc9c;

}


#name {
    width: 100%;
    grid-area: a;

}

#email {
    width: 100%;
    grid-area: b;

}

#phone {
    width: 100%;
    grid-area: c;
}

#error-name {
    width: 100%;
    grid-area: aa;

}

#error-mail {
    width: 100%;
    grid-area: bb;

}

#error-phone {
    width: 100%;
    grid-area: cc;
}

#message {
    width: 100%;
    grid-area: d;
}

#error-message {
    width: 100%;
    grid-area: dd;
}

#label-resultat {
    /* width: 50%; */
    grid-area: e;
    justify-self: center;
    text-align: center;
    /* text-transform: uppercase; */
    font-size: 0.9rem;
    color: #34495e;
    letter-spacing: 1px;

    /* margin-top: 1rem; */
}

#resultat {
    width: 100%;
    grid-area: f;
    justify-self: center;
    text-align: center;
}

#error-resultat {
    width: 50%;
    grid-area: ff;
    justify-self: center;
    text-align: center;
}

#contactform .btn {
    font-size: 0.9rem;
    grid-area: g;
    justify-self: center;
    background: #1abc9c;
    color: white;
    /* box-shadow: 0px 2px #16a085; */
    padding: 0.8rem 1.2rem;
    /* margin: 1rem 0; */
    border: none;
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    border-radius: 4px;
    font-weight: 600;
    font-family: inherit;
    transition: all 0.3s ease;
}

#contactform .btn:hover {
    background: #16a085;
    border-color: #204d74;
    cursor: pointer;
}


.form-control {
    color: black;
    border: 2px solid #ecf0f1;
    border-radius: 6px;
    transition: border .25s linear, color .25s linear, background-color .25s linear;
    font-family: inherit;
    padding: 0.5rem;
    font-size: 1rem;
}

.form-control:focus {
    border-color: #1abc9c;
}

.form-control::placeholder {
    color: #2e2e2e;
    opacity: 0.5;
}

/* .form-control::-ms-input-placeholder {
    color: #2e2e2e;
    opacity: 0.5;
} */


@media (min-width:48rem) {

    #contactform {
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-areas: "a b c"
            "aa bb cc"
            "d d d"
            "dd dd dd"
            "e e e"
            "f f f"
            "ff ff ff"
            "g g g";

    }

    #label-resultat {
        width: 50%;
    }

    #resultat {
        width: 50%;
    }

}

/* end of contact section */


.error {
    color: red;

}


#success {
    background: aquamarine;
    padding: 1rem;
    border: 0;
}



#sent {
    font-size: 1.125rem;
    padding: 0.5rem;
}

#thanks {
    color: orangered;
    text-transform: capitalize;
}

#errorsent {
    /* display: block; */
    background: #FBE3E4;
    padding: 1rem;
    color: #8a1f11;
    border: 1px solid #FBC2C4;
    border-radius: 3px;

    /* text-align: center; */
}

#map {
    display: flex;
    justify-content: center;
}

.map-container {
    width: 80vw;
}

/* -------end contact form--------- */