body {
    font-family: Roboto;
    font-size: 18px;
    font-weight: lighter;
    color: #a0a0a0;
    background-color: #2f2f2f;
    line-height: 1.4em;
    margin: 0px;
    padding: 0px;
}

/* --------------- grid layout --------------- */

section.container {
    display: grid;
    grid-template-areas:
    "banner"
    "services"
    "form"
    "footer";
}


div.banner {
    grid-area: banner;
}

div.about {
    grid-area: about;
}

div.services {
    grid-area: services;
}

div.form {
    grid-area: form;
}

div.footer {
    grid-area: footer;
}

/* --------------- end grid layout --------------- */

/* --------------- header --------------- */

.header {
    display: grid;
    height: 70px;
    color: #8d8d8d;
    grid-template-areas:
    "navbar";
}

div.navbar {
    grid-area: navbar;
}

.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.brand-title {
    margin: .5rem;
    padding-top: 5px;
}

.navbar-links ul {
    margin: 0;
    padding: 0;
    display: flex;
}

.navbar-links li {
    list-style: none;
}

.navbar-links li a {
    text-decoration: none;
    color: #8d8d8d;
    padding: 1rem;
    display: block;
}

.navbar-links li a:hover {
    color: #777777;
}

.toggle-button {
    position: absolute;
    top: .75rem;
    right: 1rem;
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 21px;
}

.toggle-button .bar {
    height: 3px;
    width: 100%;
    background-color: #ffffff;
    border-radius: 10px;
}

@media (min-width: 1024px) {
    .brand-title {
        margin-left: 50px;
    }

    .navbar-links {
        margin-right: 30px;
    }
}

@media  (max-width: 768px) {
    .toggle-button {
        display: flex;
        margin-top: 10px;
    }

    .navbar-links {
        display: none;
        width: 100%;
    }

    .navbar {
        flex-direction: column;
        align-items: flex-start;
    }

    .navbar-links ul {
        width: 100%;
        flex-direction: column;
    }

    .navbar-links li {
        text-align: center;
    }

    .navbar-links li a {
        padding: .5rem .1rem;
    }

    .navbar-links.active {
        display: flex;
    }

    div.brand-title {
        padding-left: 20px;
    }

    div.navbar-links {
        padding-right: 20px;
    }
}


/* --------------- end header --------------- */

/* --------------- banner --------------- */


.banner {
    background-image: url("../images/bg1.jpg");
    background-size: cover;
    height: 85vh;
    grid-template-areas: 
    "banner-container";
}

div.banner-container {
    text-align: center;
    grid-area: banner-container;
    padding: 100px 220px 100px 220px;
}

.banner-container p {
    font-size: 30px;
    line-height: 1.4em;
    font-style: italic;
}

h1 {
    font-size: 75px;
    font-weight: 900;
    line-height: 1.2em;
    padding-bottom: 30px;
    font-style: italic;
    color: #a0a0a0;
}

@media (max-width: 1920px) {

    h1 {
        font-size: 90px;
    }

    div.banner-container p {
        font-size: 45px;
    }
}

@media (max-width: 1680px) {

    h1 {
        font-size: 70px;
    }

    div.banner-container p {
        font-size: 35px;
    }
}


@media (max-width: 1440px) {

    h1 {
        font-size: 65px;
    }

    div.banner-container p {
        font-size: 25px;
    }
}

@media (max-width: 1024px) {
    div.banner-container {
        padding: 70px 50px 70px 50px;
    }

    h1 {
        font-size: 65px;
    }

    div.banner-container p {
        font-size: 25px;
    }
}

@media (max-width: 800px) {


    h1 {
        font-size: 55px;
    }

    div.banner-container p {
        font-size: 25px;
    }
}

@media (max-width: 480px) {
    div.banner-container {
        padding: 50px 30px 50px 30px;
    }

    h1 {
        font-size: 45px;
    }

    div.banner-container p {
        font-size: 25px;
    }
}

/* --------------- end banner --------------- */

/* --------------- about --------------- */

.about {
    background-color: #bcbcbc;
}

.about-container {
    padding: 50px 50px 50px 50px;
}

.about-container p {
    color: #1d1d1d;
    font-size: 25px;
    line-height: 1.3em;
    padding-bottom: 10px;
}

h2 {
    font-size: 35px;
    font-weight: 900;
    color: #1d1d1d;
    line-height: 1.2em;
    padding-bottom: 20px;
    font-style: italic;
}

hr  {
    border: 1px solid #1d1d1d;
    margin-bottom: 20px;
}

.about-text p {
    text-align: left;
    font-size: 20px;
}

@media (max-width: 480px) {
    .about-container {
        padding: 50px 30px 50px 30px;
    }

}

/* --------------- end about --------------- */

/* ---------- service ---------- */

.services {
    padding: 50px 50px 50px 50px;
    background-color: #2e2e2e;
}

h3 {
    font-size: 35px;
    font-weight: 900;
    color: #8d8d8d;
    line-height: 1.2em;
    padding-bottom: 20px;
    font-style: italic;
}

h4 {
    font-size: 28px;
    font-weight: 700;
    color: #8d8d8d;
    line-height: 1.2em;
    padding-bottom: 20px;
    text-align: center;
    font-style: italic;
}

.services p {
    color: #8d8d8d;
    font-size: 25px;
    line-height: 1.3em;
    padding-bottom: 10px;
}

.details p {
    font-size: 20px;
}

.hr2 {
    border: 1px solid #8d8d8d;
    margin-bottom: 20px;
}

.service-container1 {
    display: grid;
    grid-template-areas: 
    "music"
    "movies";
}

div.music {
    grid-area: music;
    background-color: #282828;
    padding: 30px 50px 30px 50px;
    
    margin: 20px;
}

div.movies {
    grid-area: movies;
    background-color: #282828;
    padding: 30px 50px 30px 50px;
    
    margin: 20px;
}

.service-container2 {
    display: grid;
    grid-template-areas: 
    "games"
    "books";
}

div.games {
    grid-area: games;
    background-color: #282828;
    padding: 30px 50px 30px 50px;
    
    margin: 20px;
}

div.books {
    grid-area: books;
    background-color: #282828;
    padding: 30px 50px 30px 50px;
    
    margin: 20px;
}

.icon   {
    text-align: center;
}

.icon img {
    width: 100px;
    height: 100px;
    padding-bottom: 10px;
}

.title {
    font-size: 25px;
    font-weight: 400;
    padding-bottom: 20px;
}

@media (min-width: 1440px) {
    div.music {
        padding: 50px 90px 50px 90px;
    }
    
    div.movies {
        padding: 50px 90px 50px 90px;
    }

    div.games {
        padding: 50px 90px 50px 90px;
    }
    
    div.books {
        padding: 50px 90px 50px 90px;
    }
}

@media (min-width: 1000px) {
    .service-container1 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-areas: 
        "music movies";
    }
    
    .service-container2 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-areas: 
        "games books";
    } 
}

@media (max-width: 480px) {
    .services {
        padding: 50px 30px 50px 30px
    }

    .icon img {
        width: 80px;
        height: 80px;
    }

    div.music {
        padding: 30px 30px 30px 30px;
    }
    
    div.movies {
        padding: 30px 30px 30px 30px;
    }

    div.games {
        padding: 30px 30px 30px 30px;
    }
    
    div.books {
        padding: 30px 30px 30px 30px;
    }
} 

/* ---------- end service ---------- */

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

.form {
    display: grid;
    background-color: #282828;
    background-size: cover;
    padding: 50px 50px 50px 50px;
    grid-template-areas: 
    "form-content"
    "form-container";
}

.join-form {
    height: 50vh;
}

h5 {
    font-size: 25px;
    font-weight: 400;
    color: #8d8d8d;
    line-height: 1.2em;
    padding-bottom: 20px;
}

.form-container {
    display: grid;
    color: #8d8d8d;
    padding-bottom: 20px;
}

.form-container p {
    color: #8d8d8d;
    font-size: 25px;
    line-height: 1.3em;
    padding-bottom: 10px;

}


.service-title p {
    color: #8d8d8d;
    font-size: 20px;
    line-height: 1.3em;
    padding-bottom: 10px;
}

.form-fillup {
    padding-bottom: 10px;
}

.form-content p {
    color: #ffffff;
    font-size: 20px;
    line-height: 1.3em;
}

.form-container {
    padding-left: 30px;
}


input[type=text], select, textarea {
    background-color: #e1e1e1;
    width: 100%;
    height: 55px;
    padding: 10px;
    border: 1px solid #ccc;
    box-sizing: border-box;
    margin-bottom: 10px;
    resize: vertical;
    font-weight: 200;
    font-size: 18px;
}
  
input[type=submit] {
    background-color: #ff0e47;
    color: white;
    padding: 10px 25px;
    border: none;
    cursor: pointer;
    font-size: 20px;
    font-weight: 600;
    width: 100%;
    height: 55px;
}

.cvv-zip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(75px, 1fr));
    grid-template-areas:
    "cvv"
    "zip";
}

div.cvv {
    grid-area: cvv;
}

div.zip {
    grid-area: zip;   
}

@media (min-width: 768px) {
    .cvv-zip {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(75px, 1fr));
        grid-template-areas:
        "cvv zip";
    }

    .cvv {
        padding-right: 10px;
    }
}
    
.month-date {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(75px, 1fr));
    grid-template-areas:
    "month"
    "date";
    }
    
    div.month{
        grid-area: month;
    }
    
    div.date {
        grid-area: date;
    }
    
@media (min-width: 768px) {
    .month-date {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(75px, 1fr));
        grid-template-areas:
        "month date";
        }
        
    .month {
        padding-right: 10px;
        }
}

@media (max-width: 425px) {
    .month {
        padding-right: 0px;
    }

    .form {
        padding: 50px 30px 50px 30px;
    }

    
}

@media (min-width: 1440px) {
    .join-form {
        height: 55vh;
    }
}

@media (min-width: 1024px) {
    .join-form {
        height: 63vh;
    }
}

@media (min-width: 800px) {
    .form {
        display: grid;
        background-color: #282828;
        background-size: cover;
        padding: 50px 50px 50px 50px;
        grid-template-columns: 1fr 1fr;
        grid-template-areas: 
        "form-content"
        "form-container";
    }

    .form-container {
        display: grid;
    }
}

@media (max-width: 768px) {
    .form-content {
        padding-top: 20px;
        padding-left: 0px;
    }

    .join-form {
        height: 65vh;
    }
}

@media (max-width: 480px) {
    .form {
        padding-top: 50px;
        padding-right: 50px;
        padding-left: 30px;
        padding-right: 30px;
    }

    .form-container {
        padding-left: 0px;
        padding-top: 20px;
    }

    .join-form {
        height: 70vh;
    }
}

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

/* ---------- footer ---------- */


.footer-container {
    display: grid;
    background-color: #222222;
    padding: 50px 50px 50px 50px;
    grid-template-areas: 
    "address"
    "logo2";
}

.footer p {
    font-size: 20px;
}

.address {
    padding: 8px;
}

.logo2 {
    padding-left: 30px;
}

.allriche {
    padding-top: 10px;
    padding-bottom: 10px;
}

.info {
    font-size: 18px;
}

.social-footer {
    display: grid;
    display: flex;
    padding-top: 10px;
    grid-template-columns: repeat(5, 1fr);
    grid-template-areas:
    "facebook-footer instagram-footer twiter-footer";
  }

  div.facebook-footer {
    grid-area: facebook-footer;
    height: 45px;
    width: 45px;
    padding: 8px;
  }

  div.instagram-footer {
    grid-area: instagram-footer;
    height: 45px;
    width: 45px;
    padding: 8px;
  }

  div.twiter-footer{
    grid-area: twiter-footer;
    height: 45px;
    width: 45px;
    padding: 8px;
  }


@media (min-width: 800px) {
    .footer-container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-areas: 
        "address logo2";
    }
}

@media (max-width: 768px) {
    .logo2 {
        padding-top: 20px;
        padding-left: 0px;
    }
}

@media (max-width: 480px) {
    .footer-container {
        padding: 50px 30px 50px 30px;
    }

    .logo2 {
        padding-left: 0px;
        padding-top: 20px;
    }
}