/* =============================================================================================
	BASE STYLES AND LAYOUT
============================================================================================= */

/* ------------------------------------------------------------------------ Page Styles & Resets */

html {
	position: relative; /*for sticky footer*/
  	min-height: 100%;
}

body {
	font: normal 100%/1.6 'Open Sans', Arial, Helvetica, sans-serif !important; 
	color: #333;
	background-color: #FFF;
} 


@font-face {
    font-family: 'gotham_boldregular';
    src: url(card'../fonts/gotham_bold_regular-webfont.eot');
    src: url('../fonts/gotham_bold_regular-webfont.eot?#iefix') format('embedded-opentype'),
         url('../fonts/gotham_bold_regular-webfont.woff2') format('woff2'),
         url('../fonts/gotham_bold_regular-webfont.woff') format('woff'),
         url('../fonts/gotham_bold_regular-webfont.ttf') format('truetype'),
         url('../fonts/gotham_bold_regular-webfont.svg#gotham_boldregular') format('svg');
    font-weight: normal;
    font-style: normal;

}

.preload * { /* Transitions fire only after page load http://css-tricks.com/transitions-only-after-page-load/ */
	-webkit-transition: none !important;
		transition: none !important;
	}

@media (min-width: 992px) {

	/*offset sticky footer*/
	.body--sticky-footer {
		padding-bottom: 360px; /*This will change depending on the height of the footer*/
	}

	/*if the header is fixed, add this class to the body*/
	.body--fixed-header {
		padding-top: 74px; /*This will change depending on the height of the header*/
	}
	
}


@media screen
and (min-width: 992px) {
   a[href*="tel:"] {
       pointer-events: none;
       cursor:auto;
	   text-decoration-color: transparent;
   }
}

/* Call Tracking Overwrite */

.phonebutton {
    background: unset !important;
    padding: 0 !important;
}

/* ------------------------------------------------------------------------ Keyboard Accessibility */

.skip-link { 
	position:absolute; 
	left:-10000px; 
	top:0; 
	width:1px; 
	height:1px; 
	overflow:hidden;
	background-color: #666;
	color: #fff;
	font-size: 0.875rem;
	text-decoration:none;
	z-index: 1100;
	padding:0.5rem 0.625rem; 
} 

.skip-link:focus, .skip-link.sr-only-focusable:active, .skip-link.sr-only-focusable:focus {
	position: absolute; 
	outline: none; 
	left:0;
	outline: none; 
	width:auto; 
	height:auto;
} 

.skip-link:hover {
	color: #fff;
	background-color: #777;
}

.anchor-tilt {
    display: block;
    height: 330px;
    margin-top: -330px;
    visibility: hidden;
}

.anchor:target {padding-top: 190px;}

a:focus, .carousel-control-next:focus,.carousel-control-prev:focus, .btn:focus, .carousel__link:focus .carousel__btn, .form-control-file:focus {
	outline: solid thin rgba(0, 0, 0, 0.5);
	box-shadow: none;
} 

.sidenav__header-link:focus, .card__header-link:focus {outline: solid thin rgba(255, 255, 255, 0.5);}

a:hover, a:active { outline: none !important; } /*...not with mouse (kinda) */


/* ------------------------------------------------------------------------ Headers */

h1, h2, h3,
.h1, .h2, .h3  { 		
	font-weight: 700;
	line-height:1.4;
}	

h1, .h1 {	
	font-size: 1.75rem;	
	text-transform: uppercase;
}
	
h2, .h2 {
	font-size: 1.5rem; 
}
		
h3, .h3 { 
	font-size: 1.375rem; 
}	
	
		
@media (min-width: 768px) {	

	h1, .h1 {
		font-size: 2.25rem;
	}

	h2, .h2 {
		font-size: 2rem;
	}
}	

.section__storage__heading {
    font-weight: 800;
	font-size: 1.75em;
	line-height: 0.85;
	color: #000;
	letter-spacing: -1px;
}

.section__heading {
	font-weight: 800;
	font-size: 1.75em;
	line-height: 1.1;
	color: #000;
	letter-spacing: -1px;
}

.section__heading.weight-normal {
    font-weight: 400;
}

.section__heading span, .section__storage__heading span {
	color: #d22030;
	font-weight: bold;
}

.accent__heading {
	color: #d22030;
	font-style: italic;
	font-weight: bold;
}

.accent__text {
    color: #d22030;
}

.white__text {
    color: #fff;
}

@media (min-width: 992px) {
	.section__heading, .section__storage__heading {
		font-size: 2em;
	}


	.accent__heading {
	}
}

@media (min-width: 1200px) {
	
	.section__heading {
		font-size: 2.5em;
	}


	.accent__heading {
	}
}
	
/* ------------------------------------------------------------------------ Lists */

ul, .list { 
	list-style: none; 
	list-style-position: outside;
	padding-left: 1.5em;
}

ul li, .list__item {	
    padding: 0 0 0.25rem 1rem;
	background: url(../../images/arrow-right-gray.svg) no-repeat left 0.625rem;
	background-size: 0.625rem 0.625rem;
	padding-left: 1.5em;
}

ul ul, .list__sub-list {
	margin-top: 0.25rem;
}


ul ol {
	padding-left: 1.375rem;
	margin-top: 0.25rem;
}

ul ol li {
	background-image: none;
	padding-left: 0;
}
		
ol {
	padding-left: 1rem;
}	

ol li {padding-bottom: 0.25rem;}

ol ol {
	padding-left: 2.25rem;
	margin-top: 0.25rem;
}

ol ul {margin-top: 0.25rem;}
		
li:last-child { 
	padding-bottom:0;
}

ul.checklist li {
    padding: 0 0 0.25rem 1rem;
	background: url(../../images/green-check.svg) no-repeat left 0.425rem;
	background-size: 0.825rem 0.825rem;
	padding-left: 1.5em;
}
		
					
/* ------------------------------------------------------------------------ Other Base Text Styles */

.color-inherit {
	color: inherit;
}	

.text-muted {
	color: #888!important;
}

.intro-text {
	font-size:1.25rem;
}

.note {
	font-size: .875rem;
}

sup, sub {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sup { 
	top: -0.5em; 
}

sub { 
	bottom: -0.25em; 
}

@media (min-width: 992px) {	

	.intro-text {
		font-size:1.5rem;
		line-height: 1.6;
	}	

}

	
/* ------------------------------------------------------------------------ Links */

a { 
	color: #d22030; 
	font-weight: 700;
	transition: all 0.25s;
}	

a:hover {
	color: #333;
	text-decoration: none !important;
}

main a { 
	word-wrap: break-word; 
}

a img {
	border: none;
	-webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0) scale(1.0, 1.0);
	transition: opacity 0.25s;
}				

a img:hover { 
	opacity: .9;
}		

.btn {
	padding: .5rem 2rem;
	border-radius:0;
	text-transform: uppercase;
	cursor: pointer;
}

.btn-group-lg>.btn, .btn-lg {
	font-size: 1.125rem;
}

.btn-primary {
	background-color: #fff;
    border: solid 2px #d22030;
    color: #333;
    font-weight: bold;
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary:disabled,
.btn-primary:not([disabled]):not(.disabled).active, .btn-primary:not([disabled]):not(.disabled):active, .show>.btn-primary.dropdown-toggle {
	background-color: #d22030;
	border-color: #d22030;
	box-shadow: none;
	color: #fff;
}

.btn--outline-primary {
	color: #fff;
	border: solid 2px #fff;
	font-weight: 800;
	font-size: 1em;
}

.btn--outline-primary:hover {
	background: #fff;
	color: #d22030;
	border: solid 2px #fff;
}


.btn-arrow:after {
    display: inline-block;
    content: ' ';
    background-image: url(../../images/arrow-right-white.svg);
    background-size: 12px 12px;
    width: 12px;
    height: 12px;
    margin-left: 1em;
    transition: all 0.25s;
}

.btn-arrow:hover::after {
    display: inline-block;
    content: ' ';
    background-image: url(../../images/arrow-right-red.svg);
    margin-left: 1.5em;
    transition: all 0.25s;
}

.play-btn {
	max-width: 1em;
    width: 100%;
    display: inline-block;
    padding-left: 0;
    position: relative;
    top: -0.15em;
}

.play-btn:hover {
	opacity: 0.5;
}

.back-btn::before {
	display: inline-block;
	content: ' ';
	background-image: url(../../images/arrow-left-grey.png);
	background-repeat: no-repeat;
	background-size: 10px 14px;
	width: 10px;
	height: 14px;
	position: relative;
	margin-right: 0.8em;
	top: 0.1em;
}

@media (min-width: 992px) {
	.btn--outline-primary {
		font-size: 1.25em;
	}
	
	.btn-arrow:after {
		background-size: 14px 14px;
		width: 14px;
		height: 14px;
	}
}

@media (min-width: 1200px) {
	
	.btn--outline-primary {
		font-size: 1.45em;
	}
	
	.btn-arrow:after {
		background-size: 16px 16px;
		width: 16px;
		height: 16px;
	}
}




/* ------------------------------------------------------------------------ Images */
	
img {
	max-width: 100%;
	height: auto!important; 
}

   .img--float-left, .img--float-right { 
	margin: .5rem 0 1rem 0;	
}

.background-cover {
    background-position: center center !important;
    background-size: cover !important;
}

@media (min-width: 576px) {	
	.img--float-left {
		float: left;
		margin: .5rem 1.5rem .375rem 0;
		max-width:50%;
		}
		
	.img--float-right {
		float: right;
		margin: .5rem 0 .375rem 1.5rem;
		max-width:50%;
		}
}

@media (min-width: 576px) {	
	.img--float-left {
		float: left;
		margin: .5rem 1.5rem .375rem 0;
		max-width:50%;
		}
		
	.img--float-right {
		float: right;
		margin: .5rem 0 .375rem 1.5rem;
		max-width:50%;
		}
}

@media (min-width: 768px) {	
	.img--float-left, 
	.img--float-right { max-width:50%; }
}	

@media (max-width: 992px) {	
    .background-cover {
        min-height: 20em;
        margin: 0 15px;
    }
}

.tilt-free {
    display: inline-block;
    max-width: 77px;
    position: relative;
    top: -0.38em;
}
	
/* ------------------------------------------------------------------------ SVG's */

svg {
	width: 1rem;
	height: 1rem;
}	
	

/* ------------------------------------------------------------------------ Horizontal Rules */

hr, .hr { 
	margin: 1.5rem auto;
}	

@media (min-width: 768px) {

	hr, .hr {
		margin: 2rem auto;
	}

}	



/* =============================================================================================
	HEADER
============================================================================================= */

.print-header { display:none; }
	
.logo { 
	flex: 1;
	display: block;
}

.logo__img {
	max-width: 18rem; 
	width: 100%;
}

.header {
	border-bottom: 1px solid #ddd;
}

.header--fixed-top {
	transition: background-color .5s;
}

.header__content {
	margin-top: 0.75rem;
}


@media (min-width: 768px) {	
		
	.logo__error-page {
		margin:1.5rem auto 2.5rem auto;
		float: none;
	}

}

@media (min-width: 992px) {	

	.header__content { 
		margin-top: 0;
		margin-left:1.5em;
	}

	.header--fixed-top {
		position: fixed;
	    top: 0;
	    right: 0;
	    left: 0;
	    z-index: 1040;    
	}

}

@media (min-width: 1200px) {	

	.header__content { 
		margin-left:2em;
	}

}
		
/* ------------------------------------------------------------------------ TopLinks */

.top-links { 
	padding-bottom: 0.5rem;
}

.top-links__link { 
	text-decoration:none;
	font-size: 0.8rem;
	font-weight: 400;
	padding: 0 0.5rem;
	color: #444;
}

.top-links__link:hover {
	text-decoration:none;
	color: #777 ;
}	

@media (min-width: 768px) {
		
	.top-links__link {
		font-size: 0.9375rem;
	}

}

@media (min-width: 992px) {

	.top-links {
		padding: 0;
	}

	.top-links__link:last-child { 
		padding-right: 0;
	}

}


/* ------------------------------------------------------------------------ Seach Area */

input[type=search] {
	background: url(../../images/search-icon.svg) no-repeat 9px center;
	border: 0;
	padding: 6px 0;
    width: 55px;
    background-size: 1em;
	
	-webkit-border-radius: 10em;
	-moz-border-radius: 10em;
	border-radius: 10em;
	
	-webkit-transition: all .5s;
	-moz-transition: all .5s;
	transition: all .5s;
}
input[type=search]:focus {
	width: 100%;
	background-color: #fff;
	border: solid 2px #ddd;
}


input:-moz-placeholder {
	color: #999;
}
input::-webkit-input-placeholder {
	color: #999;
}

#search-push input[type=search] {
	width: 25px;
	color: transparent;
	cursor: pointer;
	position: relative;
	top: 0.1em;
}

.header--scroll #search-push input[type=search] {
	top: 0.1em;
}

#search-push input[type=search]:hover {
	background-color: #fff;
}
#search-push input[type=search]:focus {
	width: 100%;
	padding-left: 32px;
	color: #000;
	background-color: #fff;
	cursor: auto;
}
#search-push input:-moz-placeholder {
	color: transparent;
}
#search-push input::-webkit-input-placeholder {
	color: transparent;
}

.search-form__input {
	border-radius: 0;
	border-right: 0;
}

.search-form__btn {
	position: relative;
	width: 3rem;
	padding: .5rem .75rem;
	border-radius: 0;
}

.search-form__btn:after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	background: url(../../images/search-icon.svg) no-repeat center;
	background-size: 1.25rem auto;
	width: 100%;
	height: 100%;

}

@media (min-width: 992px) {
.search-form__btn {
    right: 0em;
}
	
#search-push input[type=search]:focus {
	width: 130px;
}

}

/* ------------------------------------------------------------------------ Navbar Nav */

.navbar-nav .nav-link {
	border-bottom: 1px solid #ddd;
	color: #444;
	text-transform: uppercase;
	padding: .625rem 0;
}

.navbar-nav .nav-item {
	background-image: none;
	padding: 0;
}

.navbar-nav .nav-item.active .nav-link {
    color: #666;
}

.navbar-nav .nav-item.active:hover .nav-link, .navbar-nav .nav-link:hover {
    color: #777;
}

.navbar-nav .dropdown-menu {
	border: 0;
	padding-top: 0;
	background-color: #eee;
	border-radius: 0;
	margin:0;
	padding:0;
}

.navbar-nav .dropdown-menu li.active > .dropdown-item {
	color: #666;
	font-weight: 700;
}

.navbar-nav .dropdown-item {
	border-bottom: 1px solid #fff;
	padding: .625rem 1.5rem;
}

.navbar-nav li:last-child > .dropdown-item {
	border-bottom: none;
}

.navbar-nav li {
	padding: 0;
	background-image: none;
}

.navbar-nav .dropdown-item:hover {
	background-color: rgba(0,0,0,.1);
}

.navbar-nav .dropdown-item:active {
	color:#444;
}

.navbar-nav .dropdown-item:focus {
	background-color:#eee;
}

.navbar-nav .dropdown-menu .dropdown-menu {
	background-color: #ddd;
}

.navbar-nav.sm-collapsible .dropdown-menu .dropdown-menu {
	margin:0;
}

.navbar-nav .dropdown-item .dropdown-item {
	background-color: inherit;
}

.navbar-nav:not(.sm-collapsible) .nav-link .sub-arrow {
	display: none;
	border:0;
}

.navbar-nav.sm-collapsible .sub-arrow {
	border: none;
	margin-right: 0;
	width: .625rem;
    height: .625rem;
    background-image: url(../../images/arrow-right-gray.svg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: .625rem .625rem;
    position: absolute;
    right: 0;
    top: 1.25em;
    transition: all 0.25s;
}

.navbar-nav.sm-collapsible .show .sub-arrow {
	border: none;
	margin-right: 0;
	width: .625rem;
    height: .625rem;
    background-image: url(../../images/arrow-right-gray.svg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: .625rem .625rem;
    position: absolute;
    right: 0;
    top: 1.25em;
    transform: rotate(90deg);
    transition: all 0.25s;
}

.navbar-nav:not(.sm-collapsible) .dropdown-item .sub-arrow, .navbar-nav:not(.sm-collapsible):not([data-sm-skip]) .dropdown-menu .dropdown-toggle::after {
    border: none;
    width: .625rem;
    height: .625rem;
    background-image: url(../../images/arrow-right-gray.svg);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: .625rem .625rem;
}

.navbar-nav .nav-item.active .nav-link {
    color: #d22030;
}

.dropdown-item.active, .dropdown-item:active {
    color: #fff;
    text-decoration: none;
    background-color: #d22030;
}

.dropdown-toggle::after {
   display:none
}

@media (min-width: 992px) {	

	.navbar {
		margin-top: 0; 
	}

	.navbar-nav .nav-item.active .nav-link {
		position: relative;
	}

	.navbar-nav .nav-item.active:hover .nav-link:after {
		border-color: #777;
	}

	.navbar-nav .nav-link {
		padding: .5rem 0!important;
		margin-right: 1.5rem;
		font-size: 1rem;
		border-bottom: 0;
	}
	.navbar-nav .nav-item:last-child .nav-link {
		margin-right:0; 
	}

	.navbar-nav .dropdown-menu {
		padding: 0;
		min-width: 15rem !important;
	}

}

@media (min-width: 1200px) {

	.navbar-nav .nav-link {
		margin-right: 2rem;
	}

}


/* ------------------------------------------------------------------------ Navbar Toggler */

.navbar-toggler {
	padding: 0 0 0 1rem;
	border: none;
	cursor: pointer;
}

.navbar-toggler-icon {
    background-image: url(../../images/menu-icon.svg);
}

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
	background-image: url(../../images/menu-icon-open.svg);
}

@media (min-width: 992px) {

	.navbar-toggler {
		display: none;
	}

}

/* ------------------------------------------------------------------------ Top Buttons */

.float__quote__btn {
	position:relative;
	right: 0;
	z-index: 1050;
	top: 0em;
	font-family: 'Roboto Slab', serif;
}

.float__quote__btn div.quote_btn:hover, .float__quote__btn div.phone_btn:hover {
	text-decoration: none;
	opacity: 0.7;
}

.float__quote__btn div.quote_btn, .float__quote__btn div.phone_btn {
	font-weight: 400;
	text-transform: uppercase;
	color: #fff;
	padding: 0.5em 1em;
	text-align: center;
	transition: all 0.25s;
	display: block;
	width: 100%;
}

.float__quote__btn div.quote_btn {
	background: #d22030;
	font-size: 0.85rem;
}

.float__quote__btn div.phone_btn {
	background: #000000;
	font-size: 0.85rem;
}

.float__quote__btn div.phone_btn::before {
	/*display: inline-block;*/
	content: ' ';
	background-image: url(../../images/phone-icon.png);
	background-repeat: no-repeat;
	background-size: 15px 15px;
	width: 15px;
	height: 15px;
	position: relative;
	top: 0.15em;
	margin-right: 0.8em;
	display: none;
}


    .float__quote__btn div {
    	width: 100%;
    }
 
@media (min-width: 320px) {	 
   
   .float__quote__btn div.quote_btn {
    	font-size: 0.7rem;
    	padding: 1.06em 0;
    }
    
    .float__quote__btn div.phone_btn {
    	font-size: 1rem;
    	
    }
   
    /*.float__quote__btn div.phone_btn::before {
    	background-size: 10px 10px;
    	width: 10px;
    	height: 10px;
    }*/
   
    .float__quote__btn div {
    	width: 50%;
    }
}

@media (min-width: 480px) {	
    .float__quote__btn div.quote_btn {
    	font-size: 1rem;
    	padding: 1.15em 0;
    }
    
    .float__quote__btn div.phone_btn {
    	font-size: 1.5rem;
    	padding: 0.5em 1em;
    }
    
    /*.float__quote__btn div.phone_btn::before {
    	background-size: 15px 15px;
    	width: 15px;
    	height: 15px;
    }*/
    
    
}

@media (min-width: 576px) {	
    .float__quote__btn div.quote_btn {
    	font-size: 1rem;
    	padding: 0.5em 1em;
    }
    
    .float__quote__btn div.phone_btn {
    	font-size: 1rem;
    }
    
    /*.float__quote__btn div.phone_btn::before {
    	background-size: 15px 15px;
    	width: 15px;
    	height: 15px;
    }*/
}

@media (min-width: 768px) {	
    .float__quote__btn div.quote_btn {
    	font-size: 1.15rem;
    }
    
    .float__quote__btn div.phone_btn {
    	font-size: 1.15rem;
    }
    
    /*.float__quote__btn div.phone_btn::before {
    	background-size: 15px 15px;
    	width: 15px;
    	height: 15px;
    }  */ 
}

@media (min-width: 992px) {

	.float__quote__btn {
		position: absolute;
		right: 30px;
		z-index: 1050;
		top: 0;
	}
	
	.float__quote__btn div.quote_btn {
		font-size: 1.1rem;
		padding: 0.5em 2em;
		display: block;
	}
	
	.float__quote__btn div.phone_btn {
		font-size: 1.1rem;
		padding: 0.5em 2em;
		display: block;
	}
	
	.float__quote__btn div {
	    width: auto;
	}
	
	.float__quote__btn div.phone_btn::before {
    	background-size: 15px 15px;
    	width: 15px;
    	height: 15px;
    	display:inline-block;
    }   

}



/* =============================================================================================
	MAIN CONTENT AREA
============================================================================================= */

div p {
    margin-bottom: 1em;
}

div p:last-child {
    margin-bottom: 0;
}

@media (min-width: 992px) {		
	
	.aside {
		padding-left: 1rem
	}
	
	.main--full-width {
		width: 100%;
		padding-left: 0;
	}

	main p,
	main li,
	label,
	table {
		font-size: 1rem;
	}	
					
}

.container {
    padding-right: 30px;
    padding-left: 30px;
}

.steps--container {
    max-width: 1112px;
    width: 100%;
}

@media (min-width: 1440px) {
	.container {
	    max-width: 1360px;
	}
}

@media (min-width: 992px) {
	.container-mobile-fluid {
		max-width: 960px;
	}
}

@media (min-width: 1200px) {
	.container-mobile-fluid {
		max-width: 1140px;
	}
}

@media (min-width: 1440px) {
	.container-mobile-fluid {
		max-width: 1360px;
	}
}


.container-mobile-fluid {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
	}


/* ------------------------------------------------------------------------ Sidenav */

.sidenav {
	background-color: #eee;
}

.sidenav.sticky-top {
	top: 102px; /*This will change depending on the height of the header*/
}

.sidenav__header {
	padding: .75rem 1.25rem;
	background-color: #222;
}

.sidenav__header-link {
	color: #fff;
	display: block;
	transition: all 0.25s;
}

.sidenav__header-link:hover {
 	color: #777; 
 	text-decoration: none;
}

.sidenav__list {
	list-style: none;
}

.sidenav__item {
	line-height: 1.4;
	padding: 0;
	border-top: 1px solid #fff;
	background-image: none;
}

.sidenav__item.active > .sidenav__link {
    color: #666;
    font-weight: 700;
}

.sidenav__link {
	display: block;
	font-size: 1rem;
	padding: .75rem 1.5rem;
	color: #444;
	font-weight: 400;
}

.sidenav__link:hover { 
	background-color: rgba(0,0,0,.1);
	color: #444;
	text-decoration: none;
}

.sidenav__sub-list {
	background-color: #ddd;
	margin:0;
}

.sidenav__sub-list .sidenav__item { 
	background: url(../../images/arrow-right-gray.svg) no-repeat 2rem 1.125rem;
	background-size: 0.625rem 0.625rem;
}

.sidenav__sub-list .sidenav__link {
	padding-left: 3rem ;
}


@media (max-width: 992px) {

	.sidenav.sticky-top {
		position: static; /*disable on smaller screens*/
	}

}


/* ------------------------------------------------------------------------ Sections */

.section--xs {
	padding: 1rem 0;
}

.section--sm {
	padding: 1.75rem 0;
}

.section { 
	padding: 3rem 0;
}


body section:nth-child(odd) {
  background-color: #f0f0f0;
}

/*.section--grey {
	background-color: #f0f0f0;
}
*/

.section--darkgrey {
	background-color: #333;
}

.section--red {
	background-color: #d22030 !important;
}

.section--red .cta__heading a {
    color: #fff !important;
}

.section__five__reasons, .section__boxes {
	background: #f0f0f0;
	background-size: cover;
}

@media (min-width: 992px) {
	.section__five__reasons {
		background: url(../../images/cta__background.jpg) center center no-repeat;
		background-size: cover;
	}
	
	.section__boxes {
		background: url(../../images/card-bg.jpg) center center no-repeat;
		background-size: cover;
	}
}

@media (min-width: 768px) {	
	
	.section--sm {
		padding: 2.5rem 0;
	}
	
	.section { 
		padding: 3.5rem 0; 
	}

}


/* ------------------------------------------------------------------------ Call To Action */

.arrow__container {
	position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 50%);
	z-index: 1;
}

.arrow__down {
	width: 20px;
    height: 20px;
    transform: rotate(45deg);
    background: #d22030;
}

@media (min-width: 768px) {
    .arrow__down {
    	width: 40px;
        height: 40px;
    }
}

/* ------------------------------------------------------------------------ Carousel */	

.carousel__link {
	display: block;
}

.carousel__btn {
	transition: all 0.25s;
}

.carousel__link:hover .carousel__btn {
	background-color: #777
}

.carousel__image {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	min-height: 15rem;
	background-color: #ddd;
	transition: opacity 0.25s ease-in-out;
	position: relative;
	z-index: 0;
}

.carousel__link:hover .carousel__image {
	opacity: .9;
}

.carousel__heading {
    font-size: 1.5rem;
    line-height: 1;
    font-weight: 800;
    margin-bottom:.5rem;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.25);
    letter-spacing: -1px;
    text-transform: none;
    display:block;
}

.carousel__link:hover {
	text-decoration: none;
}

.carousel__subheading {
	text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.25);
	font-weight:400;
	font-size: 1em;
	letter-spacing: -1px;
	text-transform: none;
	display:block;
	font-size: 1.25rem;
}

.carousel__subheading-sm {
	text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.25);
	font-weight:400;
	font-size: 1em;
	text-transform: none;
	display:block;
	font-size: 1.25rem;
	text-transform: uppercase;
    margin-bottom: 0.5em;
    letter-spacing: 0;
    font-weight: bold;
}

.carousel-indicators {
	display: none;
}

.carousel-caption { 
    margin: 0 auto;
    padding: .5rem 1rem;
    transition: all 0.25s;
    left: 0;
    right: 0;
	bottom: 15%;
}

.carousel-control-next, .carousel-control-prev {
	align-items: stretch;	
}

.carousel-control-next-icon, .carousel-control-prev-icon {
	width: 2rem;
	height: 2rem;
	margin-top: 6.5rem;
	transition: all 0.25s;
}

.carousel-control-prev-icon {
	background-image: url(../../images/carousel-control-prev-icon-white.svg);
}

.carousel-control-next-icon {
	background-image: url(../../images/carousel-control-next-icon-white.svg);
}

@media (min-width: 576px) {	

	.carousel__image {
		min-height: 18rem;
	}

	.carousel-control-next-icon, .carousel-control-prev-icon {
		margin-top: 8rem;
	}

	.carousel-control-prev:hover {
	padding-right: .75rem;
	}

	.carousel-control-next:hover {
		padding-left: .75rem;
	}

}

@media (min-width: 992px) {	

	.carousel__image {
		min-height: auto;
		height: 0;
		padding-bottom: 34%;
	}

	.carousel__link:hover .carousel-caption {
		transform: translateY(-.375rem);
	}

	.carousel__image:after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 50%;
		/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0+0,0.25+100 */
		background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%); /* FF3.6-15 */
		background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.6) 100%); /* Chrome10-25,Safari5.1-6 */
		background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.6) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#40000000',GradientType=0 ); /* IE6-9 */
		z-index: 1;
	}
	
	.carousel__subheading {
		font-size: 2rem;
	}
	
	.carousel__subheading-sm {
		font-size: 1.25rem;
	}
	
	.carousel__heading {
	    font-size: 2.5rem;
	}

	.carousel-control-next, .carousel-control-prev {
		align-items: center;
	}

	.carousel-control-next-icon, .carousel-control-prev-icon {
		width: 3rem;
		height: 3rem;
		margin-top:0;
	}

}

@media (max-width: 992px) {	

	.carousel-caption {
		position: absolute;
		right: auto;
		left: auto;
		bottom: 0;
		background-color: rgba(0,0,0,0.6);
	}

}

@media (min-width: 1200px) {

	.carousel__image {
		padding-bottom: 36%;
	}
	
	.carousel__subheading {
		font-size: 3rem;
		line-height: 1.35;
	}
	
	.carousel__subheading-sm {
		font-size: 1.25rem;
		line-height: 1.5;
	}
	
	.carousel__heading {
	    font-size: 3.25rem;
		max-width: 13.5em;
		width: 100%;
	}
	
	.carousel__heading.w-unset {
	    max-width: unset;
	    width: 100%;
	}

}

@media (min-width: 1920px) {

	.carousel__image {
		min-height: 43rem;
		padding-bottom: 0;
	}

}

/* ------------------------------------------------------------------------ Video Banner */

.video-section {
  position: relative;
  width: 100%;
  height: 600px; /* Adjust height as needed */
  overflow: hidden;
  background-color: unset !important;
}

.video-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: -1;
}

.video-background iframe,
.video-background video { /* Selector now includes the new video tag */
  position: absolute;
  top: 50%;
  left: 50%;
  /* Original logic for cover effect */
  width: 100vh;
  height: 100vw;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.video-overlay {
    width: 100%;
    height: 100%;
    position: absolute;
    top:0;
    background-color: rgba(0,0,0,0.5);
}

.video-content {
 position: absolute;
    z-index: 1;
    color: #fff;
    text-align: center;
    padding: 50px 20px;
    bottom: 0;
    width: 100%;
    margin: 0 auto;
    padding: .5rem 1rem;
    transition: all 0.25s;
    left: 0;
    right: 0;
    bottom: 15%;
}

.video-content h1 {
    font-size: 4.5rem;
    letter-spacing: 0px;
    line-height: 1.15;
    margin-bottom: 0;
    font-weight: bold;
}

.video-content p.subheading {
    font-size: 1.5rem;
}

/* ------------------------------------------------------------------------ Jumbotron/banner */

.jumbotron {
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	padding: 0;
	margin-bottom: 0;
	min-height: 15rem;
	background-color: #ddd;
}


#jumbotron-caption {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0+0,0.25+100 */
	background: -moz-linear-gradient(top, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.3) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top, rgba(0,0,0,0.1) 0%,rgba(0,0,0,0.3) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%,rgba(0,0,0,0.3) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#40000000',GradientType=0 ); /* IE6-9 */
    z-index: -1;
}


.container-fluid h1 {
	font-size: 1.7rem;
	text-align:center;
}
	
.container-fluid {
	padding: 6.5rem 3rem;
	transition: all 0.25s;
	color: #fff;
	position: relative;
	z-index: 2;
}

.mt-insidepage h1 {
	font-size: 2.5rem;
}

@media (min-width: 576px) {	

	.jumbotron {
		min-height: 14rem;
	}
	.container-fluid h1 {
		font-size: 2.5rem;
		text-align:center;
	}

}

@media (min-width: 992px) {	
	
	.jumbotron {
		min-height: 22rem;
	}
	
	.container-fluid {
	padding: 15.5rem 3rem 6rem;
	}
	
	.container-fluid h1 {
		position: relative;
		/*top: 3.5rem;*/
	}
	
	.mt-insidepage h1 {
		font-size: 3.5rem;
	}

}

@media (min-width: 1200px) {	

	.jumbotron {
		min-height: 24rem;
	}

}


/* ------------------------------------------------------------------------ Callouts */

.callout-group { padding-top: .5rem; }

.callout-group__callout {
	display: block;
	font-weight: 400;
	position: relative;
	color: inherit;
	cursor:pointer;
}

.callout-group__callout:hover {
	text-decoration: none;
	color: inherit;
}

.callout-group__image {
	height: 0;
    padding-bottom: 20%;
    background-repeat: no-repeat;
    background-size: contain;
    transition: all 0.25s ease-in-out;
	background-position: center;
}

.callout-group__callout:hover .callout-group__image {
	opacity: 0.9;
	transform: scale(1.01);
}

.callout-group__heading {
	margin-top: 1rem;
	font-weight: 700;
	text-align: center;
	transition: all 0.25s;
}

.callout-group__callout:hover .callout-group__heading{
	color: #777;
}

.callout-group__text {
	font-size: 1rem;
	text-align: center;
	color: #888;
}

.callout-group__callout--stacked:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.25);
}

.callout-group__callout--stacked .callout-group__heading {
	position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    color: #FFF;
    text-align: center;
    width: 100%;
    margin: 0;
    padding: 0 1rem;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.25);
}

.callout-group__callout--stacked:hover .callout-group__heading{
	color: #fff;
}

@media (min-width: 576px) {	
    .callout-group__image {
        padding-bottom: 12%;
    }
}

@media (min-width: 992px) {	

	.callout-group__image {
    	padding-bottom: 100%;
	}

}


/* ------------------------------------------------------------------------ Five Reasons Section */


a .reasons {
	color: #333;
	font-weight: 400;
	text-decoration: none !important;
	transition: all 0.25s;
}

a:hover .reasons {
	color: #d22030;
	text-decoration: none !important;
	transition: all 0.25s;
}


@media (min-width: 992px) {	
	
	a .reasons .info {
		padding-left: 2em;
		transition: all 0.25s;
	}

	a:hover .reasons .callout-group__image {
		margin-left: 0.5em;
		transition: all 0.25s;
	}

	a:hover .reasons .info {
		padding-left: 1.5em;
		transition: all 0.25s;
	}
}


/* ------------------------------------------------------------------------ Cards */

.last-block .col-md-4, .last-block .col-lg-6 {
    margin-bottom: 4em;
}

@media (max-width: 768px) {	
    .last-block .col-md-4:last-child, .last-block .col-lg-6:last-child  {
        margin-bottom: 0;
    }
}

.card, .card-header:first-child  {
	border-radius: 0;
}

.card:hover {
	text-decoration: none;
}

.card-header {
	background-color: #222;
    border-bottom: 0;
    color: #fff;
    font-weight: 700;
}

.card__header-link {
	color: #fff;
	display: block;
	transition: all 0.25s;
}

.card__header-link:hover {
 	color: #777; 
 	text-decoration: none;
}

.card__header-no-link {
	transition: all 0.25s;
}

.card:hover .card__header-no-link {
	color: #777;
}

.card-text {
	font-size: 1rem;
	font-weight: 400;
	color: #444;
}

.card__date, .card:hover .card__date {
	color: #888;
}

.card-text small {
	font-size: 90%;
}

.card--open-concept {
	border:none;
	background-color: transparent;
}

.card--open-concept:hover {
	background-color: transparent;
}

.card--open-concept .card-body{
	padding: 0;
}


.card--open-concept:hover .btn {
	background-color: #777;
}

.section__boxes .col-md-6 {
	margin-bottom: 3em;
}

.section__boxes .col-md-6:nth-last-child(-n + 2) {
	margin-bottom: 3em;
}

.section__boxes .col-md-6:last-child {
	margin-bottom: 0em;
}

.card.card-service{
	padding: 1.5em;
	-webkit-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	border: none;
	transition: all 0.25s;
	color: #333;
	font-weight: 400;
	cursor: default;
}

.card.card-service .card-title {
    text-align: center;
}

.card.card-service .icon {
    margin-bottom: 1em;
}

.card.card-service .icon img {
    max-width: 80px;
    width: 100%;
    margin: 0 auto;
}

.card.card-profile {
    text-align: center;
	padding: 1.5em;
	-webkit-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	border: none;
	transition: all 0.25s;
	color: #333;
	font-weight: 400;
	cursor: default;
}

.card.card-profile:hover {
	background: #333;
	transition: all 0.25s;
	color: #fff;
}

.card.card-profile .card-avatar {
    width: 75px;
	height: 75px;
    max-width: 75px;
    max-height: 75px;
    margin: -50px auto 0;
    border-radius: 50%;
    padding: 0.1em;
    background: #fff;
    font-size: 2.5em;
	border: solid 2px #d22030;
	color: #333;
	font-weight: 600;
	transition: all 0.25s;
}

.card.card-profile:hover .card-avatar {
    background: #d22030;
	border: solid 2px #fff;
	color: #fff;
	transition: all 0.25s;
}

.card .card-header.card-header-image {
    position: relative;
    padding: 0;
    z-index: 1;
    margin-left: 15px;
    margin-right: 15px;
    margin-top: -30px;
    border-radius: 6px;
    max-height: 215px;
}

.card .card-header.card-header-image a {
    display: block;
}

.card .card-header.card-header-image img {
    width: 100%;
    height: 215px;
    border-radius: 6px;
    pointer-events: none;
    box-shadow: 0 5px 15px -8px rgba(0,0,0,.24), 0 8px 10px -5px rgba(0,0,0,.2);
}

.card .card-header.card-header-image .colored-shadow {
    transform: scale(.94);
    top: 12px;
    filter: blur(12px);
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    z-index: -1;
    transition: opacity .45s;
    opacity: 1;
}

.card-title {
	font-size: 1.5em;
	font-weight: 600;
}

.card .card-header.card-header-image .card-title {
    position: absolute;
    bottom: 5px;
    left: 15px;
    color: #fff;
    font-size: 1.125rem;
    text-shadow: 0 2px 5px rgba(33,33,33,.5);
    font-weight: 700;
    font-family: 'Roboto Slab';
}

.card .card-body+.card-footer {
    padding-top: 0;
    border: 0;
    border-radius: 6px;
}

.card .card-footer {
    display: flex;
    align-items: center;
    background-color: transparent;
    border: 0;
}

.card-profile .card-footer .btn.btn-just-icon{
    font-size: 20px;
    padding: 12px 13px;
    line-height: 1em;
}

.card .card-footer {
    padding: .9375rem 1.875rem;
}


.card-profile .card-body+.card-footer{
    margin-top: -15px;
}
.card .text-info {
    color: #00bcd4!important;
}


.card.cardbox {
	border: none;
	-webkit-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	font-weight: normal;
}

.cardbox__image {
	height: 0;
    padding-bottom: 40%;
    background-repeat: no-repeat;
    background-size: cover;
    transition: all 0.25s ease-in-out;
	background-position: center center;
}

.cardbox__image__container {
	height: 0;
    padding-bottom: 65%;
    background-repeat: no-repeat;
    background-size: cover;
    transition: all 0.25s ease-in-out;
	background-position: center center;
}

.cardbox-title p {
	font-size: 1.5em;
    font-weight: 400;
}

.cardbox .card-body {
	padding: 1.5em;
}

a .card.cardbox {
    color: #333;
}

a:hover .card.cardbox {
    color: #777;
}

.card.cardbox__dk {
    background: none;
    border:none;
}

.card.cardbox__dk .cardbox-title p {
    font-size: 1em;
    text-align: center;
}

.card.cardbox__dk:hover .cardbox-title p{
    color: #ddd;
}

.card.cardbox__dk .cardbox__image {
    padding-bottom: 60%;
}

.storage__image {
	height: 0;
    padding-bottom: 60%;
    background-repeat: no-repeat;
    background-size: contain;
    transition: all 0.25s ease-in-out;
	background-position: center center;
}

.storage-title {
	background: #d22030;
	color: #fff;
	font-size: 1.25em;
	font-weight: 600;
	padding: 1em 1.5em;
}

.storage-title p {
	font-size: 1.25em;
	margin: 0;
}

@media (min-width: 992px) {
	.section__boxes .col-md-6:nth-last-child(-n + 2) {
		margin-bottom: 0em;
	}
}

a .card.blogbox {
	border: none;
	-webkit-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
	transition: all 0.25s;
	font-weight: 400;
}

a:hover .card.blogbox {
	background: #000;
	transition: all 0.25s;
	color: #fff;
}

a .blogbox__image {
	height: 0;
    padding-bottom: 60%;
    background-repeat: no-repeat;
    background-size: cover;
    transition: all 0.25s;
	background-position: center center;
}

a:hover .blogbox__image {
	opacity: 0.5;
}

a .blogbox-title {
	font-size: 1.25em;
    font-weight: 400;
    line-height: 1.4;
    margin-bottom: 0.5em;
}

a .blogbox-summary {
    margin-bottom: 4.5em;
}

a .blogbox .card-body {
	padding: 1.5em;
	color: #000;
	transition: all 0.25s;
}

a:hover .blogbox .card-body {
	color: #fff;
	transition: all 0.25s;
}

a .blogbox .blog-btn {
	background: #d22030;
	color: #fff;
	padding: 0.5em 1em;
	display: inline-block;
	margin-top: 1em;
	transition: all 0.25s;
	font-weight: 700;
	position: absolute;
    bottom: 1.5em;
}

a:hover .blogbox .blog-btn {
	background: #fff;
	color: #333;
	transition: all 0.25s;
}

@media (min-width: 992px) {
    a .blogbox-title {
    	font-size: 1.5em;
    }
}

/* ------------------------------------------------------------------------ Call To Action */


.cta__heading {
	font-size: 1em;
	color: #fff;
	line-height: 1.25;
	letter-spacing: -1px;
}

.cta__heading span {
	font-size: 1.6em;
	font-weight: 600;
}

@media (min-width: 992px) {	

	.cta__heading {
		font-size: 1.25em;
	}
}

@media (min-width: 1200px) {	

	.cta__heading {
		font-size: 1.45em;
	}
}

/* ------------------------------------------------------------------------ Full Width Image */

.full-width-image {
	position: relative;
    overflow: hidden;
}

.full-width--image__area {
	position: relative;
    overflow: hidden;
	width: 100%;
	height: 15em;
}

.image__area__left {
	left: 0;	
}

.image__area__right {
	right: 0;
}

@media (min-width: 992px) {
.full-width--image__area {
    overflow: hidden;
    position: absolute;
    top: 0;
    bottom: 0;
    width: 50%;
    min-width: 1px;
    max-width: none;
    height: 100%;
    min-height: 100%;
    max-height: none;
    margin: 0;
    z-index: 0;
	}
}

.full-width-image {
    min-height: 22em;
}

.bg-image {
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
}


/* ------------------------------------------------------------------------ Accordion */


.accordion {
	background-color :#fff;
	position: relative;
}

.accordion .card  {
	background-color: #f8f8f8;
	border:none;
}

.accordion-header {
    color: #333;
    cursor: pointer;
    padding: 1em 1.5em;
    font-size: 1em;
    border-bottom: solid 1px #f0f0f0;
    border-left: solid 3px #d22030;
    font-weight: bold;
    transition: all 0.25s;
    position: relative;
}

.accordion-header p {
    width: 90%;
    margin-bottom: 0;
    display: inline-block;
}

.accordion-header.active {
    color: #d22030;
    transition: all 0.25s;
}

.accordion-header:hover {
    background: #F6F7F9;
}

.accordion-content {
    display: block;
    border-bottom: 1px solid #DDE0E7;
    background: #fafafa;
    padding: 1.5rem;
}

.accordion-header::after {
    content: '';
    position: absolute;
    background-image: url(../../images/arrow-right-grey.png);
    background-size: 14px 13px;
    width: 14px;
    height: 13px;
    margin-top: 0.3em;
    right: 2em;
    margin-left: auto;
    margin-right: auto;
}

.active.accordion-header::after {
    background-image: url(../../images/arrow-down-grey.png);
}


/* ------------------------------------------------------------------------ List Group */

.list-group__link {
	display: block;
	font-weight: 400;
	transition: all 0.25s;
	padding: 1.0rem 1.25rem;
}

.list-group__link:hover {
	text-decoration: none;
	background-color: #f8f8f8;
}

.list-group__link:hover .list-group__heading {
	text-decoration: none;
}

.list-group-item, .list-group-item:last-child {
	padding: 0;
	background-image: none;
}


.list-group-item.active {
	background-color: #666;
    border-color: #666;
}

/* ------------------------------------------------------------------------ List Group */

ul.checkmark li {
    padding: 0 0 1.25rem 2rem;
	background: url(../../images/checkmark.svg) no-repeat left 0.4rem;
	background-size: 1.25rem 1.25rem;
	
}

/* ------------------------------------------------------------------------ Accordions */

.accordion {
	background-color :#fff;
}

.accordion .card  {
	background-color: #f8f8f8;
	border:none;
}


/* ------------------------------------------------------------------------ Pagination */

.page-item {
	font-size: 1rem;
	background-image: none;
	padding: 0;
}

.page-item a img {
    max-width: 0.5em;
}

.page-link {
	font-weight: 400;
	color: #666;
}

.page-item.active .page-link {
	background-color: #666;
	border-color: #666;
}


/* ------------------------------------------------------------------------ Quote Page */

.quote__box {
    padding: 2em;
    -webkit-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
    -moz-box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
    box-shadow: 0px 2px 17px -5px rgba(0,0,0,0.3);
    background: #fff;
}

.quote__box .col-lg-4:nth-child(2) {
    border-left: 0;
    border-right: 0;
    border-top: solid 1px #ddd;
    border-bottom: solid 1px #ddd;
}

.quote__heading {
	font-size: 1.5rem;
	font-weight: bold;
	background: #d22030;
	color: #FFF;
}

.storage-box ul {
    margin-top: 1em;
}

.storage-box .title {
	background: #d22030;
	color: #fff;
	font-weight: bold;
	text-transform: uppercase;
	text-align: center;
	padding: 10px;
}

/*.storage-box .title--small {
	background: #d22030;
	color: #fff;
	font-size: 12px;
	font-weight: bold;
	text-transform: uppercase;
	text-align: center;
	padding: 3px 8px;
	display: inline-block;
}*/

.storage-box .title--small {
	color: #d22030;
	font-weight: bold;
	text-align: center;
	font-size: 20px;
}

.note {
	font-style: italic;
	font-size: 0.85em;
	font-weight: bold;
}

@media (min-width: 992px) {
    .quote-checklist {
        min-height: 11.9em;
    }
    
    .quote__box .col-lg-4:nth-child(2) {
        border-left: solid 1px #ddd;
        border-right: solid 1px #ddd;
        border-top: 0;
        border-bottom: 0;
    }
}

@media (min-width: 1200px) {
    .quote-checklist {
        min-height: 17.5em;
    }
}

@media (min-width: 1200px) {
    .quote-checklist {
        min-height: 14.5em;
    }
}

/* ------------------------------------------------------------------------ Tables */

.table {
	background-color: #fff;
	font-size: 1rem;
}

.table .thead-dark th {
	background-color: #222;
    border: none;
}

.table td, .table th {
    border-top: 1px solid rgba(0,0,0,.125);
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: #f8f8f8;
}

.table td {vertical-align: middle;}

.table-md td, .table-md th {padding: .5rem;}

.table .custom-control {
	margin: 0;
	padding-left: 1.5rem;
    }
		

	/* ------------------------------------------------------------------------ Moving Services Table */
	
	.table-moving-services table thead tr th:first-child {
		background: none;
	}

	.table-moving-services table tr td:first-child {
		background: #000;
		color: #fff;
		font-weight: 600;
		border-bottom: solid 1px #333;
	}

	.table-moving-services table tr td, .table-moving-services table tr th {
		padding: 1em 1.5em;
	}

	.table-moving-services .table {
		background: none;
	}

	.checkmark--icon {
		width: 100%;
		max-width: 30px;
	}

	.checkmark--icon--grey {
		width: 100%;
		max-width: 20px;
	}

/* ------------------------------------------------------------------------ Forms */

.field-validation-error {
    color: #990000;
    font-size: 0.8em;
    font-style: italic;
    padding: 0.5em 0 0 0;
}
	
legend { font-size: 1.25rem;}

.required-input {
	color: #e7004c !important;
	font-size: 0.875rem;
	font-weight:bold;
}

.form-text {
	font-style: italic;
	font-size: 80%;
    font-weight: 400;
    }

.form-control {
	border-radius:0;
	border-color: #ddd;
	padding: .5rem .75rem;
}

.form-control:focus {
	box-shadow: none;
	border-color: rgba(0, 0, 0, 0.5);
}

select.form-control:not([size]):not([multiple]) {
    height: calc(2.5rem + 2px);
}

.form-check-label {
    margin-right:1em;
}

.form-control-file {cursor: pointer;}

/*custom radio and checkbox*/
.custom-control {
	padding-left: 1.75rem;
	margin-bottom: 0;
	cursor: pointer;
}

.custom-control-description {
	font-weight: 400;
}

.custom-control-indicator {
	top: .375rem;
	width: 1.125rem;
    height: 1.125rem;
    background-color: #f8f8f8;
    border: 1px solid #ddd;
    border-radius: 2px;
}

.custom-control-input:checked~.custom-control-indicator {
	background-color: #666;
	border-color: #666;
}

.custom-control-input:focus ~ .custom-control-indicator {
    box-shadow: none;
    border-color: #000;
}

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 30px white inset;
}		

input[type=radio] {
	-webkit-appearance: none;
    -moz-appearance: none;
    border: 2px solid #f0f0f0;
    border-radius: 15px;
	padding: 2px;
    width: 19px;
    height: 19px;
	cursor: pointer;
	position: relative;
    top: 0.25em;
}

input[type=radio]:checked {
	-webkit-appearance: none;
    -moz-appearance: none;
    border: 2px solid #d22030;
	background: #f0f0f0;
    border-radius: 15px;
	padding: 2px;
    width: 19px;
    height: 19px;
}

/* ------------------------------------------------------------------------ Reviews */

.star__review {
    max-width: 20px;
    width: 100%;
}

.google__review {
    max-width: 250px;
    width: 100%;
}

.block {
	background: #ffffff;
	border: solid 1px #ddd;
	padding: 2em;
}

.reviews .testimonial__block {
	margin-bottom: 2em;
}

/* ------------------------------------------------------------------------ Popup gallery */

.ekko-lightbox .modal-dialog {
  flex: 100%!important;
  margin-left: 0;
  margin-right: 0;
}


/* ------------------------------------------------------------------------ Quote Page Modal */

.modal {
    background: rgba(0,0,0,0.4);
}

.quotePageModal .modal-header {
    border-bottom: 0;
}

.quotePageModal .btn-close {
    background-color: var(--blue);
    opacity: 1;
    background-image: url('../../images/close-light.svg');
    right: -1.25em;
    top: -1.25em;
    border: 0;
    background-color: var(--red);
    padding: 1.25em;
    border-radius: 100%;
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
}

.quotePageModal .modal-content {
    background: var(--cream);
    border: 0;
    box-shadow: 0 4px 15px rgba(0,0,0,0.5);
}

.quotePageModal .modal-body {
    padding: 4em;
    background: var(--white);
}

/* ------------------------------------------------------------------------ Search Results */

.search-row {
    border-bottom: solid 1px #eee;
}
			
/* =============================================================================================
	FOOTER
============================================================================================= */

.print-footer { 
	display:none;
}

.footer { 
	padding: 2rem 0;
	background: #333;
	color: #fff;
	font-size: 0.85em;
}

.footer__heading {
	color: #fff;
	font-weight: 700;
	font-size: 1.25em;
}

.footer__rkd {
	display: inline-block;
	width: 5.625rem; 
}

.footer__copyright {
	margin-bottom: 0;
	font-size: 0.875rem;
}	

.footer__link {
	margin-right: 1rem;
	color: #fff;
	font-weight: 400;
	font-size: 1em;
	}
	
.footer__link:hover {
    color: #d22030;
}

/*.footer__link::before {
	display: inline-block;
	content: ' ';
	background-image: url(../../images/arrow-right-white.svg);
	background-repeat: no-repeat;
	background-size: 10px 10px;
	width: 10px;
	height: 10px;
	position: relative;
	margin-right: 0.8em;
}*/

ul.footer__quick__link {
    padding-left: 0;
}

ul.footer__quick__link li {
	padding: 0 0 0.25rem 1rem;
    background: url(../../images/arrow-right-white.svg) no-repeat left 0.625rem;
    background-size: 0.625rem 0.625rem;
    padding-left: 1.5em;
    text-align:left;
}
		
.footer__icon {
	display: inline-block;
	width: 2.75rem;
	height: 2.75rem;
	margin: 0 0 0 0.5em;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 1.25rem 1.25rem;
	background-color: #d22030;
}

.footer__icon:hover { 
	background-color: #111;
}

.footer__icon--twitter { 
	background-image: url(../../images/twitter.svg); 
}
	
.footer__icon--facebook { 
	background-image: url(../../images/facebook.svg); 
}
	
.footer__icon--youtube { 
	background-image: url(../../images/youtube.svg); 
}		
			
.footer__icon--instagram { 
	background-image: url(../../images/instagram.svg); 
}		

.footer__icon--linkedin { 
	background-image: url(../../images/linkedin.svg); 
}

.phone_link, .email_link {
	color: #fff;
}

.phone_link::before {
	display: inline-block;
	content: ' ';
	background-image: url(../../images/phone-icon.png);
	background-repeat: no-repeat;
	background-size: 15px 15px;
	width: 15px;
	height: 15px;
	position: relative;
	top: 0em;
	margin-right: 0.8em;
}

.email_link::before {
	display: inline-block;
	content: ' ';
	background-image: url(../../images/email-icon.svg);
	background-repeat: no-repeat;
	background-size: 18px 18px;
	width: 18px;
	height: 18px;
	position: relative;
	top: 0.2em;
	margin-right: 0.8em;
}

	
@media (min-width: 992px) {

	.footer {
		height: 360px;
		overflow: hidden;
		width: 100%;
		position: absolute;
	    bottom: 0;
	    right: 0;
	    padding: 3rem 0;
	}
	
	ul.footer__quick__link.two-columns {
        columns: 2;
          -webkit-columns: 2;
          -moz-columns: 2;
    }

}

	/* ------------------------------------------------------------------------ Footer - News & Media */
	
	.footer a:last-child .news__media {
		margin-bottom: 0em;
	}

	.footer a .news__media {
		margin-bottom: 1.5em;
	}

	a .news__media {
		color: #fff;
		font-weight: 400;
		text-decoration: none !important;
		transition: all 0.25s;
	}

	a .news__media .date {
		color: #d22030;
		font-weight: bold;
		font-style: italic;
		font-size: 0.6;
	}

	a:hover .news__media {
		color: #ccc;
		transition: all 0.25s;
	}
	
	a:hover .news__media .date {
		color: #fff;
		transition: all 0.25s;
	}


	@media (min-width: 992px) {	

		a .reasons .info {
			padding-left: 2em;
			transition: all 0.25s;
		}

		a:hover .reasons .callout-group__image {
			margin-left: 0.5em;
			transition: all 0.25s;
		}

		a:hover .reasons .info {
			padding-left: 1.5em;
			transition: all 0.25s;
		}
	}
