*,
*::after,
*::before {
  margin: 0;
  padding: 0;
  box-sizing: inherit; }

html {
  font-size: 62.5%; }

body {
  box-sizing: border-box; }

body {
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  /*font-size: 16px;*/
  line-height: 1.7;
  color: #777;
  background-color: #EEEEEE;
}

.images {
  width: 100%;
  height: auto;
}

*  SECTIONS  */
.section {
  clear: both;
  padding: 0px;
  margin: 0px;
}

/*  COLUMN SETUP  */
.col {
  display: block;
  float:left;
  margin: 1% 0 1% 3%;
}
.col:first-child { margin-left: 0; }

/*  GROUPING  */
.group:before,
.group:after { content:""; display:table; }
.group:after { clear:both;}
.group { zoom:1; /* For IE 6/7 */ }

/*  GRID OF THREE  */
.span_3_of_3 { width: 100%; }
.span_2_of_3 { width: 65.66%; }
.span_1_of_3 { width: 31.33%; margin-bottom: 7rem;}

.span_1_of_3:nth-child(3n+1) { 
	clear:both; 
  margin-left: 0;
	}

/*  GO FULL WIDTH BELOW 480 PIXELS */
@media only screen and (max-width: 480px) {
	.col {  margin: 1% 0 1% 0%; }
	.span_3_of_3, .span_2_of_3, .span_1_of_3 { width: 100%; margin-bottom: 5rem;}
}

  .header {
      height: 95vh;
      background-image: linear-gradient(to bottom, rgba(51, 51, 51, 0.8),rgba(51,51,51, 0.3)), url(../asset/bg_top_dua.jpg);
      background-size: cover;
      background-position: top;
      background-attachment: fixed;
      position: relative;
      /*-webkit-clip-path: polygon(0 0, 100% 0, 100% 75vh, 0 100%);
      clip-path: polygon(0 0, 100% 0, 100% 75vh, 0 100%); */
    }
    
      .header__logo-box {
        position: absolute;
        top: 4rem;
        left: 4rem; }
      .header__logo {
        height: 3.5rem; }
      .header__text-box {
        position: absolute;
        top: 40%;
        left: 50%;
        transform: translate(-50%, -50%);
        text-align: center; }

  .heading-primary {
    color: #fff;
    text-transform: uppercase;
    backface-visibility: hidden;
    margin-bottom: 6rem; }
    .heading-primary--main {
      display: block;
      font-size: 5rem;
      font-weight: 400;
      /*letter-spacing: 3.5rem;*/
      animation-name: moveInLeft;
      animation-duration: 1s;
      animation-timing-function: ease-out;
      /*
          animation-delay: 3s;
          animation-iteration-count: 3;
          */ }
    .heading-primary--sub {
      display: block;
      font-size: 2rem;
      font-weight: 700;
      letter-spacing: 1.55rem;
      animation: moveInRight 1s ease-out; }

    .heading-secondary {
    font-size: 3.5rem;
    text-transform: uppercase;
    font-weight: 700;
    display: inline-block;
    background-image: linear-gradient(to right, #7ed56f, #28b485);
    -webkit-background-clip: text;
    color: transparent;
    letter-spacing: .2rem;
    transition: all .2s; }
    .heading-secondary:hover {
      transform: skewY(2deg) skewX(15deg) scale(1.1);
      text-shadow: 0.5rem 1rem 2rem rgba(0, 0, 0, 0.2); }

    .heading-tertiary {
    font-size: 1.6rem;
    font-weight: 700;
    text-transform: uppercase; }

    .btn, .btn:link, .btn:visited {
      text-transform: uppercase;
      text-decoration: none;
      padding: 1.5rem 4rem;
      display: inline-block;
      border-radius: 10rem;
      transition: all .2s;
      position: relative;
      font-size: 1.6rem;
      border: none;
      cursor: pointer; }
    
    .btn:hover {
      transform: translateY(-3px);
      box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.2); }
      .btn:hover::after {
        transform: scaleX(1.4) scaleY(1.6);
        opacity: 0; }
    
    .btn:active, .btn:focus {
      outline: none;
      transform: translateY(-1px);
      box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); }
    
    .btn--white {
      background-color: #fff;
      color: #777; }
      .btn--white::after {
        background-color: #fff; }
    
    .btn--green {
      background-color: #55c57a;
      color: #fff; }
      .btn--green::after {
        background-color: #55c57a; }
    
    .btn::after {
      content: "";
      display: inline-block;
      height: 100%;
      width: 100%;
      border-radius: 10rem;
      position: absolute;
      top: 0;
      left: 0;
      z-index: -1;
      transition: all .4s; }
    
    .btn--animated {
      animation: moveInBottom .5s ease-out .75s;
      animation-fill-mode: backwards; }
    
    .btn-text:link, .btn-text:visited {
      font-size: 1.6rem;
      color: #55c57a;
      display: inline-block;
      text-decoration: none;
      border-bottom: 1px solid #55c57a;
      padding: 3px;
      transition: all .2s; }
    
    .btn-text:hover {
      background-color: #55c57a;
      color: #fff;
      box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.15);
      transform: translateY(-2px); }
    
    .btn-text:active {
      box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
      transform: translateY(0); }

  .about {
    background-color: #212121;
    font-size: 1.75rem;
    font-weight: 300;
    color: #FFF;
    padding : 8rem;
    text-align: center; 
  }
    .about-primary {
      color: #FFF;
      backface-visibility: hidden;
      margin-bottom: 6rem; }
      .about-primary--main {
        font-family: 'Lora', serif;
        display: block;
        font-size: 6rem;
        font-weight: 700;
        /*letter-spacing: 3.5rem;*/
        animation-name: moveInLeft;
        animation-duration: 1s;
        animation-timing-function: ease-out;
        /*
            animation-delay: 3s;
            animation-iteration-count: 3;
            */ }
  
  .services {
    background-color: #F2F2F2;
    font-size: 1.5rem;
    font-weight: 300;
    color: rgb(39, 39, 39);
    padding : 8rem;
    text-align: center; 
  }
    .services-primary {
      color: #393939;
      backface-visibility: hidden;
      margin-bottom: 6rem; }
      .services-primary--main {
        font-family: 'Lora', serif;
        display: block;
        font-size: 6rem;
        font-weight: 700;
        /*letter-spacing: 3.5rem;*/
        animation-name: moveInLeft;
        animation-duration: 1s;
        animation-timing-function: ease-out;
        /*
            animation-delay: 3s;
            animation-iteration-count: 3;
            */ }
      
        .services-secondary--awesome {
          font-size: 7rem;
          padding-bottom: 2rem;
          color: #393939;
        }

        .services-third {
          font-family: 'Lora', serif;
          font-size : 2rem;
          font-weight: 700;
          color: #777;   
          padding-bottom: 1rem;     
        }
  
  .portfolio {
    background-color: #EEEEEE;
    font-size: 1.5rem;
    font-weight: 300;
    color: rgb(39, 39, 39);
    padding : 8rem;
    text-align: center; 
  }
    .portfolio-primary {
      color: #393939;
      backface-visibility: hidden;
      margin-bottom: 6rem; }
      .portfolio-primary--main {
        font-family: 'Lora', serif;
        display: block;
        font-size: 6rem;
        font-weight: 700;
        /*letter-spacing: 3.5rem;*/
        animation-name: moveInLeft;
        animation-duration: 1s;
        animation-timing-function: ease-out;
        /*
            animation-delay: 3s;
            animation-iteration-count: 3;
            */ }
      
        .portfolio-secondary--awesome {
          font-size: 7rem;
          padding-bottom: 2rem;
          color: #393939;
        }

        .portfolio-third {
          font-family: 'Lora', serif;
          font-size : 2rem;
          font-weight: 700;
          color: #777;   
          padding-bottom: 1rem;     
        }

        /*Filter*/
        .filter a {
          padding: 10px 20px;
          display: inline-block;
          color: #003;
          background: #eee;
          text-decoration: none;
          transition: all 0.2s;
          border-radius: 9px;
          margin-top: 0px;
        }

        .filter a:hover { background: #8ad }

        .filter {
          padding: 10px;
          text-align: center;
        }

        .gallery a img {
          width: 100%;
          height: auto;
          padding: 15px;
        }

        .gallery a {
          width: 50%;
          transition: all 0.2s;
          display: block;
          float: left;
          opacity: 1;
        }

        .gallery .hide, .gallery .pophide {
          width: 0%;
          opacity: 0;
          transition: all 0.1s;
        }

        .gallery .pop {
          width: 100%;
          position: relative;
          z-index: 2;
          box-shadow: 0 0 0px 1000px rgba(0,0,0,0.5);
        }

        /*.gallery:after {
          content: "\00D7";
          position: absolute;
          top: 10px;
          right: 10px;
          color: #333;
          background: #fff;
          padding: 10px 15px;
          border-radius: 50%;
          opacity: 0.8;
        }*/
  
  .contact {
    background-color: #212121;
    font-size: 1.6rem;
    font-weight: 200;
    color: azure;
    padding : 8rem;
    text-align: center; 
  }
    .contact-primary {
    color: azure;
    backface-visibility: hidden;
    margin-bottom: 6rem; }
    .contact-primary--main {
      font-family: 'Lora', serif;
      display: block;
      font-size: 6rem;
      font-weight: 700;
      /*letter-spacing: 3.5rem;*/
      animation-name: moveInLeft;
      animation-duration: 1s;
      animation-timing-function: ease-out;
      /*
          animation-delay: 3s;
          animation-iteration-count: 3;
          */ }
  
      .contact-third {
        font-family: 'Lora', serif;
        font-size : 2rem;
        font-weight: 700;
        color: azure;   
        padding-bottom: 1rem;     
      }
    .contact__form-box {
      text-align: center;
      color: azure;
      }

    /*Contact Form*/
    form { max-width:490px; margin: 0 auto;}

    .feedback-input {
      color:white;
      border-radius: 5px;
      line-height: 22px;
      background-color: transparent;
      border:2px solid #999;
      transition: all 0.3s;
      padding: 13px;
      margin-bottom: 15px;
      width:100%;
      box-sizing: border-box;
      outline:0;
    }

    .g-recaptcha {
      padding-bottom: 30px;
    }

    .feedback-input:focus { border:2px solid #CC4949; }

    textarea {
      height: 150px;
      line-height: 150%;
      resize:vertical;
    }

    [type="submit"] {
      font-family: 'Lora', serif;
      width: 17rem;
      background: azure;
      border-radius:5px;
      border:0;
      cursor:pointer;
      color: #212121;
      font-size: 3rem;
      font-variant: small-caps;
      padding-top:10px;
      padding-bottom:10px;
      transition: all 0.3s;
      margin-top:-4px;
      font-weight:500;
    }
    [type="submit"]:hover { color:#999; }


    .clear {
      clear: both;
    }



/*RESPONSIVE SYSTEM*/
@media screen and (max-width:1000px){

  #rc-imageselect, .g-recaptcha {transform:scale(0.77);-webkit-transform:scale(0.77);transform-origin:0 0;-webkit-transform-origin:0 0;}

  

}

/*Potrait Tablet to Landscape Desktop*/
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {

  .col {  margin: 1% 0 1% 0%; }
  .span_3_of_3, .span_2_of_3, .span_1_of_3 { width: 100%; }

  
  

}

/*Landscape Phone to Potrait Tablet, iPhone*/
@media (max-width: 767px) {

  .col {  margin: 1% 0 1% 0%; }
  .span_3_of_3, .span_2_of_3, .span_1_of_3 { width: 100%; }

  .about, .services, .portfolio, .contact {padding: 3rem}
  .about-primary--main, .services-primary--main, .portfolio-primary--main, .contact-primary--main {font-size: 3.5rem}


}

/*Landscape Phone and Down*/)
@media only screen and (max-width: 480px) {

  .col {  margin: 1% 0 1% 0%; }
  .span_3_of_3, .span_2_of_3, .span_1_of_3 { width: 100%; }

  .about, .services, .portfolio, .contact {padding: 3rem}
  .about-primary--main, .services-primary--main, .portfolio-primary--main, .contact-primary--main {font-size: 3.5rem}

}