/* ==========================================================================
CUSTOM CSS
========================================================================== */

#pre-loader {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999999;
}

#status {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.loader-dot {
    opacity:0;
    background: #fff;
    width: 20px;
    height: 20px;
    margin: .3rem;
    border-radius: 50px;
    display: inline-block;
     -webkit-animation: pulsate 1.5s ease-out;
    -webkit-animation-iteration-count: infinite; 
    animation: pulsate 1.5s ease-out;
    animation-iteration-count: infinite; 
}

#dot-2 {

    animation-delay: .5s

}

#dot-3 {
 animation-delay: 1s
}


@-webkit-keyframes pulsate {
    0% {-webkit-transform: scale(0.1, 0.1); opacity: 0.0;}
    25% {opacity: 1.0;}
    50% {-webkit-transform: scale(1.2, 1.2); opacity: 0.5;}
    100% {-webkit-transform: scale(0.1, 0.1); opacity: 0.2;}
}


@keyframes pulsate {
    0% {transform: scale(0.1, 0.1); opacity: 0.0;}
    25% {opacity: 1.0;}
    50% {transform: scale(1.2, 1.2); opacity: 0.5;}
    100% {transform: scale(0.1, 0.1); opacity: 0.2;}
}


::selection {
    color: #fff;
    background: #a3bcc4;
}


body {
    color: #08152e;
    padding-top: 38px;
    font-family: 'Roboto', sans-serif;
    padding-right: 0px !important;

}



.body-overlay {
  position: fixed;
  top:0;
  bottom:0;
  left:0;
  right:0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 999;
  display: none;

}


section {
    padding-top: 80px;
    padding-bottom: 80px;
}

.sticky-side-bar {
    padding: 80px 0;
}


.min-600 {
    min-height: 600px;
}

header.small-header {
    height: auto;
}

.small-header-container {
    max-width: 100%;
}

.small-header .title-container {
    padding: 4rem 2rem;
    margin: 0;
    max-width: 100%;
    border-radius: 0;
    background: rgba(248, 248, 248, 0.8);
}




.draw {
   display: none;
}


.col-full {
   padding: 80px 1rem;
}

.full-col-img {
    background-size: cover;
    background-position: center;
}

.full-col-img h2 {
    font-weight: 300;
    font-size: 5rem;
}

h1, h2, h3, h4, h5, h6 {
   font-family: 'Big Shoulders Display', cursive;
}

.logo {
     font-family: 'Roboto', sans-serif;
     font-weight:800;
     font-style: italic;

}

h3 {
    font-weight: 700;
}


.section-header {
    font-size: 2.2rem;
    font-weight: 700;

}

.feature-header {
    border-left: 14px solid #1cd9b3;
    padding-left: 1.6rem;
}

.alert#cookie-consent {margin-bottom: 0px;}


.card {
    min-width: 100%;
    margin-bottom: 4rem !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}


.card-image {
    position: relative;

}


.card-image-anchor {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.card-overlay {
     position:absolute;
     height:100%;
     width:0%;
     top:0;
     background: #1cd9b3;
     transition: all .6s ease;
}


.card-image:hover .card-overlay {
    width: 100%;

    }

.card-img-text {
    opacity: 0;
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    margin-top:30px;

}

.card-image:hover .card-img-text {
    transform: translateY(-50%);
    -webkit-transition: opacity .3s ease-in .2s, margin-top .5s ease-in .2s;
    transform: translateY(-50%);
    transition: opacity .4s ease-in .2s, margin-top .4s ease-in .2s;
    margin-top: 0;
    opacity:1;

}

.card:last-child{
    margin-bottom: 0 !important;
}

.card, .card-footer {
    border: 0;
    background: none;
}


.card-body { 
    padding: 2rem 1.25rem 1rem;
}

.card-footer {
    border: 0px;
    background: transparent;
}

.card-img-top {
    border-radius: 0;
    border-left: 10px solid #1cd9b3;
    width:100%;
    height: auto;
}


.values-card {
    padding: 3rem 1rem;
    height: 100%;
}

.values-card:last-child {
   padding-bottom: 0;
}

.values-inner {
    height: 100%;
    border-bottom: 4px solid #fff;
    padding-bottom: 1rem;
}


.owl-stage {
    background: #000;
    padding-bottom: 40px;
}

.owl-item-inner {
    padding: 3rem 1.4rem;
    color: #fff;

}

.owl-carousel button.owl-dot {
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.8);
    margin: 1.4rem .7rem;
    border-radius: 50px;
}

.owl-dots {
    margin-top:-80px;
    position: relative;
    z-index: 1;
}

.owl-carousel button.owl-dot.active {
    background: #1cd9b3;
}

.quote-lead {
    width: 20px;
    height: 2px;
    background: #1cd9b3;
    margin: auto;
}

.modal {
     padding-right: 0px !important;
}


.to-top {
    color: rgba(28, 217, 179, .8);
    display: none;
   position: fixed;
   right: 1rem;
   bottom: 0rem;
   font-size: 3rem;
   z-index:2;
   transition: all .2s ease;
}

.to-top:hover {
    color: rgba(28, 217, 179, 1);
    bottom: 1.3rem;
}


.small-container {
    border-left: 12px solid #1cd9b3;
    background: rgba(255, 255, 255, 0.9);
}

/* ==========================================================================
COLOURS
========================================================================== */

.bg-dark {
     background-color: #08152e !important;
     color:#fff;
}

.bg-white {
    background-color: #fff !important;
}

.bg-light {
    background: #f8f8f8 !important;
}

.bg-marine {
    background-color: #1cd9b3 !important;
}


.text-dark {
    color: #08152e !important;
}

.text-marine {
    color: #1cd9b3;
}

.text-light-blue {
    color: #8896b1;
}


a.text-marine {
    color: #1cd9b3;
}

a.text-marine:hover {
    color: #1cd9b3;
}


a.text-dark {
    color: #08152e;
}

a.text-dark:hover {
    color: #1cd9b3;
}


.modal a {
    color: #1cd9b3;
}

.mob-hide {
    display: none;
}

/* ==========================================================================
TABLE
========================================================================== */

.table tbody tr td:last-child {
    text-align: center;
}



/* ==========================================================================
BUTTONS
========================================================================== */

button, .btn.focus, .btn:focus {
    outline: 0 !important;
    box-shadow: none !important;
}

.btn{
    font-size: 1rem;
    padding: .3rem 2rem;
    font-weight: 500;
    min-width: 230px;
    background: transparent;
}

.btn-large {
    font-size: 1.2rem;
    padding: .6rem 2rem;
    font-weight: 500;
    min-width: 250px;
}

.btn-outline-blue {
    color: #08152e !important;
    border: 4px solid #08152e;
   
}

.btn-outline-white {
    color: #fff !important;
    border: 4px solid #fff;
   
}

.btn-outline-blue:hover, .btn-outline-white:hover {
    color: #1cd9b3 !important;
    border: 4px solid #1cd9b3;

}

.btn-service {
	background: #08152e;
	color: #fff !important;
	border-radius: 0px;
	border: 4px solid #08152e;
	position: relative;
	text-align: left;
	width: 100%;
	max-width: 360px;

}


.btn-service:hover {
	color: #fff !important;
    border: 4px solid #1cd9b3;
    background: #1cd9b3;

}

.btn-service i {
	position: absolute;
	right: 10px;
	top: 14px;
}

/* ==========================================================================
NAV
========================================================================== */

.navbar {
	background: #f8f8f8;
	background-image: url('../img/logos/gp-steel-trans.svg');
	background-size: cover;
}

.fixed-top {
    position: fixed;
    width: 88%;
    right: 0;
    left:auto;
    height: 100%;
    z-index: 1030;
    margin-right: -100%;

}

.navbar>.container, .navbar>.container-fluid {
	display: block;
}

.menu-slide {
  transition: all .2s ease;
  margin-right: 0px;
}

.fade-container {
	opacity: 0;
	margin-top: 100px;
	transition: all .3s ease-in;
	transition-delay: .3s
}

.menu-slide .fade-container {
	opacity: 1;
	margin-top: 0px;
	
}

.navbar {
  padding: .8rem 0rem !important;
}

.navbar-nav {

  display: block;
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-align: left;
}


#website-navbar {
  margin: 0;
  width:100%;
  padding: 0 1.4rem;
}

.nav-item {

  padding: 0rem 0;
  font-weight: 500;
  border-bottom: 1px solid #bac4db;
  
}

.navbar-light .navbar-nav .nav-link {

  color: #000;
  padding: .8rem .8rem;
  font-size: 1.2rem;

}

.navbar-light .navbar-nav .nav-link.active {

  color: #000;
}

.navbar-light .navbar-nav .nav-link:hover {

  color: #1cd9b3;
}


.mobile-nav-bar {
	position: fixed;
	width: 100%;
	top:0;
	padding: .6rem 1rem;
	z-index: 9;
}


.menu-icon-container {
    position: fixed;
    padding: 0;
    z-index:9999;
    margin-top: 12px;
    top:0;
    right: 22px;

}

.nav-logo {
	font-size: 1.6rem;
	display: inline-block;
}

.hamburger {
  padding: 0;
  display: inline-block;
  cursor: pointer;
  -webkit-transition-property: opacity, -webkit-filter;
  transition-property: opacity, -webkit-filter;
  transition-property: opacity, filter;
  transition-property: opacity, filter, -webkit-filter;
  -webkit-transition-duration: 0.15s;
          transition-duration: 0.15s;
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
  border: 0;
  margin: 0;
  overflow: visible;

  z-index: 999999;
}
.hamburger:hover {
  opacity: 0.7;
}

.hamburger-box {
  width: 22px;
  height: 22px;
  display: inline-block;
  position: relative;
}
.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -3px;
}
.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
  width: 36px;
  height: 5px;
  background-color: #000;
  border-radius: 4px;
  position: absolute;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.15s;
          transition-duration: 0.15s;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
}
.hamburger-inner::before,
.hamburger-inner::after {
  content: "";
  display: block;
}
.hamburger-inner::before {
  top: -10px;
}
.hamburger-inner::after {
  bottom: -10px;
}
.hamburger--spin .hamburger-inner {
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
  -webkit-transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
          transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin .hamburger-inner::before {
  -webkit-transition: top 0.1s 0.34s ease-in, opacity 0.1s ease-in;
  transition: top 0.1s 0.34s ease-in, opacity 0.1s ease-in;
}
.hamburger--spin .hamburger-inner::after {
  -webkit-transition: bottom 0.1s 0.34s ease-in, -webkit-transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 0.1s 0.34s ease-in, -webkit-transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 0.1s 0.34s ease-in, transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 0.1s 0.34s ease-in, transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19), -webkit-transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin.is-active .hamburger-inner {
  -webkit-transform: rotate(225deg);
          transform: rotate(225deg);
  -webkit-transition-delay: 0.14s;
          transition-delay: 0.14s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--spin.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  -webkit-transition: top 0.1s ease-out, opacity 0.1s 0.14s ease-out;
  transition: top 0.1s ease-out, opacity 0.1s 0.14s ease-out;
}
.hamburger--spin.is-active .hamburger-inner::after {
  bottom: 0;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
  -webkit-transition: bottom 0.1s ease-out, -webkit-transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: bottom 0.1s ease-out, -webkit-transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: bottom 0.1s ease-out, transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: bottom 0.1s ease-out, transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
}


.desktop-social {
	width: 100%;
	text-align: center;
}

.desktop-social a {
	margin: 0 .5rem;
}

.desktop-social a img {
	width: 34px;
	height: 34px;
}

/* ==========================================================================
HEADER
========================================================================== */

header {
    height: 100%;
    position:relative;
    overflow: hidden;
    background: url('../img/backgrounds/steelfixer.jpg');
    background-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
}


#header-reveal {
    width: 100%;
    height:100%;
    position:absolute;
    top: 0;
    right:0;
    bottom: 0;
    z-index: 999999;
    -webkit-transition: all .7s ease;
    -webkit-transition-delay: 1s;
    transition: all .7s ease;
    transition-delay: 1s;
}

.reveal {
    width: 0px !important;
}

#head-img-panel {
    height: 100vh;
    background: #fff;
     background: url('../img/backgrounds/steefixer-v2.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: 140%;
}


#head-img-panel{
	display: none;

}


#feature-panel {
    height: 100%;
    background: rgba(248, 248, 248, 0.7);
}

#feature-panel h1 {
    max-width: 580px;
}


.feature-inner {
		padding: 4.6rem 1rem
	}

#feature-logo {
    height: 100%;
    margin-left: 2rem;
    margin-top: 0rem;
    opacity:.5;
}

header h1 {
    font-size: 2.8rem;
    line-height: 3.0rem;
    font-weight: 900;
}

.small-header h1 {
    font-size: 2.4rem;
    line-height: 2.5rem;
    font-weight: 900;
}


#head-para {
	font-size: 1rem;
	font-weight: normal;
}



/* ==========================================================================
SLIDES
========================================================================== */

.slide-overlay {
    background:rgba(8, 21, 46, 0.5);
    width:100%;
    height:100%;
    position:absolute;
    top:0;
}


.slide-caption {
    position: absolute;
    top: 20%;
    left: 14%;
    max-width: 400px;
    padding-right: 2rem;
}

.slide-caption h2 {
    font-size: 3rem;
}

.slide-caption p {
    font-size: 1.2rem;
}


.carousel-indicators li {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin: 0.7rem;
}


.carousel-indicators li.active {
        background-color:#1cd9b3;
    }

.slide-image {
	min-height: 540px;
	width: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center
}



/* ==========================================================================
TESTEMONIALS
========================================================================== */


#news {
    position: relative;
    background: url(../img/backgrounds/steel-casing.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}


#feature-block {
    position: absolute;
    top:0;
    width:100%;
    height:55%;
    background-image: url() no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-color: #f8f8f8 ;
}

#feature-block img {
    position:absolute;
    right:0;
    width:450px;
    margin-top:-520px;
    opacity:.3;
}


/* ==========================================================================
CONTACT PAGE
========================================================================== */

.form-col {
	padding-top: 1rem !important;
}

#contact-form {
    border-radius: 8px;
    position: relative;
    padding: 2.6rem 1.2rem;
    overflow-x: hidden;
}

#contact-form *:not(.bg-gp) {
    position: relative;
    z-index:1;
}

.bg-gp {
    position: absolute;
    width: 100%;
    height: auto;
    top:0;
    opacity: .1;
}


.contact-text {
    font-family: 'Roboto', sans-serif;

}



.form-control, .custom-select {
    border: 2px solid #fff;
    border-radius: 0;
    background-color: transparent;
    color:#fff;
}

#contact-form .custom-select {

    background: transparent url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23fff' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right .75rem center;
    background-size: 12px;
}

.custom-select option {
    color: #000 !important;
}

#contact-form h3 {
    font-size: 1.5rem;
    font-weight: 500;
}


#map iframe {
    WIDTH: 100%;
}


/* ==========================================================================
Projects
========================================================================== */


#gallery-header {
    background: url('../img/backgrounds/steel-fixing-4.jpg');
    background-size: cover;
    background-position: center top;

}

.project-row  {
    border-bottom: 6px solid #08152e;
    margin-bottom: 2.8rem;
    padding-bottom: 2.8rem;
}

.project-title {
    font-size: 1.4rem;
    color: #fff;
    border-left: 10px solid #1cd9b3;
    background: url('../img/backgrounds/angle.svg');
    background-repeat: repeat;
    background-size: auto;
    background-size: 95%;
    padding: .6rem 1rem;
    background-repeat: no-repeat;
    position: absolute;
    width: 90%;
    bottom: 0rem;
    left: -.2rem;
}


.project-sub-info {
    color: #dde3f0;
    font-size: 1rem;
}

.project-brief {
    padding-top: 2rem;
}

.project-thumb {
    width: 100%; 
    height: auto;
}


/* ==========================================================================
FOOTER
========================================================================== */


.background-section {
    height: 220px; 
    background: url('../img/backgrounds/steel-casing.jpg');
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover
}


footer {
    padding-top: 80px;
    padding-bottom: 80px;
}

footer hr {
    border-top: 4px solid #fff;
}

footer h3 {
    font-family: 'Roboto', sans-serif;
    font-size: 1.25rem;

}

.footlinks a {
    color: #ffffff
}

.footlinks a:hover {
    color: #1cd9b3;
}

footer ul li {
    line-height: 2rem;
}

.foot-icons {
	font-size: 2rem;
	width:100%;
	text-align:left;
	padding-right:3.3rem
}



.blueimp-gallery-display>.close {
	width: 50px !important;
	height: 50px !important;
	z-index: 4 !important;
}


@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .card-image {
        display:flex;
        height: 220px;
    }



  
}
