/* DEV SITE */
html, body {
  height: 100%;
  margin: 0;
  font-family: 'Open Sans', sans-serif;
}

abbr, ul, ol, li {
	font-family: 'Open Sans', sans-serif;
}

ul {
	margin-bottom: 15px;
}

.btn {
	background-color: rgba(36,36,36, 0.75);
	color: #ffffff;
}

.fis-logo {
	padding-right: 5px;
	width: 75px;
}

#system_name {
	width: 100%;
	height: 60px;
	padding-top: 10px;
	z-index: 1029;
}

#system_name.affix {
		background-color: rgba(41, 41, 41, 0.95);
}

.system-name-placeholder {
	width: 100%;
	height: 60px;
	background-color: rgba(41, 41, 41, 0.95);
}

.row .row {
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.service-circle {
  border-radius: 50%;
  width: 100%;
  background-color: #242424;
  background-size: cover;
  margin: auto;
  margin-top: 15px;
}

a.service-circle {
  display: inline-block;
}

.service-circle-small {
  max-width: 100px;
}

.service-circle-medium {
  max-width: 200px;
}

.service-circle-large {
  max-width: 250px;
}

.service-circle:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.service-circle-small:hover {
	background-color: #656565;
}

.service-square {
  border-radius: 6px;
  width: 100%;
  background-color: #242424;
  background-size: cover;
  max-width: 100px;
  margin: auto;
  margin-top: 15px;
}

.service-square:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.service-square:hover {
	background-color: #656565;
}

.service-ironmongery {
	background-image: url('/img/icons/ironmongery.png');
}

.service-glass {
	background-image: url('/img/icons/glass.png');
}

.service-blinds {
	background-image: url('/img/icons/blinds.png');
}

.service-doors {
	background-image: url('/img/icons/doors.png');
}

.service-design {
	background-image: url('/img/icons/design.png');
}

.service-installers {
	background-image: url('/img/icons/installers.png');
}

.neslo-system-info {
	height: 40vh;
	min-height: 350px;
}

.neslo-system-info img {
	max-height: 300px;
}

.neslo-product-text {
	padding-left: 30px;
	padding-right: 30px;
}

.img-preview {
	max-height: 350px;
	border: 1px solid #242424;
}

.vertical-align-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
  display: table;
}

.vertical-align {
  background: white;
  display: table-cell;
}

.vertical-align-middle {
  vertical-align: middle;
}

.vertical-align-bottom {
  vertical-align: bottom;
}

.news-tile {
	background: rgba(0, 0, 0, 0.2);
	padding: 15px;
	margin-bottom: 30px;
	border-radius: 6px;
}

.project-tile {
	background: rgba(0, 0, 0, 0.2);
	padding: 15px;
	margin-bottom: 30px;
	border-radius: 6px;
}

.img-fill {
  width: 100%;
  height: 275px;
  float: left;
  position: relative;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  margin-bottom: 20px;
  margin-top: 20px;
}

.logo-fill {
  width: 100%;
  height: 170px;
  float: left;
  position: relative;
  background-repeat: no-repeat;
  background-position: 50%  50%;
  background-size: contain;
  margin-bottom: 15px;
}

.gallery-slider img {
	max-height: 500px;
	margin: auto;
	margin-top: 5px;
	margin-bottom: 5px;
	margin-left: 5px;
	border: 0.5px solid #c0c0c0;
	border-radius: 6px;
}

.news-spacer {
	height: 30px;
	width: 100%;
}

.pagination>.active>a, .pagination>.active>a:focus, .pagination>.active>a:hover, .pagination>.active>span, .pagination>.active>span:focus, .pagination>.active>span:hover {
  background-color: #369dcc;
  border-color: #369dcc;
}

.pagination>li>a, .pagination>li>span {
  color: #369dcc;
}

.email-input {
	max-width: 200px;
	margin: auto;
	display: inline-block;
}

.email-submit {
	display: inline-block;
	margin-bottom: 2px;
}

.email-access {
	color: #ffffff !important;
	background-color: rgba(36,36,36, 0.8);
	text-align: center;
	border-top: 1px solid #ffffff;
}

.email-access small.help-block {
	display: inline-block;
	padding-left: 5px;
}
.email-access h6 {
	padding-top: 10px;
	padding-bottom: 10px;
	margin-right: 0px;
}

.home-text>.container {
  background: rgba(255,255,255,0.9);
  padding: 15px;
}

.body-text .container {
  background: rgba(255,255,255,0.9);
  padding: 15px;
}

.image-wrapper {
	padding-top: 30px;
}

.no-bg {
	background: none !important;
}

.neslo-product-bar {
	background-color: rgba(41,41,41, 0.95) !important;
}

.neslo-other-products-bar {
	background-color: rgba(233,233,233, 0.95);
}

.neslo-top-gallery img {
	max-height: 400px;
}

.overlay h2 {
	color: #ffffff !important;
	opacity: 0.8;
}

.hover-only {
	color: #ffffff !important;
	letter-spacing: 5px;
}

.mobile-only {
	color: #ffffff !important;
	letter-spacing: 5px;
	background-color: rgba(0, 0, 0, 0.5);
}

.mobile-only h2 {
	font-size: 28px;
}

.neslo-products .container {
	background: none;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Open Sans', sans-serif;
	letter-spacing: 2px;
}

h1 {
	font-size: 32px;
	font-style: normal;
	font-variant: normal;
	font-weight: 400;
	line-height: 32px;
	padding-bottom: 16px;
	margin-top: 5px;

}

h2 {
	font-size: 28px;
	font-style: normal;
	font-variant: normal;
	font-weight: 400;
	line-height: 25px;
	padding-bottom: 10px;
}

h3 {
	font-size: 22px;
	font-style: normal;
	font-variant: normal;
	font-weight: 400;
	line-height: 22px;
}

h4 {
	font-size: 18px;
	font-style: normal;
	font-variant: normal;
	font-weight: 400;
	line-height: 18px;
}

h6 {
	letter-spacing: 1px;
	font-size: 14px;
}

a {
	color: #369dcc;
    -webkit-transition: background-color 0.2s ease;
    -moz-transition: background-color 0.2s ease;
    -ms-transition: background-color 0.2s ease;
    -o-transition: background-color 0.2s ease;
	transition: background-color 0.2s ease;
}

a:hover {
	color: #369dcc;
}

p {
	font-size: 16px;
	font-style: normal;
	font-variant: normal;
	font-weight: 300;
	line-height: 28px;
	padding-bottom: 5px;
}

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

blockquote {
	font-size: 21px;
	font-style: normal;
	font-variant: normal;
	font-weight: 600;
	line-height: 30px;
}

ul.dropdown-menu {
	background-color: rgba(85,85,85, 0.9);
}

ul.dropdown-menu a {
	color: #fff !important;
}

pre {
	font-size: 13px;
	font-style: normal;
	font-variant: normal;
	font-weight: 300;
	line-height: 18px;
}

body {
	overflow: hidden;
}

#preloader {
	position: fixed;
	top:0;
	left:0;
	right:0;
	bottom:0;
	background-color:#242424; /* change if the mask should have another color then white */
	z-index:9999; /* makes sure it stays on top */
}

#status {
	width:200px;
	height:200px;
	position:absolute;
	left:50%; /* centers the loading animation horizontally one the screen */
	top:50%; /* centers the loading animation vertically one the screen */
	background-image:url(../img/status.gif); /* path to your loading animation */
	background-repeat:no-repeat;
	background-position:center;
	margin:-100px 0 0 -100px; /* is width and height divided by two */
}

.loading-gif {
	padding-left: 20px;
	padding-right: 20px;
	padding-right: 5px;
}

.loading-text {
	text-transform: uppercase;
	color: #fff; 
	padding-top: 15px;
}

.neslo-logo-load {
	max-width: 200px;
}

.white {
	color: #fff !important;
}

footer {
	width: 100%;
	background-color: rgba(36,36,36, 0.95);
	color: #ffffff;
	text-align: center;
	border-top: 1px solid #fff;
	height: 115px;
}

.phone-number {
	width: 100%;
	height: 45px;
	text-align: center;
	font-weight: 300;
	background-color: rgba(36,36,36, 0.75);
}

.phone-number a {
	color: #ffffff;
	font-size: 19px;
	line-height: 45px;
}

.navbar-neslo-condensed .navbar-nav {
	margin-top: 0px !important;
	    -webkit-transition: margin 0.4s linear;
	    -moz-transition: margin 0.4s linear;
	    -ms-transition: margin 0.4s linear;
	    -o-transition: margin 0.4s linear;
	    transition: margin 0.4s linear;
}

.overlay {
	position: absolute;
	width: 100%;
	height: 100%;
	border: 0.5px solid #c0c0c0;
	border-radius: 6px;
	top: 0;
	opacity: 1;
	background-color: rgba(0,0,0,0.5);
	    -webkit-transition: all 0.4s;
	    -moz-transition: all 0.4s;
	    -ms-transition: all 0.4s;
	    -o-transition: all 0.4s;
	    transition: all 0.4s;
}

.col-product-img {
	position: relative;
	text-align: center;
	max-width: 75vw;
	margin: auto;
}

.col-product-img h2 {
	padding-top: 10px;
	margin-top: 40%;
	width: 100%;
	position: absolute;
	font-size: 18px;
}


.col-product-img h2.hover-only {
	opacity: 0;
	background-color: rgba(0, 0, 0, 0.5);
	margin-top: 40%;
	width: 100%;
	    -webkit-transition: all 0.4s;
	    -moz-transition: all 0.4s;
	    -ms-transition: all 0.4s;
	    -o-transition: all 0.4s;
	    transition: all 0.4s;
	    font-size: 24px;
}

.col-product-img:hover h2.hover-only {
	opacity: 1;
	margin-top: 60%;
	width: 100%;
	    -webkit-transition: all 0.4s;
	    -moz-transition: all 0.4s;
	    -ms-transition: all 0.4s;
	    -o-transition: all 0.4s;
	    transition: all 0.4s;
}

.img-tile {
  background-size: cover;
  position: relative;
  width: 100%;
  margin-bottom: 30px;
}

.img-tile:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.download-tiles {
	position: relative;
	text-align: center;
	max-width: 75vw;
	margin: auto;
}

.download-tiles h2 {
	padding-top: 10px;
	margin-top: 80%;
	width: 100%;
	position: absolute;
	font-size: 18px;
	color: #292929;
}


@media(max-width:767px){

	.product-spacer {
		width: 100%;
		height: 105px;
	}

	.neslo-product-info {
		padding-right: 10px;
		padding-left: 10px;
	}

	.body-text {
		padding-top: 118px;
	}

	.phone-number {
		margin-top: 5px;
	}

	.neslo-logo {
		max-height: 60px;
		float: left;
		margin-left: 2px;
		margin-top: 2px;
	}

	.neslo-products {
		padding-top: 10px;
	}

	.col-product-img h2 {
		margin-top: 35%;
		font-size: 18px;
	}

	.col-product-img {
		padding-bottom: 15px;
	}

	.line a {
		border-bottom: solid 2px #369dcc;
	}

	.navbar-nav {
		background-color: rgba(0,0,0, 0.75);
	}


	.navbar-nav>li>a {
		color: #c7d632;
		margin: 2px;
		font-size: 17px;
		border-bottom: solid 2px rgba(255,255,255,0);
		background: none;
	}

	.navbar-nav>li>a:hover {
		border-bottom: solid 2px #369dcc;
		background: none;
	}

	.navbar-neslo {
		margin-top: 25vh;
	}
	
	.col-product-img {
		padding-left: 15px;
		padding-right: 15px;
		padding-top: 15px;
	}

	.overlay h2 {
		color: #ffffff !important;
		opacity: 0.8;
		letter-spacing: 4px;
	}

	.news-img {
		width: 100%;
	}

}

@media(min-width:768px){

	.product-spacer {
		width: 100%;
		height: 125px;
	}

	.neslo-product-info {
		min-height: 250px;
		padding-left: 30px;
		padding-right: 30px;
	}

	.col-product-img h2 {
		margin-top: 40%;
		font-size: 18px;
		letter-spacing: 6px;
	}

	.neslo-products {
		width: 100vw;
		height: 350px;
		padding-top: 10px;
		display:table-cell; 
		vertical-align: middle;
	}

	.body-text {
    	min-height: calc(100vh - 465px);
		padding-top: 195px;
	}

	.navbar-nav>li>a {
		color: #369dcc;
		margin: 2px;
		font-size: 17px;
		line-height: 34px;
		height: 68px;
	}

	.navbar-nav>li>a:hover {
		border-bottom: solid 2px #ffffff;
		background: none;
	}

	.line a {
		border-bottom: solid 2px #369dcc;
	}

	.neslo-logo {
		max-height: 70px;
		float: right;
		margin: 1px;
	}

	.news-img {
		width: 100%;
	}

	.navbar-neslo {
		margin-top: 25vh;
	}

	.navbar-neslo-condensed .neslo-logo {
		max-height: 70px;
	}

	.navbar-neslo-condensed {
		height: 194px;
	}

	.col-product-img:hover .overlay {
		opacity: 0;
	}

}

@media(min-width:992px){

	.vertical-center {
		display: flex;
		vertical-align: middle;
	}

	.body-text {
		padding-top: 123px;
    	min-height: calc(100vh - 465px);	
	}

	.project-tile {
		height: 420px;	
	}

	.neslo-logo {
		max-height: 100px;
		margin: 1px;
	}

	.navbar-neslo-condensed {
		height: 122px;
	}

	.navbar-neslo {
		margin-top: 18%;
	}

	.navbar-neslo .navbar-nav {
		margin-top: 30px;
	    -webkit-transition: margin 0.4s linear;
	    -moz-transition: margin 0.4s linear;
	    -ms-transition: margin 0.4s linear;
	    -o-transition: margin 0.4s linear;
	    transition: margin 0.4s linear;
	}

	.news-img {
		width: 41.66666667%;
	}

}

@media(min-width:1200px){

	.body-text {
		padding-top: 123px;
    	min-height: calc(100vh - 471px);	
	}

	.neslo-logo {
		max-height: 200px;
	}

	.navbar-neslo {
		margin-top: 18%;
	}

	.navbar-neslo-condensed {
		height: 122px;
	}

	.navbar-neslo .navbar-nav {
		margin-top: 128px;
	    -webkit-transition: margin-top 0.4s linear;
	    -moz-transition: margin-top 0.4s linear;
	    -ms-transition: margin-top 0.4s linear;
	    -o-transition: margin-top 0.4s linear;
	    transition: margin-top 0.4s linear;
	}

	.navbar-neslo .navbar-right {
		margin-top: -25px !important;
	    -webkit-transition: margin-top 0.4s linear;
	    -moz-transition: margin-top 0.4s linear;
	    -ms-transition: margin-top 0.4s linear;
	    -o-transition: margin-top 0.4s linear;
	    transition: margin-top 0.4s linear;
	}


	.navbar-neslo-condensed .navbar-right {
		margin-top: 0px !important;
	}

	.news-img {
		width: 41.66666667%;
	}

}

.img-cen {
	margin: auto;
}

.nav .open>a, .nav .open>a:focus, .nav .open>a:hover {
	background: none;
}

.neslo-products {
	background-color: rgba(41, 41, 41, 0.95);
}

.neslo-xs-product-img {
	max-height: 12vh;
	margin: auto;	
}

.neslo-xs-product-title {
	height: 12vh;
	padding-top: 30px;
	margin: 0;
}

.neslo-xs-product-desc {
	padding-top: 15px;
}

.v-middle {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.all-product-images {
	text-align: center;
	padding-top: 20px;
	padding-bottom: 10px;
	background: none !important
}

.img-neslo-products {
	max-height: 350px;
	display: inline-block;
	margin: 2px;
}

.home-image {
	position: relative;
	background-image: url('/img/home-bg.jpg');
    background-position: 40% top;
    background-repeat: no-repeat;
    background-size: cover;
	min-height: 100vh;
}

.home-text {
	padding-top: 30px;
	padding-bottom: 30px;
}

.home-text p {
	font-size: 18px;
}

.neslo-logo {
    -webkit-transition: max-height 0.4s linear;
    -moz-transition: max-height 0.4s linear;
    -ms-transition: max-height 0.4s linear;
    -o-transition: max-height 0.4s linear;
    transition: max-height 0.4s linear;
}

.navbar-neslo {
	text-transform: uppercase;
	font-weight: 300;
	padding: 2px;
	background-color: rgba(36,36,36, 0.95);
	border-radius: 0px;
    -webkit-transition: all 0.4s linear;
    -moz-transition: all 0.4s linear;
    -ms-transition: all 0.4s linear;
    -o-transition: all 0.4s linear;
    transition: all 0.4s linear;
}

.navbar-neslo-condensed {
	text-transform: uppercase;
	font-weight: 300;
	margin-top: 0px;
	padding: 2px;
	background-color: rgba(36,36,36, 0.95);
    -webkit-transition: all 0.4s linear;
    -moz-transition: all 0.4s linear;
    -ms-transition: all 0.4s linear;
    -o-transition: all 0.4s linear;
    transition: all 0.4s linear;
}

.navbar-nav>li>a {
	font-family: 'Open Sans', sans-serif;
	color: #fff;
	margin: 2px;
	font-size: 17px;
	padding-top: 25px;
}

.social-footer {
	height: 50px;
	margin-bottom: 0px;
	text-align: center;
	padding: 0;
}

.social-footer a{
	color: #c7d632;
}

.social-footer a:hover{
	color: #fff;
}

ul.social-footer li {
	display: inline-block;
    vertical-align: middle;
	margin-top: 20px;
}

li.social>a {
	padding-top: 15px;
	padding-left: 7.5px;
	padding-right: 7.5px;
	color: #fff;
}

.nav .open>a, .nav .open>a:focus, .nav .open>a:hover {
	border-color: #c7d632;
}

.open .dropdown-toggle {
	border-bottom: solid 2px #c7d632;
}

.dropdown-menu {
	border-radius: 0px;
}

.dropdown-menu>li>a {
	color: #369dcc;
	margin: 2px;
}

.dropdown-menu>li>a:hover {
	color: #fff;
	background-color: rgba(54,157,204, 0.8);
}

.navbar-toggle {
	margin: 0px;
	margin-left: 2px;
	margin-right: 5px;
	height: 55px;
}

.icon-bar {
	border: solid 2px #fff;
	border-radius: 0px !important;
}

.navbar-toggle:hover {
	border-color: rgba(255,255,255,0);
}

.navbar-toggle:hover .icon-bar {
	border-color: #ffffff;
}

#circle-bouncer {
	position: absolute;
	top: 80%;
	width: 100%;
}

.circle {
	height: 50px;
	width: 50px;
	margin: auto;
}

/*arrow bounce*/
.bounce {
    -webkit-animation: bounce 2s infinite;
    animation: bounce 2s infinite;
}

.no-bg {
	background: none !important;
}

/* Scroll down indicator (bouncing) */
@-webkit-keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    -webkit-transform: translateY(0); }
  40% {
    -webkit-transform: translateY(-30px); }
  60% {
    -webkit-transform: translateY(-15px); } }
@-moz-keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    -moz-transform: translateY(0); }
  40% {
    -moz-transform: translateY(-30px); }
  60% {
    -moz-transform: translateY(-15px); } }
@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0); }
  40% {
    -webkit-transform: translateY(-30px);
    -moz-transform: translateY(-30px);
    -ms-transform: translateY(-30px);
    -o-transform: translateY(-30px);
    transform: translateY(-30px); }
  60% {
    -webkit-transform: translateY(-15px);
    -moz-transform: translateY(-15px);
    -ms-transform: translateY(-15px);
    -o-transform: translateY(-15px);
    transform: translateY(-15px); } }

/*arrow down end*/