/* Font Styles */
@import url('https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600;700;800;900&display=swap');


body{
    font-family: 'Rubik', sans-serif;
    justify-content: center;
    background: #ffffff;
}

/* Key Elements */

a {
    text-decoration: none;
    color: #21201E;
    transition: 0.3s ease-in-out;
}

h1 {
    font-family: 'Rubik', sans-serif;
    font-weight: 400;
    font-size: 100px;
    color: white;
}

h2 {
    font-family: 'Rubik', sans-serif;
    font-weight: 800;
    font-size: 50px;
    text-transform: uppercase;
    color: black;
}

h3 {
    font-family: 'Rubik', sans-serif;
    font-weight: 500;
    font-size: 30px;
    color: black;
}

.bodyCopy {
    font-size: 20px;
    line-height: 30px;
}

.btn:hover {
    transition: .3s ease-in-out;
}

.homeButton {
    width: 150px;
    height: auto;

    background-color: #ffc349;
    border-radius: 30px;

    padding: 20px;
    text-align: center;
    font-family: 'Rubik', sans-serif;
    font-size: 20px;
    font-weight: 500;
    color: black; 
}

.homeButton:hover {
    background-color: #000000;
    color: white; 
}

strong {
    font-weight: 800;
    color: red;
}

strong:hover {
    font-weight: 800;
    background: linear-gradient(45deg, red, orange, yellow, green, blue, indigo, violet, red);  -webkit-background-clip: text;
    color: transparent;
    transition: 1.5s ease-in-out;
}



/* ****** Header ****** */
.header {
    width: 100%;
    height: 100%;

    background-image: url("../images/hero.png");
    background-size: cover;
    background-repeat: no-repeat;

}

.headerContents{
    width: 100%;
    display: flex;
    justify-content: space-around;
    position: fixed;
}

.menu-list {
    display: flex;
    gap: 20px;
    margin-top: 52px;
}

.menu-item a:hover {
    color:red;
    font-size: 18px;
    font-weight: 500;
    transition: .1s ease-in;
}

.jlo-logo {
    height: 120px;
    width: auto;
}

.social-media {
    display: flex;
    align-items: center;
    gap: 20px;
}

.social-media a:hover {
    color:red;
    font-size: 18px;
    font-weight: 500;
    transition: .1s ease-in;
}

.hicon {
    height: 22px;
    width: 22px;
}


/* HERO TEXTS */
.heroCont {
    width: 50%;
    display: flex;
    flex-wrap: wrap;

    position: absolute;
    top: 30vh;
    left: 5vw;
}

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

 .heroCopy {
    margin-left:5px;
    font-size: 30px;
 }

 .heroButton {
    width: 200px;
    height: auto;

    background-color: #000000;
    border-radius: 30px;

    padding: 20px;
    text-align: center;
    font-family: 'Rubik', sans-serif;
    font-size: 30px;
    font-weight: 500;
    color: white;
 }

 .heroButton:hover {
    background-color: white;
    color: black;
 }

  /* ***** END OF HEADER ***** */

  /* ***** ABOUT ****** */
.aboutSec {
    width: 100%;
    height: auto;

    display: flex;
    justify-content: space-around;

    margin-top: 100px;
}

.aboutPhoto3Wrap {
    display: flex;
    justify-content: center;
}

.aboutPhoto3 {
    width: 50%;
}

.aboutR {
    width: 50%;
}

.aboutRWrapper {
    width: 70%;

    display: flex;
    flex-direction: column;
}

/* ***** END OF ABOUT ***** */

/* ***** CALL TO ACTION ***** */

.ctaSec {
    width: 100%;
    height: auto;

    background-image: url(../images/banner.jpg);
    background-size: cover;
    background-position: 60%;

    margin-top: 100px;
}

.ctaWrapper {
    display: flex;
    justify-content: space-around;

    padding: 50px;
}

.ctaWrapper .homeButton {
    background-color: black;
    color: white;
}

.ctaWrapper .homeButton:hover {
    background-color: white;
    color: black;
}

.ctaHomeCopy h3 {
    color: white;
}

.ctaHomeCopy .bodyCopy {
    color: white;
}

/* ***** END OF CALL TO ACTION ***** */

/* ***** SERVICES ***** */

.servicesSec {
    width: 100%;
    height: auto;

    margin-top: 100px;

    display: flex;
    flex-direction: column;

}

.servicesSec h2 {
    margin: auto;
}

.servWrapper {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    text-align: center;
}

.flexb {
    width: 300px;
    margin-top: 20px;
}

.service1, .service2, .service3 {
    width: 50%;
} 

.galleryButton {
    width: 100%;

    margin-top:10vh;

    display: flex;
    justify-content: center;
}

.galleryText .bodyCopy{
    color: white;
}

/* ***** END OF SERVICES ***** */

/* ***** FEEDBACK ***** */

.feedbackSec {
    width: 100%;
    height: auto;


    margin-top: 100px;
    background-color: #000000;
}

.feedbackCont {
    display: flex;
    flex-direction: column;
    padding: 50px;
}

.feedbackCont h2 {
    color: white;
    text-align: center;
}

.feedbackWrap {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}

.profile {
    display: flex;
    align-items: center;
}
.prof {
    width: 10%;
}

.fb {
    width: 400px;
    height: auto;

    margin: 20px;
    padding: 20px;
    background-color: #ffc349;
}

/* ***** END OF FEEDBACK ***** */

/* ***** FOOTER ***** */

.footerSec {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;

    padding: 10px 0px 10px 0px;

    background-image: url("../images/footer.png");
    background-size: cover;
    background-repeat: no-repeat;
}

.socialMediaList {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 3vw;
}

.socialMediaList a:hover {
    display: flex;
    gap: 3vw;
    color: red;
}

@media only screen and (max-width: 700px) {
    .menu-item a:hover {
        color:red;
        font-size: 10px;
        font-weight: 500;
        transition: .1s ease-in;
    }
}