@charset "utf-8";
/* CSS Document */
html {
  overflow-x:hidden;
  scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    background-color: #f5f5f5;
    line-height: 1.7;
}

section {
	padding:8em 0;
	overflow: hidden;
}

p {
  font-family: 'Roboto', sans-serif;
  color:#1e1e1e;
}

img {
	max-width: 100%;
	height: auto;
}

h1,h2,h3,h4,h5,h6 {
  font-family: 'Titillium Web', sans-serif;
  font-weight: 900;
}

.about-us-link a {
  color:#212529!important;
}

.orange {
	color: #D4431D;
}

.green {
	color: #023b4c;
}

.font-4em {
  font-size: 3.3em!important;
}

.font-3em {
  font-size: 2.5em!important;
}

.brown-bg {
  background-color:#f7f4f0;
}

.grey-bg {
  background-color:#fff9ee;
  color: white;
}

#map {
  height: 200px;  /* The height is 400 pixels */
  width: 100%;  /* The width is the width of the web page */
}

/*<!-- Navigation -->*/
.hm-gradient {
    background-image: linear-gradient(to top, #f3e7e9 0%, #e3eeff 99%, #e3eeff 100%);
}
.navbar .dropdown-menu a:hover {
    color: #616161 !important;
}
.darken-grey-text {
    color: #2E2E2E;
}

.nav-position {
  position: fixed;
  z-index: 3;
  width: 100%;
  max-height: 70px;
  transition:1s ease;
}

.nav-position li {
  padding-right: 3em;
}

.nav-shadow {
  box-shadow:0px 1px 10px #999;
}

.dropdown-menu {
  background-color: #f5f5f5;
 }

/*<!-- Navigation -->*/


/*<!-- Video Header -->*/
header {
  position: relative;
  background-color: black;
  height: 100vh;
  min-height: 25rem;
  width: 100%;
  overflow: hidden;
}


header video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;
  -ms-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

header img {
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;
}

header .container {
  position: relative;
  z-index: 2;
}

header .overlay {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: black;
  opacity: 0.4;
  z-index: 1;
}

.background-img {
  -webkit-animation: zoomout 2s ease-out;
  animation: zoomout 2s ease-out;
  transition: all .5s ease-in-out;
  overflow: hidden;
  object-fit: cover;
}


/* Zoom out Keyframes */
@-webkit-keyframes zoomout {
  0% {transform: scale(1.15);}
  100% {transform: scale(1);}
}
@keyframes zoomout {
    0% {transform: scale(1.15);}
  100% {transform: scale(1);}
}/*End of Zoom out Keyframes */


/*UPLOAD TO TEST SERVER AND SEE IF MOBILE CAN PLAY VIDEO. IF CAN, FUCK THIS CODE OFF :D; */
@media (pointer: coarse) and (hover: none) {
  header {
    background: url('https://source.unsplash.com/Mu9uo42SXEY/1600x900') black no-repeat center center scroll;
  }
  header video {
    display: none;
  }
}

/*<!-- Quick Contact Phone -->*/
.quick_contact a {
  position: fixed;
  width: 40px;
  height: 40px;
  right: 19px;
  bottom: 22px;
  color: #fff;
  border-radius: 50px;
  text-align: center;
  font-size: 20px;
  box-shadow: 0px 10px 20px rgba(0, 0, 0, 0.2);
  z-index: 100;
  transition: transform 0.5s ease;
}

.qcall {
  bottom: 120px;
}
.quick_contact_icon {
  margin-top: 10px;
}
.quick_contact a:hover {
  transform: scale(1.1);
}

.quick_contact span {
    font-size: 1.5em;
    text-align: center;
    font-weight: bold;
    color: #fff;
    background: #2196f3; /* change background color of text */
    padding: 0 5px 0;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}
/*<!-- Quick Contact Phone -->*/




/*<!-- Arrow Pointer -->*/
.arrows {
  width: 60px;
  height: 72px;
  position: absolute;
  left: 50%;
  margin-left: -30px;
  bottom: 20px;
}

.arrows path {
  stroke: white;
  fill: transparent;
  stroke-width: 1px;  
  animation: arrow 2s infinite;
  -webkit-animation: arrow 2s infinite; 
}

@keyframes arrow
{
0% {opacity:0}
40% {opacity:1}
80% {opacity:0}
100% {opacity:0}
}

@-webkit-keyframes arrow /*Safari and Chrome*/
{
0% {opacity:0}
40% {opacity:1}
80% {opacity:0}
100% {opacity:0}
}

.arrows path.a1 {
  animation-delay:-1s;
  -webkit-animation-delay:-1s; /* Safari 和 Chrome */
}

.arrows path.a2 {
  animation-delay:-0.5s;
  -webkit-animation-delay:-0.5s; /* Safari 和 Chrome */
}

.arrows path.a3 { 
  animation-delay:0s;
  -webkit-animation-delay:0s; /* Safari 和 Chrome */
}


/*<!-- Buttons -->*/
.button {
  border: none;
  color: white;
  padding: 10px 35px; 
  max-width: 100%;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  cursor: pointer;
}

.btn.rounded {
  border-radius: 60px!important;
}

.orange-button {
  color: #D4431D;
}

.green-button {
  color: #023b4c;
}

.btn.rounded.outline {
    background-color: transparent;
    border: 2px solid #D4431D;}
.btn.rounded.outline:hover {
    background-color: #D4431D;
    border-color: #D4431D;
    color:white;  }

.btn.rounded.outline.greeny {
    background-color: transparent;
    border: 2px solid #023b4c;}
.btn.rounded.outline.greeny:hover {
    background-color: #023b4c;
    border-color: #023b4c;
    color:white;  }


/*<!-- Slider -->*/
.head-slider {
  box-sizing: border-box;
}

.slider-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  font: 16px / 1.5 'Helvetica Neue', sans-serif;
}

.slider {
  width: 100%;
  overflow-x: hidden;
}


.slider-container {
  display: inline-flex;
  padding: 0 0;
  flex-direction: row;
}

.item {
  width: 500px;
  height: 100%;
  flex-shrink: 0;
  margin: 0 2rem;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

.img-wrap {
  display: inline-block;
  overflow: hidden;
}

.img-zoom {
  transition: transform 1.5s ease-out;
}

.img-zoom:hover {
  transform: scale(1.2);
}


.img-move-1 {
  transition: transform 1.5s ease-out;
}

.img-button-1:hover ~ .img-move-1 {
  transform: translateY(2rem)
  transform: scale(1.2);
}
.contact_success {
    height: 50vh !important;
}
/*<!-- Footer -->*/
.site-footer
{
  background-color:#023b4c;
  padding:5em 0 3em;
  font-size:15px;
  line-height:30px;
  color:white;
}
.site-footer hr
{
  border-top-color:#bbb;
  opacity:0.5
}
.site-footer hr.small
{
  margin:20px 0
}
.site-footer h6
{
  color:#fff;
  font-size:16px;
  text-transform:uppercase;
  margin-top:5px;
  letter-spacing:2px
}
.site-footer a
{
  color:white;
}
.site-footer a:hover
{
  color:#ced4da;
  text-decoration:none;
}
.footer-links
{
  padding-left:0;
  list-style:none
}
.footer-links li
{
  display:block
}
.footer-links a
{
  color:white;
}
.footer-links a:active,.footer-links a:focus,.footer-links a:hover
{
  color:#ced4da;
  text-decoration:none;
}
.footer-links.inline li
{
  display:inline-block
}

.copyright-text
{
  margin:0
}
@media (max-width:991px)
{
  .site-footer [class^=col-]
  {
    margin-bottom:30px
  }
}
@media (max-width:767px)
{
  .site-footer
  {
    padding-bottom:0
  }
  .site-footer .copyright-text,.site-footer .social-icons
  {
    text-align:center
  }
}

.green-line {
    border-top: 3px solid #023b4c;
    width: 20px;
    text-align: left;
    margin-left: 0;
}

.orange-line {
    border-top: 3px solid #D4431D;
    width: 20px;
    text-align: left;
    margin-left: 0;
}

.errormsg {
    margin-top: 80px;
    margin-bottom: 80px;
    text-align: center;
}



@media only screen and (min-width: 1024px) {
  .gutter-text {
    padding:0 9em 0em; 
  }
  .home-roof {
    text-align: center;
    max-width: 500px;
    background: white;
    padding:3em;
  }
  .padding-0 {
    padding-right: 0;
    padding-left: 0;
  }
  .home-metal {
    text-align: center;
    background: white;
    border-bottom: 18px solid #023b4c;
    padding:3em;
  }
  .home-service {
    margin: 0 2rem;
  }

  .header-text {
    font-size: 4.7em;
    letter-spacing: 3px;
  }
  .header-p {
    font-size: 2.2em;
  }
  .home-align-1 {
    left: -3em;
    top: 6em;
  }
  .home-align-2 {
    left: -9em;
  }
  .padding-2em {
  padding-top: 2em;
}
  .padding-3em {
  padding-top: 3em;
}
  .margin-top-desktop-2em {
    margin-top: 2em;
  }
  .margin-top-desktop-3em {
    margin-top: 3em;
  }
  .about-us-text {
    font-size: 1.2em;
    line-height: 2em;
  }
  .about-us-box {
    background: white;
    padding: 1.5em 2.8em;
  }
  .metal-link-text {
    font-size: 2em;
    line-height: 1.3em;
    font-weight: 600;
  }
  .skylight-position {
    top: -3em;
  }
  .padding-desktop-btm {
    padding-bottom: 2em;
  }
  .padding-desktop-btm-1em {
    padding-bottom: 1em;
  }
  .factory-roof-textbox {
    background: white;
    padding: 5em 4em;
    top: -6em;
    right: -3em;
    z-index: 2;
  }
  .factory-roof-textbox-2{
    background: white;
    padding: 2em 3em;
    z-index: 2;
    top: 1em;
  }
  .factory-roof-textbox-3 {
    background: white;
    padding: 4em 4em;
    left: -4em;
  }
  .gutter-textbox {
    background: white;
    padding: 2em 2em;
  }
}

@media only screen and (max-width: 1023px) {
  .desktop-only {
    display:none;
  }
  .collapse.show {
    background: #f5f5f5;
    padding: 1em;
    border-radius: 0.75em;
  }
  .nav-link {
    color: black!important;
  }
  .navbar-toggler {
    background: rgba(0,0,0,0.5);
  }
  .item {
    width: 450px;
    height: 100%;
    flex-shrink: 0;
    margin: 0 2em 0 0em;
  }
  .padding-1em-side {
    padding:0 1em;
  }
  .tablet-padding-left{
        padding: 0 0 0 2em;
  }
  .about-us-box {
    background: white;
    padding: 1em 1.7em;
  }
  .about-us-text {
    font-size: 1.1em;
    line-height: 2em;
  }
  .metal-link-text {
    font-size: 1.5em;
    font-weight: 600;
  }
  .padding-2em-tablet {
    padding-top: 3em;
  }
  .padding-2em-tablet-btm {
    padding-bottom:2em;
  }
  .gutter-textbox {
    background: white;
    padding: 1em 1em;
  }
  .margin-top-desktop-2em {
    margin-top:2em;
  }
}


@media only screen and (max-width: 767px) {
  
  .mobile-35-padding {
    padding:0 35px;
  }
  .collapse.show {
    background: #f5f5f5;
    padding: 1em;
    border-radius: 0.75em;
  }
  .navbar-toggler {
    background: rgba(0,0,0,0.5);
  }
  .nav-link {
    color: black!important;
  }
  .desktop-only {
    display:none;
  }
  .padding-2em-mobile {
    padding-top: 2em;
  }
  .flex-order-rev {
    flex-direction: column-reverse;
  }
  .item {
    width: 290px;
    height: 100%;
    flex-shrink: 0;
    margin: 0 2em 0 0em;
  }
  .padding-1em-side {
    padding:0 1em;
  }
  section {
  padding: 4em 0;
}
  .about-us-box {
    background: white;
  }
  .about-us-text {
    font-size: 1em;
    line-height: 2em;
  }
  .metal-link-text {
    font-size: 1.4em;
    font-weight: 600;
  }


/*<!-- Loader-Homepage -->*/
#loader-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
}
#loader {
    display: block;
    position: relative;
    left: 50%;
    top: 50%;
    width: 150px;
    height: 150px;
    margin: -75px 0 0 -75px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #3498db;

    -webkit-animation: spin 2s linear infinite; /* Chrome, Opera 15+, Safari 5+ */
    animation: spin 2s linear infinite; /* Chrome, Firefox 16+, IE 10+, Opera */

    z-index: 1001;
}

    #loader:before {
        content: "";
        position: absolute;
        top: 5px;
        left: 5px;
        right: 5px;
        bottom: 5px;
        border-radius: 50%;
        border: 3px solid transparent;
        border-top-color: #e74c3c;

        -webkit-animation: spin 3s linear infinite; /* Chrome, Opera 15+, Safari 5+ */
        animation: spin 3s linear infinite; /* Chrome, Firefox 16+, IE 10+, Opera */
    }

    #loader:after {
        content: "";
        position: absolute;
        top: 15px;
        left: 15px;
        right: 15px;
        bottom: 15px;
        border-radius: 50%;
        border: 3px solid transparent;
        border-top-color: #f9c922;

        -webkit-animation: spin 1.5s linear infinite; /* Chrome, Opera 15+, Safari 5+ */
          animation: spin 1.5s linear infinite; /* Chrome, Firefox 16+, IE 10+, Opera */
    }

    @-webkit-keyframes spin {
        0%   { 
            -webkit-transform: rotate(0deg);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: rotate(0deg);  /* IE 9 */
            transform: rotate(0deg);  /* Firefox 16+, IE 10+, Opera */
        }
        100% {
            -webkit-transform: rotate(360deg);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: rotate(360deg);  /* IE 9 */
            transform: rotate(360deg);  /* Firefox 16+, IE 10+, Opera */
        }
    }
    @keyframes spin {
        0%   { 
            -webkit-transform: rotate(0deg);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: rotate(0deg);  /* IE 9 */
            transform: rotate(0deg);  /* Firefox 16+, IE 10+, Opera */
        }
        100% {
            -webkit-transform: rotate(360deg);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: rotate(360deg);  /* IE 9 */
            transform: rotate(360deg);  /* Firefox 16+, IE 10+, Opera */
        }
    }

    #loader-wrapper .loader-section {
        position: fixed;
        top: 0;
        width: 51%;
        height: 100%;
        background: #222222;
        z-index: 1000;
        -webkit-transform: translateX(0);  /* Chrome, Opera 15+, Safari 3.1+ */
        -ms-transform: translateX(0);  /* IE 9 */
        transform: translateX(0);  /* Firefox 16+, IE 10+, Opera */
    }

    #loader-wrapper .loader-section.section-left {
        left: 0;
    }

    #loader-wrapper .loader-section.section-right {
        right: 0;
    }

    /* Loaded */
    .loaded #loader-wrapper .loader-section.section-left {
        -webkit-transform: translateX(-100%);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: translateX(-100%);  /* IE 9 */
                transform: translateX(-100%);  /* Firefox 16+, IE 10+, Opera */

        -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);  
                transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    }

    .loaded #loader-wrapper .loader-section.section-right {
        -webkit-transform: translateX(100%);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: translateX(100%);  /* IE 9 */
                transform: translateX(100%);  /* Firefox 16+, IE 10+, Opera */

-webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);  
        transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
    }
    
    .loaded #loader {
        opacity: 0;
        -webkit-transition: all 0.3s ease-out;  
                transition: all 0.3s ease-out;
    }
    .loaded #loader-wrapper {
        visibility: hidden;

        -webkit-transform: translateY(-100%);  /* Chrome, Opera 15+, Safari 3.1+ */
            -ms-transform: translateY(-100%);  /* IE 9 */
                transform: translateY(-100%);  /* Firefox 16+, IE 10+, Opera */

        -webkit-transition: all 0.3s 1s ease-out;  
                transition: all 0.3s 1s ease-out;
    }