
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

* {
    box-sizing: border-box;
      box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: Roboto;
    cursor: none;
    list-style: none;
    text-decoration: none;

}   

     @keyframes appear {
        from {
          opacity: 0;
          clip-path: inset(100% 100% 0 0);
        }
        to {
          
          opacity: 1;
          clip-path: inset(0 0 0 0);
        }
      }


      

    .imp {
      font-weight: bold;
      
    }
  


html {
  scroll-behavior: smooth;
}

.cursor-dot-black {
  width: 5px;
  height: 5px;
  background-color: rgb(0, 0, 0);
}

.cursor-outline-black {
  width: 30px;
  height: 30px;
  border: 2px solid hsla(0, 0%, 100%, 0.5);
}

.cursor-dot-black,
.cursor-outline-black {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50px;
  z-index: 1;
  pointer-events: none;
}



header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 10%;
    background-color: black;
}

.logo {
    
        font-weight: bold;
        font-size: 30px;
    color: white;
    text-decoration: none;
    transition: color 0.9s ease 0s;
}



.nav__links a,
.cta,
.cta1,
.overlay__content a {
    font-weight: 500;
    font-size: 23;
    color: white;
    text-decoration: none;
}

.nav__links {
    list-style: none;
    display: flex;
}

    .nav__links li {
        padding: 0px 27px;
       
    } 

    .nav__links li a {
        transition: color 0.9s ease 0s;
      
    }

    .nav__links li a:hover {
        border: solid white;
        border-radius: 50px;
        padding: 5px 5px 5px;
         transition: color 0.9s ease 0s;

   color: rgb(255, 255, 255);
   box-shadow: 0 0 18px rgb(133, 133, 133), 0 0 20px rgb(93, 93, 93), 0 0 30px rgb(105, 106, 106), 0 0 40px rgb(99, 99, 99);
  transition:  0.9s ease 0s;
       
    }
    
    .cta,
    .cta1 {
margin-right: -100px;
  background-color: rgb(255, 255, 255);
  color: black;
  border: none;
  border-radius: 50px;
    display: inline-block;
  padding: 10px 20px;
  font-size: 18px;
  color: #000000;
  background-color: #ffffff;
  border: none;

  text-align: center;
  transition:  1.5s ease 0s;
}

.cta1 {
   
margin-right: -260px;
  background-color: rgb(255, 255, 255);
  color: black;
  border: none;
  border-radius: 50px;
    display: inline-block;
  padding: 10px 20px;
  font-size: 18px;
  color: #000000;
  background-color: #ffffff;
  border: none;

  text-align: center;
  transition:  1.5s ease 0s;
}

.cta:hover {
   background-color: rgb(255, 255, 255);
   color: rgb(0, 0, 0);
   box-shadow: 0 0 20px rgb(133, 133, 133), 0 0 20px rgb(93, 93, 93), 0 0 30px rgb(105, 106, 106), 0 0 40px rgb(99, 99, 99);
  transition:  1.5s ease 0s;
   
}

.cta1:hover {
   background-color: rgb(255, 255, 255);
   color: rgb(0, 0, 0);
   box-shadow: 0 0 20px rgb(133, 133, 133), 0 0 20px rgb(93, 93, 93), 0 0 30px rgb(105, 106, 106), 0 0 40px rgb(99, 99, 99);
  transition:  1.5s ease 0s;
   
}

/* Mobile Nav */

.menu {
  display: none;
}

.overlay {
  height: 100%;
  width: 0;
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  background-color: #000000;
  overflow-x: hidden;
  transition: width 0.5s ease 0s;
}

.overlay--active {
  width: 100%;
}

.overlay__content {
  display: flex;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.overlay a {
  padding: 15px;
  font-size: 36px;
  display: block;
  transition: color 0.3s ease 0s;
}


.overlay a:hover,
.overlay a:focus {
  color: #646464;
}
.overlay .close {
  position: absolute;
  top: 20px;
  right: 45px;
  font-size: 60px;
  color: #edf0f1;
}

.slogan {
  text-align: center;
  font-weight: 300;
}

    .about-section {
            animation: appear linear;
        animation-timeline: view();
        animation-range: entry 0% cover 40%;
      align-items: center;
      background: #ffffff;
      padding: 60px;
      background-color: #ffffff;
      justify-content: center;
    }

    .about-section h2 {
      text-align: center;
      color: rgb(0, 0, 0);
      font-size: 60px;
      margin-top: 50px;
      margin-bottom: 8px;
    }

    .about-content {
      display: flex;
      align-items: center;
      justify-content: space-between;
      color: rgb(0, 0, 0);
      flex-wrap: wrap;
    }

    .about-text {
      flex: 1;
      padding: 20px;
      color: #000000;
      min-width: 300px;
    }

    .about-text p {
      font-size: 18px;
      color: #000000;
      line-height: 1.8;
      margin-top: -3px;
    }

    .about-image {
      flex: 1;
      min-width: 300px;
      margin-top: -50px;
      padding: 20px;
    }

    .about-image img {
      width: 40%;
      border-radius: 10px;
      margin-left: 300px;
      margin-top: 100px;
    }

    .read-more-btn {
      display: block;
      
      justify-self: center;
 
      padding: 20px 45px;
      margin-top: -10px;
      font-size: 18px;
      color: #ffffff;
      background-color: #000000;
      transition: background-color 0.9s ease 0s;
      border: none;
      border-radius: 50px;
      text-decoration: none;
      text-align: center;
    }


    .read-more-btn:hover {
      background-color: rgb(0, 0, 0);
   color: rgb(255, 255, 255);
   box-shadow: 0 0 10px rgb(0, 0, 0), 0 0 20px rgb(227, 227, 227), 0 0 30px rgb(0, 0, 0), 0 0 40px rgb(0, 0, 0);
  transition:  1.5s ease 0s;
    }









@media screen and (max-height: 450px) {

 
           .service .service_content h1 {
            font-size: 3.4rem;
    }

    .service .service_content{
      flex-direction: column;
      align-items: center;
    }

    .service .service_content h1, 
   .service .service_content p {
    width: 100%;
    text-align: center;
  }

  .service .service_content h1 {
            font-size: 2.5rem;
            margin-top: 10px;
            margin-bottom: 30px;
    }

    .cta1 {
      display: none;
    }
    .circle {
      display: none;
    }
      
         .cards {
    grid-template-columns: repeat(1,1fr); 
    margin: 0 auto;
  }

  .card {
    width: 80%;
  }

    .service .service_content h1 {
            font-size: 2rem;
    }

  .overlay {
    .cursor-dot-black {
  width: 5px;
  height: 5px;
  background-color: rgb(0, 0, 0);
}

.cursor-outline-black {
  width: 30px;
  height: 30px;
  border: 2px solid hsla(0, 0%, 100%, 0.5);
}

.cursor-dot-black,
.cursor-outline-black {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50px;
  z-index: 1;
  pointer-events: none;
}

  }
  .overlay a {
    font-size: 20px;
  }
  .overlay .close {
    font-size: 40px;
    top: 15px;
    right: 35px;
  }
.cursor-dot-black {
  width: 5px;
  height: 5px;
  background-color: rgb(0, 0, 0);
}

.cursor-outline-black {
  width: 30px;
  height: 30px;
  border: 2px solid hsla(0, 0%, 100%, 0.5);
}

.cursor-dot-black,
.cursor-outline-black {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50px;
  z-index: 1;
  pointer-events: none;
}

      .about-text p {
      font-size: 16px;
      text-align: center;
      align-items: center;
      color: #000000;
      line-height: 1.8;
  
      margin-right: 600px;
      margin-top: 10px;
    }

}

@media only screen and (max-width: 800px) {



           .service .service_content h1 {
            font-size: 3.4rem;
    }

    .service .service_content{
      flex-direction: column;
      align-items: center;
    }

    .service .service_content h1, 
   .service .service_content p {
    width: 100%;
    text-align: center;
  }

  .service .service_content h1 {
            font-size: 2.5rem;
            margin-top: 10px;
            margin-bottom: 30px;
    }

    .cta1 {
      display: none;
      margin: 0;
    }

    .circle {
      display: none;
    }
      
           .cards {
    grid-template-columns: repeat(1,1fr); 
    margin: 0 auto;
  }

  .card {
    width: 80%;
  }

    .service .service_content h1 {
            font-size: 2rem;
    }
  .nav__links,
  .cta {
    display: none;
    margin: 0;
    .cursor-dot-black {
  width: 5px;
  height: 5px;
  background-color: rgb(0, 0, 0);
}

.cursor-outline-black {
  width: 30px;
  height: 30px;
  border: 2px solid hsla(0, 0%, 100%, 0.5);
}

.cursor-dot-black,
.cursor-outline-black {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50px;
  z-index: 1;
  pointer-events: none;
}
  }

  .cursor-dot-black {
  width: 5px;
  height: 5px;
  background-color: rgb(0, 0, 0);
}

.cursor-outline-black {
  width: 30px;
  height: 30px;
  border: 2px solid hsla(0, 0%, 100%, 0.5);
}

.cursor-dot-black,
.cursor-outline-black {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  border-radius: 50px;
  z-index: 1;
  pointer-events: none;
}
  .menu {
    display: initial;
  }

      .about-section h2 {
      text-align: center;
      align-items: center;
      color: rgb(0, 0, 0);
      font-size: 42px;
      align-items: center;
      margin-top: -30px;
    }

    .about-section h4 {
      margin-top: 24px;
      text-align: center;
    }

        .about-image {
      flex: 1;
      min-width: 300px;
      margin-top: -50px;
      padding: 20px;
    }

    .about-image img {
      width: 80%;
      border-radius: 10px;
      margin-left: 10px;
      margin-top: 100px;
    


    .about-content {
      display: flex;
      align-items: center;
      justify-content: space-between;
      color: rgb(0, 0, 0);
      flex-wrap: wrap;
    }

      .about-text p {
      font-size: 16px;
      text-align: center;
      align-items: center;
      color: #000000;
      line-height: 1.8;
  
      margin-right: 600px;
      margin-top: 10px;
    }

    .about-section {
      align-items: center;
      background: #ffffff;
      
      padding: 60px;
      background-color: #ffffff;
      justify-content: center;
    }
}


      .about-text p {
      font-size: 16px;
      text-align: center;
      align-items: center;
      color: #000000;
      line-height: 1.8;
  
      margin-right: 30px;
      margin-top: 10px;
    }

}
.cursor2 {
    height: 90vh;
   display: flex;
   align-items: center;
   text-align: center;
   justify-content: center;
   background-color: #000000;
   border-bottom: solid white;
  }

  .cursor2 div{
   
  padding-bottom: 60px;
  align-items: center;
  text-align: center;
  justify-content: center;
  
  color: #ffffff;
  }


  .cursor2 h1{
    background: #000000;
    background: linear-gradient(to top, #000000 0%, #E1E1E1 70%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 60px;
      align-items: center;
      
   text-align: center;
   justify-content: center;
    font-weight: bold;
    text-align: center;
     }

   .cursor2 h4 {
    margin-top: 10px;
 
    background: linear-gradient(to top, #000000 0%, #E1E1E1 60%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 25px;
    text-align: center;
    font-weight: 400;
    align-items: center;
    justify-content: center;
    align-content: center;
   }


   .cursor2 i {
    color: #ffffff;
    justify-content: center;
    align-content: center;
    padding-top: 20px;
    font-size: 30px;
   }
  

   .service {
          animation: appear linear;
        animation-timeline: view();
        animation-range: entry 0% cover 40%;
    min-height: 100vh;
    width: 100%;
    display: flex;
    position: relative;
    flex-direction: column;
    padding: 7rem 8%;
    color: white;
    background-color: black;
    overflow: hidden;
   }

   .service .service_content {
    display: flex;
    justify-content: space-between;
    margin: 5rem 0;
    overflow: hidden;
   }


   .service .service_content h1 {
    font-size: 3.7rem;
    line-height: 3.7rem;
    letter-spacing: 1px;
    width: 40%;
   }

   .service .service_content p {
    width: 40%;
   }


   .cards {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 20px;
   }


   .cards .card {
    height: 220px;
    width: 420px;
    border: 0.5px solid rgba(255, 255, 255, 0.5);
    border-radius: 28px;
    z-index: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 3rem 8%;
    background-color: transparent;
    overflow: hidden;
    transition: .6s;
   }

   .flas {
    font-weight: 400;
   }
   .cards .card:after {
    position: absolute;
    content: "";
    height: 40%;
    width: 8%;
    top: 30%;
    right: -4%;
    background-color: #fff;
    z-index: -1;
    border-radius: 28px;
    transition: .6s;

   }

  .cards .card:hover {
    color: black;
  }

  .cards .card:hover:after {
    height: 100%;
    width: 100%;
    top: 0%;
    right: 0%;
  }









     .cards .card h3{
      font-size: 1.5rem;
      letter-spacing: 1px;
      margin-bottom: 16px;
     }

     .cards .card ul li {
      margin-left: 12px;
     }
    .cards .card ul li i{
      margin-right: 8px;
    }

    .circle {
      height: 750px;
      width: 750px;
      border: 150px solid rgba(255, 255, 255, 0.1);
      border-radius: 50%;
      position: fixed;
      top: 48%;
      left: 80%;
    }

        @media(max-width:1200px){

          footerNav{
    margin: 300px 0;
}
.footerNav ul{
    display: flex;
    justify-content: center;
    margin-left: -17px;
    list-style-type: none;
}
.footerNav ul li a{
    color:rgb(255, 255, 255);

    text-decoration: none;
    font-size: 1.3em;
    opacity: 0.7;
    transition: 0.5s;

}



                 .cards {
    grid-template-columns: repeat(2,1fr); 
    margin: 0 auto;
  }
        }

    @media(max-width:1100px){
         .service .service_content h1 {
            font-size: 3.4rem;
    }

    .service .service_content{
      flex-direction: column;
      align-items: center;
    }

    .service .service_content h1, 
   .service .service_content p {
    width: 100%;
    text-align: center;
  }

  .service .service_content h1 {
            font-size: 2.5rem;
            margin-top: 10px;
            margin-bottom: 30px;
    }

  

    .circle {
      display: none;
    }
      
  }


    @media(max-width:900px){

       .cards {
    grid-template-columns: repeat(1,1fr); 
 
  }

  .cards .card {
  height: 200px;
    width: 300px;
    padding: 2rem 10%;
    border-radius: 28px;
   
  }

    .service .service_content h1 {
            font-size: 2rem;
    }

    
    }

footer{
    background-color: #000000;
}
.footerContainer{
    width: 100%;
    padding: 70px 30px 20px ;
}
.socialIcons{
    display: flex;
    justify-content: center;
}
.socialIcons a{
    text-decoration: none;
    padding:  10px;
    background-color: white;
    margin: 10px;
    border-radius: 50%;
}
.socialIcons a i{
    font-size: 2em;
    color: black;
    opacity: 0,9;
}
/* Hover affect on social media icon */
.socialIcons a:hover{
    background-color: #000000;
    transition: 0.5s;
}
.socialIcons a:hover i{
    color: white;
    transition: 0.5s;
}
.footerNav{
    margin: 30px 0;
}
.footerNav ul{
    display: flex;
    justify-content: center;
    list-style-type: none;
}
.footerNav ul li a{
    color:white;
    margin: 20px;
    text-decoration: none;
    font-size: 1.3em;
    opacity: 0.7;
    transition: 0.5s;

}
.footerNav ul li a:hover{
    opacity: 1;
}
.footerBottom{
    background-color: #000;
    padding: 20px;
    text-align: center;
}
.footerBottom p{
    color: white;
}
.designer{
    opacity: 0.7;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 400;
    margin: 0px 5px;
}
@media (max-width: 700px){
    .footerNav ul{
        flex-direction: column;
    } 
    .footerNav ul li{
        width:100%;
        text-align: center;
        margin: 10px;
    }
    .socialIcons a{
        padding: 8px;
        margin: 4px;
    }
}


.cta20 {

 
}

#section-wrapper{
        animation: appear linear;
        animation-timeline: view();
        animation-range: entry 0% cover 40%;
    width: 100%;
    padding: 10px;
}
.box-wrapper{
        animation: appear linear;
        animation-timeline: view();
        animation-range: entry 0% cover 40%;
    position: relative;
    display: table;
    width:1100px;
    margin:auto;
    margin-top:35px;
    margin-bottom:35px;
    border-radius: 30px;
}
.info-wrap{
    width:35%;
    height: 551px;
    padding: 40px;
    float: left;
    display: block;
    border-radius: 30px 0px 0px 30px;
    background: linear-gradient(144deg, rgb(255, 255, 255) 0%, rgb(0, 0, 0) 49%);
    color: #fff;
}
.info-title{
    text-align: left;
    font-size: 28px;
    letter-spacing: 0.5px;
}
.info-sub-title{
    font-size: 18px;
    font-weight: 300;
    margin-top: 17px;
    letter-spacing: 0.5px;
    line-height: 26px;
}
.info-details {
    list-style: none;
    margin: 60px 0px;
}
.info-details li {
    margin-top: 25px;
    font-size: 18px;
    color: #fff;
}
.info-details li i {
    background: #ffffff;
    color: black;
    padding: 12px;
    border-radius: 50%;
    margin-right: 5px;
}
.info-details li a {
    color: #fff;
    text-decoration: none;
    transition: .6s;
}
.info-details li a:hover {
    border-bottom: solid white;
}
.social-icons {
    list-style: none;
    text-align: center;
    margin: 20px 0px;
}
.social-icons li {
    display: inline-block;
}
.social-icons li i {
    background: #ffffff;
    color: #000000;
    padding: 15px;
    font-size: 20px;
    border-radius: 22%;
    margin: 0px 5px;
    cursor: pointer;
    transition: all .5s;
}
.social-icons li i:hover {
    color: rgb(0, 0, 0);
   box-shadow: 0 0 18px rgb(133, 133, 133), 0 0 20px rgb(93, 93, 93), 0 0 30px rgb(105, 106, 106), 0 0 40px rgb(99, 99, 99);
  transition:  0.9s ease 0s;
}
.form-wrap{
    width:65%;
    float: right;
    padding:40px 25px 35px 25px;

    border: solid black 1px;
    border-radius: 0px 30px 30px 0px;
    background: #ffffff;
    box-shadow: inset 8px 8px 8px #cbced1, inset -8px -8px 8px #ffffff;
}
.form-title{
    text-align: left;
    margin-left: 23px;
    font-size: 28px;
    letter-spacing: 0.5px;
}
.form-fields{
    display: table;
    width: 100%;
    padding: 15px 5px 5px 5px;
}
.form-fields input,
.form-fields textarea{
    border: none;
    outline:none;
    background: none;
    font-size: 18px;
    color:#555;
    padding: 20px 10px 20px 5px;
    width:100%
}
.form-fields textarea{
    height: 150px;
    resize: none;
}
.form-group{
    width: 46%;
    float: left;
    padding: 0px 30px;
    margin: 14px 12px;
    border-radius: 25px;
    box-shadow: inset 8px 8px 8px #cbced1, inset -8px -8px 8px #ffffff;
}
.form-fields .form-group:last-child {
    width: 96%;
}
.submit-button{
    width: 96%;
    height: 60px;
    margin: 0px 12px;
    border-radius: 30px;
    font-size: 20px;;
    font-weight: 700;
    outline: none;
    border:none;
    cursor: pointer;
    color:#fff;
    text-align: center;
    background: #000000;
    box-shadow: 3px 3px 8px #b1b1b1, -3px -3px 8px #ffffff;
    transition: .5s;
}
.submit-button:hover{
        color: rgb(255, 255, 255);
   box-shadow: 0 0 18px rgb(133, 133, 133), 0 0 20px rgb(93, 93, 93), 0 0 30px rgb(105, 106, 106), 0 0 40px rgb(99, 99, 99);
  transition:  0.9s ease 0s;
}


span {
  font-weight: bold;
}


/* Responsive css */

@media only screen and (max-width: 767px) {

    .box-wrapper{
        width: 100%;
    }
    .info-wrap,
    .form-wrap{
        width: 100%;
        height: inherit;
        float: none;  
    }
    .info-wrap{
        border-radius: 30px 30px 0px 0px;
    }
    .form-wrap{
        border-radius: 0px 0px 30px 30px;
    }
    .form-group{
        width: 100%;
        float: none;
        margin: 25px 0px;
    }
    .form-fields .form-group:last-child, 
    .submit-button{
        width: 100%;
    }
    .submit-button{
        margin: 10px 0px;
    }
   
}