@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

body{
  margin: 0;
  font-family: 'Roboto', sans-serif;
}
/* .container{
  padding: 20px;
  background-color: #000b17;
} */

/* --------------------------------------------------------------------------------- */
/* DIV STYLE */
/* --------------------------------------------------------------------------------- */
.maingrid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(min-content, max-content);
  grid-gap: 20px;
}

/* Desktop - Homepage */
/* ------------------------------------------------------- */
.home-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  /* margin-bottom: 40px; */
}

.home-content-1 {
  grid-column: 2 / 7;
  grid-row: 2;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: subgrid;
  align-items: center;
  justify-items: center;
  margin-bottom: 50px;
}

    .home-content-1 .item-1{
      grid-column: 1 / 2;
      grid-row: 1;
      padding: 0 0 20px 0;
      text-align: left;
    }

    .home-content-1 .item-2{
      grid-column: 1 / 2;
      grid-row: 2;
    }

.home-content-2 {
  grid-column: 7 / 12;
  grid-row: 2;
}

/* Desktop - About Us */
/* ------------------------------------------------------- */

.about-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  /* margin-bottom: 40px; */
}

.about-content-img {
  grid-column: 2 / 6;
  grid-row: 2;
  margin: 50px 0;
}

.about-content-1 {
  grid-column: 6 / 12;
  grid-row: 2;
  margin: 50px 0;
}

.about-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  margin-bottom: 50px;
}

.about-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
  text-align: center;
  margin-bottom: 50px;
}

.about-content-4 {
  grid-column: 1 / 13;
  grid-row: 5;
  display: grid;
  grid-template-columns: 80px 1fr 1fr 1fr 80px;
  grid-template-rows: subgrid;
  text-align: center;
  gap: 40px;
  color: white;
  padding: 50px 0;
}
    .about-content-4 .header{
      grid-column: 2 / 5;
      grid-row: 1;
    }
    .about-content-4 .item-1{
      grid-column: 2 / 3;
      grid-row: 2;
    }

    .about-content-4 .item-2{
      grid-column: 3 / 4;
      grid-row: 2;
    }

    .about-content-4 .item-3{
      grid-column: 4 / 5;
      grid-row: 2;
    }

.about-content-5 {
  grid-column: 2 / 12;
  grid-row: 6;
  margin: 20px 0 50px;
}


/* Desktop - Services */
/* ------------------------------------------------------- */
.services-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; 
  /* margin-bottom: 40px; */
}

.services-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: subgrid;
  text-align: left;
  gap: 40px;
  margin-bottom: 50px;
}

  .services-content-1 .item-1{
    grid-column: 1 / 6;
    grid-row: 1;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: subgrid;
  }
      .services-content-1 .item-1 .sub-item-1{
        grid-column: 1 / 3;
        grid-row: 1;
      }
      
      .services-content-1 .item-1 .sub-item-2{
        grid-column: 1 / 2;
        grid-row: 2;
      }
      .services-content-1 .item-1 .sub-item-3{
        grid-column: 2 / 3;
        grid-row: 2;
      }
  .services-content-1 .item-2{
    grid-column: 6 / 8;
    grid-row: 1;
  }

.services-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  text-align: center;
  align-items: center;
  justify-content: center;
}

.services-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
  margin-bottom: 50px;
  text-align: center;
  align-items: center;
  justify-content: center;
}

.services-content-3 .list {
  display: grid;
  overflow: hidden;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 1fr;
  gap: 20px;
  width: 100%;
  padding-left: 0;
}
.services-content-3 .list-item {
  background-color: #f0eb0c;
  display: flex;
  flex-direction: column;
  height: min-content;
}
.services-content-3 .list-content {
  width: 100%;
  background-color: white;
  padding-top: 10px;
  /* border: #38b0e6 solid 3px; */
}

.services-content-3 img {
  width: 60px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  position: absolute;
}

.services-content-3 .list-item div:first-child {
  width: 100%;
  height: 100px;
  position: relative;
  /* border: green solid 3px; */
}


/* Desktop - Our Brands */
/* ------------------------------------------------------- */

.brand-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; 
  /* margin-bottom: 40px; */
}

.brand-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 50px 0;
  text-align: center;
}

    .brand-container {
      display: flex;
      flex-wrap: wrap;                  /*  allow items to wrap  */
      align-items: center;
      justify-content: center;
      gap: 30px;
    }

    .brand-logo {
      flex-basis: calc(25% - 60px); /*  subtract the margin from the width  */
    }

    .brand-logo img {
      display: block;
      width: 100%;
      min-width: 100px;
    }

.brand-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  margin-bottom: 50px;
  text-align: center;
  align-items: center;
  justify-content: center;
}


/* Desktop - Product */
/* ------------------------------------------------------- */
.product-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; 
  /* margin-bottom: 40px; */
}

.spacing > div {
  margin-bottom: 50px;
  align-items: center;
  text-align: center;
  justify-content: center;
}


.product-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
}

.product-content-1 img{
  width: 70%;
  height: auto;
}

.product-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
}

.product-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
}

      .product-content-3 .container {
        width: 100%;
        height: auto;
        display: flex;
        flex-wrap: nowrap;
        gap: 20px;
        margin-bottom: 20px;
      }

      .product-content-3 img {
        width: 100%;
        min-width: 150px;
        height: auto;
        display: block;
      }

      .product-content-3 .column-1 {
        flex-basis: 200px;
        flex-grow: 0;
        flex-shrink: 0;
      }

      .product-content-3 .column-2 {
        flex-grow: 1;
        text-align: left;
      }

      /* @media only screen and (max-width: 1000px) {
        .container div {
          width: 100%;
          flex-grow: 0;
          border:red solid 3px; 
        }
        .column-1 {
          max-width: 200px;
          flex-grow: 0;
          object-fit: cover;
        }
        } */
      

.product-content-4 {
  grid-column: 2 / 12;
  grid-row: 5;
}

.product-content-5 {
  grid-column: 2 / 12;
  grid-row: 6;
}

.product-content-6 {
  grid-column: 2 / 12;
  grid-row: 7;
}
.product-content-7 {
  grid-column: 2 / 12;
  grid-row: 8;
}

.product-content-8 {
  grid-column: 2 / 12;
  grid-row: 9;
}
.product-content-9 {
  grid-column: 2 / 12;
  grid-row: 10;
}

.product-content-10 {
  grid-column: 2 / 12;
  grid-row: 11;
}

.product-content-11 {
  grid-column: 2 / 12;
  grid-row: 12;
}

.product-content-12 {
  grid-column: 2 / 12;
  grid-row: 13;
}

.product-content-13 {
  grid-column: 2 / 12;
  grid-row: 14;
}

.product-content-14 {
  grid-column: 2 / 12;
  grid-row: 15;
}

.product-content-15 {
  grid-column: 2 / 12;
  grid-row: 16;
}

.product-content-16 {
  grid-column: 2 / 12;
  grid-row: 17;
}

.product-content-17 {
  grid-column: 2 / 12;
  grid-row: 18;
}

      /* Desktop - Product List */
      /* ------------------------------------------------------- */
      .product-list {
        display: grid;
        overflow: hidden;
        grid-template-columns: repeat(4, 1fr);
        grid-auto-rows: 1fr;
        gap: 20px;
        width: 100%;
        padding-left: 0;
      }
      .product-list-item {
        display: flex;
        flex-direction: column;
        height: min-content;

      }
      .product-list-content { 
        width: 100%;
        padding-top: 10px;
      }
      
      .product-list-item img {
        width: 150px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        position: absolute;
      }

      .product-list-item div:first-child {
        width: 100%;
        height: 180px; /* product image section height */
        position: relative;
        background-color: #e3e3e3;
        border: #a8a8a8 solid 3px;
      }


/* Desktop - Contact */
/* ------------------------------------------------------- */
.contact-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; 
  /* margin-bottom: 40px; */
}

.contact-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 50px 0;
  text-align: center;
}

.contact-content-2 div:first-child{
  position: relative;
  width: 100%;
  overflow: hidden;
  padding-top: 56.25%;
}

.responsive-iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.contact-content-2 {
  grid-column: 2 / 6;
  grid-row: 3;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: subgrid;
}

.contact-content-2 .map {
  grid-column: 1 / 2;
  grid-row: 1;
}

.contact-content-2 .add {
  grid-column: 1 / 2;
  grid-row: 2;
  margin-top: 10px;
}

.contact-content-3 {
  grid-column: 6 / 12;
  grid-row: 3;
  margin-bottom: 50px;
}

.contact-content-3 label {
  width: calc(100% - 40px);
  height: 40px;
  color: #7c7c7c;
}

.contact-content-3 input {
  width: calc(100% - 40px);
  height: 40px;
  padding: 5px;
  margin: 5px 0 20px 0;
  border: #a1a1a1 solid 1px;
}

.contact-content-3 textarea{
  width: calc(100% - 40px);
  height: 60px;
  padding: 5px;
  margin: 5px 0 5px 0;
  border: #a1a1a1 solid 1px;
}

.contact-content-3 .email-button {
  padding: 10px 50px;
  font-size: 18px;
  font-weight: 700;
  width:max-content;
  border-radius: 5px;
  color: white;
  background-color: #38b0e6;
  border: none;
}


/* Footer */
/* ------------------------------------------------------- */
.footer-1 {
  grid-column: 1 / 7;
  grid-row: 2;
  display: grid;
  grid-template-columns: 50px 1fr 1fr 1fr 1fr 50px;
  grid-template-rows: subgrid;
  padding: 50px 0;
  gap: 20px;
}
    .footer-1 .address{
      grid-column: 2 / 3;
      grid-row: 1;
    }

    .footer-1 .products{
      grid-column: 3 / 4;
      grid-row: 1;
    }
    .footer-1 .industry{
      grid-column: 4 / 5;
      grid-row: 1;
    }
    .footer-1 .services{
      grid-column: 5 / 6;
      grid-row: 1;
    }

.footer-2 {
  grid-column: 1 / 7;
  grid-row: 2;
  height: 60px;
  display: grid;
  grid-template-columns: 50px 1fr 1fr 1fr 1fr 50px;
  grid-template-rows: subgrid;
  background-color: #434343;
}
    .footer-2 .menu{
      grid-column: 2 / 4;
      grid-row: 1;
      margin-top: 15px;
      
    }
    .footer-2 .copyright{
      grid-column: 4 / 6;
      grid-row: 1;
      text-align: right;
      margin-top: 15px;
    }

/* --------------------------------------------------------------------------------- */
/* TABLET LAYOUT */
/* --------------------------------------------------------------------------------- */
@media screen and (max-width: 970px) {
/* Home */
/* ------------------------------------------------------- */

  .home-content-1 {
    grid-column: 1 / 7;
    grid-row: 2;
    padding-left: 20px;
  }
  
  .home-content-2 {
    grid-column: 7 / 13;
    grid-row: 2;
  }

/* Tablet - About Us */
/* ------------------------------------------------------- */

.about-content-img {
  grid-column: 2 / 6;
  grid-row: 2;
  margin: 0;
  position: relative;
}

.about-content-1 {
  grid-column: 6 / 12;
  grid-row: 2;
  margin: 50px 0;
}

.about-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  margin: 20px 0 50px 0;
}

.about-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
  text-align: center;
  margin-bottom: 50px;
}

.about-content-4 {
  grid-column: 1 / 13;
  grid-row: 5;
  display: grid;
  grid-template-columns: 80px 1fr 1fr 1fr 80px;
  grid-template-rows: subgrid;
  text-align: center;
  gap: 40px;
  color: white;
  margin-bottom: 50px;
  padding: 50px 0;
}
    .about-content-4 .header{
      grid-column: 2 / 5;
      grid-row: 1;
      padding: 20px;
    }
    .about-content-4 .item-1{
      grid-column: 2 / 3;
      grid-row: 2;
    }

    .about-content-4 .item-2{
      grid-column: 3 / 4;
      grid-row: 2;
    }

    .about-content-4 .item-3{
      grid-column: 4 / 5;
      grid-row: 2;
    }


/* Tablet - Services */
/* ------------------------------------------------------- */
.services-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: subgrid;
  text-align: left;
  gap: 40px;
  margin-bottom: 50px;
}

  .services-content-1 .item-1{
    grid-column: 1 / 5;
    grid-row: 1;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: subgrid;
  }
      .services-content-1 .item-1 .sub-item-1{
        grid-column: 1 / 3;
        grid-row: 1;
        margin-bottom: 10px;
      }
      
      .services-content-1 .item-1 .sub-item-2{
        grid-column: 1 / 3;
        grid-row: 2;
      }

      .services-content-1 .item-1 .sub-item-3{
        grid-column: 1 / 3;
        grid-row: 3;
      }

  .services-content-1 .item-2{
    grid-column: 5 / 8;
    grid-row: 1;
  }

.services-content-3 .list {
  display: grid;
  overflow: hidden;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 1fr;
  gap: 20px;
  width: 100%;
  padding-left: 0;
}


/* Tablet - Our Brands */
/* ------------------------------------------------------- */

.brand-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  aspect-ratio: 16 / 3;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; 
  /* margin-bottom: 40px; */
}

.brand-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 50px 0;
  text-align: center;
}

    .brand-container {
      display: flex;
      flex-wrap: wrap;                  /*  allow items to wrap  */
      align-items: center;
      justify-content: center;
      gap: 30px;
    }

    .brand-logo {
      flex-basis: calc(25% - 60px); /*  subtract the margin from the width  */
    }

    .brand-logo img {
      display: block;
      width: 100%;
      min-width: 100px;
    }

.brand-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  margin-bottom: 50px;
  text-align: center;
  align-items: center;
  justify-content: center;
}


/* Tablet - Product List */
/* ------------------------------------------------------- */
.product-list {
  grid-template-columns: repeat(2, 1fr);
}

/* Tablet - Contact */
/* ------------------------------------------------------- */
.contact-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 50px 0;
  text-align: center;
}

.contact-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: subgrid;
}

.contact-content-2 .map {
  grid-column: 1 / 2;
  grid-row: 1;
}

.contact-content-2 .add {
  grid-column: 2 / 3;
  grid-row: 1;
  margin-top: 10px;
}

.contact-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
  margin-bottom: 50px;
}


/* Tablet - Footer */
/* ------------------------------------------------------- */
.footer-1 .address{
  grid-column: 2 / 4;
  grid-row: 1;
}

.footer-1 .products{
  grid-column: 4 / 6;
  grid-row: 1;
}
.footer-1 .industry{
  grid-column: 2 / 4;
  grid-row: 2;
}
.footer-1 .services{
  grid-column: 4 / 6;
  grid-row: 2;
}
.footer-2 {
height: 100px;
}
.footer-2 .menu{
  grid-column: 1 / 7;
  grid-row: 1;
  text-align: center;
  margin-top: 15px;
  
}
.footer-2 .copyright{
  grid-column: 1 / 7;
  grid-row: 2;
  text-align: center;
  margin-top: 15px;
}
}


/* --------------------------------------------------------------------------------- */
/* MOBILE LAYOUT */
/* --------------------------------------------------------------------------------- */
@media screen and (max-width: 768px) {
  /* Mobile - Home */
  /* ------------------------------------------------------- */
  
    .home-content-1 {
      grid-column: 1 / 13;
      grid-row: 3;
      padding: 0 20px;
    }
    
    .home-content-2 {
      grid-column: 1 / 13;
      grid-row: 2;
    }

/* Mobile - About Us */
/* ------------------------------------------------------- */

.about-banner {
  grid-column: 1 / 13;
  grid-row: 1;
  position: relative;
  /* margin-bottom: 40px; */
}

.about-content-img {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 0;
}

.about-content-1 {
  grid-column: 2 / 12;
  grid-row: 3;
  margin: 0;
}

.about-content-2 {
  grid-column: 2 / 12;
  grid-row: 4;
  margin: 20px 0 40px 0;
}

.about-content-3 {
  grid-column: 2 / 12;
  grid-row: 5;
  text-align: center;
}

.about-content-4 {
  grid-column: 1 / 13;
  grid-row: 6;
  display: grid;
  grid-template-columns: 20px 1fr 1fr 1fr 20px;
  grid-template-rows: subgrid;
  text-align: center;
  gap: 20px;
  margin-bottom: 0;
  color: white;
}
    .about-content-4 .header{
      grid-column: 2 / 5;
      grid-row: 1;
      padding: 0 20px;
    }
    .about-content-4 .item-1{
      grid-column: 2 / 5;
      grid-row: 2;
    }

    .about-content-4 .item-2{
      grid-column: 2 / 5;
      grid-row: 3;
    }

    .about-content-4 .item-3{
      grid-column: 2 / 5;
      grid-row: 4;
    }

.about-content-5 {
  grid-column: 2 / 12;
  grid-row: 7;
  margin: 20px 0 50px;
}


/* Mobile - Services */
/* ------------------------------------------------------- */
.services-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: subgrid;
  text-align: left;
  gap: 40px;
  margin-bottom: 50px;
}

  .services-content-1 .item-1{
    grid-column: 1 / 8;
    grid-row: 2;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: subgrid;
  }
      .services-content-1 .item-1 .sub-item-1{
        grid-column: 1 / 3;
        grid-row: 1;
        margin-bottom: 10px;
      }
      
      .services-content-1 .item-1 .sub-item-2{
        grid-column: 1 / 3;
        grid-row: 2;
      }

      .services-content-1 .item-1 .sub-item-3{
        grid-column: 1 / 3;
        grid-row: 3;
      }

  .services-content-1 .item-2{
    grid-column: 1 / 8;
    grid-row: 1;
  }
  .product-content-3 .container {
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-bottom: 20px;
  }

.services-content-3 .list {
  display: grid;
  overflow: hidden;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 1fr;
  gap: 20px;
  width: 100%;
  padding-left: 0;
}


/* Tablet - Contact */
/* ------------------------------------------------------- */
.contact-content-1 {
  grid-column: 2 / 12;
  grid-row: 2;
  margin: 50px 0;
  text-align: center;
}

.contact-content-2 {
  grid-column: 2 / 12;
  grid-row: 3;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: subgrid;
}

.contact-content-2 .map {
  grid-column: 1 / 3;
  grid-row: 1;
}

.contact-content-2 .add {
  grid-column: 1 / 3;
  grid-row: 2;
  margin-top: 10px;
}

.contact-content-3 {
  grid-column: 2 / 12;
  grid-row: 4;
  margin-bottom: 50px;
}


/* Mobile - Footer */
/* ------------------------------------------------------- */
.footer-1 {
    grid-column: 1 / 7;
    grid-row: 2;
    display: grid;
    grid-template-columns: 50px 1fr 1fr 1fr 1fr 50px;
    grid-template-rows: subgrid;
    padding: 50px 0;
    gap: 20px;
}

.footer-1 .address{
    grid-column: 1 / 7;
    grid-row: 1;
    margin: 0 20px;
  }

  .footer-1 .products{
    grid-column: 1 / 7;
    grid-row: 2;
    margin: 0 20px;
  }
  .footer-1 .industry{
    grid-column: 1 / 7;
    grid-row: 3;
    margin: 0 20px;
  }
  .footer-1 .services{
    grid-column: 1 / 7;
    grid-row: 4;
    margin: 0 20px;
  }
  .footer-2 {
    height: 120px;
    }

  .footer-2 .copyright {
    margin-top: 0;
  }
}