

@import url('https://fonts.googleapis.com/css?family=Staatliches');
@import url('https://fonts.googleapis.com/css?family=Montserrat:200,300,400,700,900');

@font-face {
	font-family: 'font';
	src:url('../fonts/arvo.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'font2';
	src:url('../fonts/poppins.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}
@font-face {
	font-family: 'font3';
	src:url('../fonts/Copeland.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}
@font-face {
	font-weight: normal;
	font-style: normal;
	font-family: 'feathericons';
	src:url('../fonts/feathericons/feathericons.eot?-8is7zf');
	src:url('../fonts/feathericons/feathericons.eot?#iefix-8is7zf') format('embedded-opentype'),
		url('../fonts/feathericons/feathericons.woff?-8is7zf') format('woff'),
		url('../fonts/feathericons/feathericons.ttf?-8is7zf') format('truetype'),
		url('../fonts/feathericons/feathericons.svg?-8is7zf#feathericons') format('svg');
}


.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  border: 0;
}



.vertically-centered{
	display: flex;
	flex-direction: column;
	justify-content: center; 
}





.pest-expandable-button {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: auto;
  background-color: #f9f9f9;
  color: #000;
  border-radius: 30px;
  overflow: hidden;
  cursor: pointer;
  z-index: 999;
  transition: all 0.4s ease;
  box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}

.pest-expandable-button:hover {
  width: 260px;
  border-radius: 20px;
}

.pest-expandable-button span {
	font-family: font3; font-size: 15px;
}

/* Default collapsed state (shows just icon + label) */
.ppb-main {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  transition: opacity 0.3s ease;
}

.pest-expandable-button img {
  width: 32px;
  height: 32px;
  border-radius: 50%;
}

.pest-expandable-button span {
  white-space: nowrap;
  font-weight: 500;
}

/* Hidden content initially */
.ppb-content {
  max-height: 0;
  opacity: 0;
  padding: 0 16px;
  transition: all 0.4s ease;
  pointer-events: none;
}

/* Reveal on hover */
.pest-expandable-button:hover .ppb-content {
  max-height: 300px;
  opacity: 1;
  padding: 10px 16px 16px;
  pointer-events: auto;
}

/* Inner list */
.ppb-content ul {
  list-style: none;
  padding: 0;
  margin: 0 0 12px 0;
}

.ppb-content li {
  margin: 6px 0; font-family: monospace; text-align: center;
}

.ppb-content li a {
  color: #ed1d26;
  text-decoration: none;
  font-size: 14px;
  transition: color 0.2s ease;
}

.ppb-content li a:hover {
  color: #491218;
}

/* CTA Button */
.pest-cta {
  display: inline-block;
  background-color: #ed1d26;
  color: #fff;
  text-align: center;
  padding: 8px 12px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: bold;
  transition: background-color 0.3s ease;
}

.pest-cta:hover {
  background-color: #000; color: #fff;
}





/* ======================================== */
/* === Top Header Section ================= */
/* ======================================== */
.top-header {
	position: fixed; width: 100%; z-index: 1000; padding: 10px 0 0px 0; background-color: #f9f9f9 !important;	 -webkit-transition: all .30s ease; -moz-transition: all .30s ease; -o-transition: all .30s ease; transition: all .30s ease;    background: linear-gradient(to right, #ffffffd9, #ffffff00), url(/img/homepage/8.png);
    background-size: contain; background-repeat: repeat;    box-shadow: 1px 1px 10px 1px #000;
}
.top-header .container-fluid {
	padding: 0px;
}
.top-header .header-nav-menu {
	position: relative; background: #fff;    margin-bottom: -115px;
    margin-top: 40px;
}
.top-header .header-nav-menu .row {
		    --bs-gutter-x: 1px;
}
.top-header .header-nav-menu h6 {
	font-family: font3; font-size: 20px; padding: 15px 10px 15px 10px; color: #fff; height: 50px;
	
	 background: #000; margin-bottom: 0px; text-align: center;
}
.top-header .header-nav-menu h6:hover {
	color: #ed1d26;
}
.top-header i {
    font-size: 20px;
    height: 40px;
    width: 40px;
    text-align: center;
    padding-top: 10px;
    margin-bottom: -50px;
    border-radius: 5px;
    margin-top: 5px;
    border: 2px solid #000;
    
}
.top-header i:hover {
	box-shadow: 1px 1px 10px 1px #000;background: #fff;border: 2px solid #ed1d26; color: #ed1d26;
}
.top-header a {
	color: inherit;
	
}



.top-header img {
	margin-left: 75px; margin-right: -75px; margin-top: -50px; margin-bottom: 50px;
}
.top-header .header-contact_info {
	padding: 15px; text-align: center; background: #ed1d26; width: fit-content; color: #fff; font-family: font3; letter-spacing: 3px; border-radius: 5px;
}
.top-header .header-contact_info i {
	font-size: 15px; height: auto; width: auto; margin: 0px; padding: 0px; border: none;
}
.top-header .header-contact_info2 {
	padding: 15px; text-align: center; background: #444; width: fit-content; color: #fff; font-family: monospace;  border-radius: 5px;
}
.top-header .header-contact_info2 i {
	font-size: 15px; height: auto; width: auto; margin: 0px; padding: 0px; border: none;
}
.top-header-animate {
margin-top: -100px; transition: 1s;
}
.top-header-animate .header-nav-menu {
	margin-top: 20px;
}
.top-header-animate img {
	    margin-top: 20px;
    margin-bottom: -1px;
    max-width: 75%; transition: 1s;
}
.top-header .dropdown-menu {
	background: whitesmoke; border-radius: 0;
}
.top-header .dropdown-menu a {
	color: #222; padding: 3px 20px !important;
}
.top-header .dropdown-toggle {
	background: #21212100; padding: 6px 25px; outline: none !important; border-color: #f3f3f3b5;
}
.top-header .dropdown-toggle:hover {
	background-color: white !important; color: #000 !important;
}
.btn-secondary:not([disabled]):not(.disabled).active, .btn-secondary:not([disabled]):not(.disabled):active, .show>.btn-secondary.dropdown-toggle {
	color: #000; background-color: rgb(255, 255, 255); border-color: #666e76; box-shadow:none !important;
}
.top-header .btn-secondary.focus,
.btn-secondary:focus {
	outline: none !important; box-shadow: none !important;
}

/* ======================================== */
/* === Navigvation Section ================ */
/* ======================================== */
.navbar-inverse .navbar-inner {
	display:none;
}
.dropdown-menu {
	position: absolute; top: 100%; left: 0; z-index: 1000; display: none; float: left; min-width: 200px; padding: .5rem 0; margin: .125rem 0 0; font-size: 18px; color: rgb(33, 37, 41); text-align: left; list-style: none; background-color: rgb(255,255,255); background-clip: padding-box; border: 1px solid rgba(0,0,0,.15); border-radius: .25rem;
}
.dropdown-menu.columns-3 {
	min-width: 600px;
}
.dropdown-menu li a {
	padding: 5px 15px; font-weight: 300;
}
.dropdown-item {
	display: block; width: 100%; font-weight: 600; font-family: 'font2'; padding: .25rem 1.5rem; clear: both; color: rgb(12,12,12); text-align: inherit; white-space: nowrap; background: 0 0;border: 0;
}
.dropdown-item.active, .dropdown-item:active {
	color: rgb(255,255,255); text-decoration: none; background-color: rgb(22,22,22) !important;
}
.dropdown {
	 position: relative;
}
.dropdown .dropbtn {
	font-family: font3; font-size: 20px; padding: 12px 10px 15px 10px; color: #fff;
	
	; background: #000; margin-bottom: 0px; text-align: center; height: 50px;
}
.navbar a:hover, .dropdown:hover .dropbtn {
	background-color: #ed1d26; color: #000;
}
.dropdown-one {
	cursor: pointer; display: none; position: absolute; background-color: #ed1d26; min-width: 250px; box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
}
.dropdown-two {
	cursor: pointer; display: none; position: absolute; left: 160px; top: 0px; min-width: 160px; background-color: #f9f9f9; box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
}
.dropdown-three {
	cursor: pointer; display: none; position: absolute; left: 160px; top: 48px; min-width: 160px; background-color: #f9f9f9; box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
}
.dropdown:hover .dropdown-one, #link1:hover > .dropdown-two {
	display: block;
}
.dropdown:hover .dropdown-one, #link2:hover > .dropdown-three {
	display: block;
}
.dropdown-one .dItem {
	color: #fff; padding: 12px 16px; display: block; text-align: left; font-family: Atlassian Sans;
}
.dropdown-one .dItem:hover, .dropdown-two a:hover {
	background-color: #ddd; color: #000;
}
.my-pad {
	padding: 0 0 0 15px;
}
.my-pad h5 {
	color: rgb(255,255,255); font-size: 18px; text-transform: uppercase; padding-top: 20px;	line-height: 5px; font-weight: 600;
}
.multi-column-dropdown {
	list-style: none; margin: 0px; padding: 0px;
}
ul.multi-column-dropdown {
	padding: 0 0 0;
}
.multi-column-dropdown li a {
	display: block;	clear: both; line-height: 1.428571429; color: #333; white-space: normal;
}
.multi-column-dropdown li a:hover {
	text-decoration: none; color: #262626; background-color: #999;
}
.tab {
	overflow: hidden; border: 1px solid #ccc; background-color: #f1f1f1; font-family: 'font2';
}
.tab button {
	background-color: inherit; float: left; border: none; outline: none; cursor: pointer; padding: 14px 16px; transition: 0.3s; font-size: 17px;
}
.tab button:hover {
	background-color: #ddd;
}
.tab button.active {
	background-color: #ccc;
}
.tabcontent {
	display: none; padding: 6px 12px; border: 1px solid #ccc; border-top: none;
}
.tabcontent h3 {
	padding-top: 40px; padding-bottom: 40px; font-family: 'font'; text-align: center; font-size: 2rem; color: rgb(246,177,24);
}

.top-header-animate .dropdown-toggle {
	color:#0a0a0a; font-size: 16px;
}
.top-header-animate .navbar-brand {
	font-size: 1.5em;
}
body {
	padding: 0; -webkit-transition-property: all; -webkit-transition-duration: .30s; -webkit-transition-timing-function: ease-in-out; transition-property: all; transition-duration: .30s; transition-timing-function: ease-in-out; overflow-x: hidden;
}
.navbar-scroll {
	padding: 95px 0 0; position: fixed; background: rgb(83,82,82); width: 100%; z-index: 2;	-webkit-transition: all .30s ease; -moz-transition: all .30s ease; -o-transition: all .30s ease; transition: all .30s ease;
}
.navbar-scroll .container {
	background: rgb(60,36,17,0); border-bottom-left-radius: 1.5rem;	border-bottom-right-radius: 1.5rem;
}
#projects .navbar-scroll {
	background: #fdfdfd; position:relative !important;
}
#projects .navbar-scroll li a {
	color:#333;
}
#projects .navbar-scroll .navbar-brand {
	color:#252525;
}
#projects .navbar-light .lnr {
	color:#222;
}
.navbar-light .lnr {
	color: #fdfdfd;	font-size: 1.5em; position: absolute; top: 6px; right: 10px;
}
.navbar-light .navbar-brand {
	color: #e8e8e8; font-size: 20px; font-family: 'Montserrat', sans-serif;
}
.navbar-brand {
	font-size:2.5em; font-weight:700; text-transform:uppercase;
}
.navbar-brand:focus, .navbar-brand:hover {
	color:#f3f3f3 !important;
}
.navbar-light .navbar-nav .nav-link {
	margin: 0 28px; padding: 6px 0px; font-weight: 900; font-size: 18px; color: rgb(255,255,255); font-family: 'font2';
}
.navbar-light .navbar-nav .active>.nav-link, .navbar-light .navbar-nav
.nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light
.navbar-nav .show>.nav-link {
	color: rgb(255,255,255);
}
.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover {
	color: rgb(196,41,56);
}
.navbar-light .navbar-nav li a {
	position: relative;
}
.navbar-collapse {
	height: 100%;
}
.mobile-top-header {
	display: none !important;
}

/* ========================================== */
/* === Website Pages Section ================ */
/* ========================================== */

/**** Home Section ****/
.bg-primary {
	background: rgb(83,82,82) !important;
}
.home-header-section {
	padding-top: 149px;
}
.home-header-section .slider-logo span {
	font-family: 'font'; color: rgb(196,41,56);
}
.showcase {
    position: relative;
    height: 120vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.background-video {
    /*margin-bottom: 377px;*/
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%;
    height: 100%;
    overflow: hidden;
    object-fit: cover;

	
}
.video-overlay {
    position: absolute;
    padding: 50px 100px 200px 200px;
    background: url(/img/homepage/metal-5.png);
    background-size: cover;
    background-color: #0000001c;
	top:0%; height: 83.5%;
	width: 100%;
	
/*    margin-top: -1075px;
    width: 100%;
    height: 1068px;*/
}
.video-overlay h1 {
	font-family: font3; font-size: 35px; color: #fff; font-weight: 500;  line-height: 50px; text-shadow: 0px 0px 1px #000;
	text-transform: uppercase;
}
.video-overlay h1 strong {
	font-size: 45px; letter-spacing: 3px; color: #b2985b;
}
.video-overlay h1 span {
font-size: 25px;
    font-family: Atlassian Sans;
    color: #f9f9f9; letter-spacing: 2px;
    font-weight: 600; text-shadow: 1px 1px 1px #000;
}
.video-overlay h1 u {
	font-family: Atlassian Sans; text-decoration: none; text-transform: lowercase; font-size: 25px;
}
.video-overlay p {
	font-family: Atlassian Sans; font-size: 20px; line-height: 35px; color: #fff;  margin: 0px 200px 0px 200px;
}
.video-overlay a.estimate {
	padding: 25px; color: white; font-weight: 800;
	font-family: font3;
	background:  #ed1d26;
	border-radius: 10px;
	width:max-content; 
	box-shadow: 2px 2px 5px black ;
	margin-top: 100px; position: relative;
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);;
	transition: box-shadow 0.7s; margin-left: -65px;
}
.video-overlay a.estimate:hover {	
	box-shadow: inset 480px 0 0 0 rgba(255, 255, 255, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);;
	color: #ed1d26;
}

.video-overlay h3 {
	font-size: 20px; font-family: font3; line-height: 50px; margin-left: 65px; text-align: left; color: #fff;
}

.video-overlay h4 {
	padding: 35px; border-radius: 10px; color: #fff; font-size: 20px; letter-spacing: 2px;
	background: #b2985b; text-align: center; font-family: font5; font-weight: 500; text-transform: uppercase;
}
.video-overlay h4:hover {
	background: #245695;
}
.video-overlay hr {
	background: #ed1d26; height: 3px;
}
.video-overlay img {
	max-width: 35%;
}
.background-slider {
  position: absolute;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100vw;
  z-index: 0;
  overflow: hidden;
}

.background-slider .slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.background-slider .slide.active {
  opacity: 1;
}

.nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  padding: 10px 15px;
  cursor: pointer;
  z-index: 3;
}

.nav-btn.prev {
  left: 30px;
}

.nav-btn.next {
  right: 30px;
}

.home1 {
	padding: 0; position: relative; margin-top: -100px; margin-bottom: -110px;
	
	opacity: 0;
	transform: translateY(100px); 
	transition: 0.5s;
	
}
.home1 .row {
	--bs-gutter-x: 0;
	    /*--bs-gutter-x: 0; margin-left: -100px; margin-right: -100px; border: 3px solid #fff;    box-shadow: 1px 1px 10px 1px #000;*/
}
.home1 .pad {
	padding: 25px; background: #ed1d26;
	
	
	
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);
	transition: all 0.5s ;
	
	
	height: 270px;
	display: flex;
	flex-direction: column;
	justify-content: center; 

	
}
.home1 .pad2 {
	padding: 25px; background: #ed1d26; border-right: 1px solid #fff; border-left: 1px solid #fff;
	
	
	
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);
	transition: all 0.5s ;
	
	height: 270px;
	display: flex;
	flex-direction: column;
	justify-content: center; 
}
.home1 .sq {
    padding: 5px;
    background: #000;
    transform: rotate(45deg);
border-radius: 50px;
    margin-left: 0;
    margin-top: 5px; border: 2px solid #fff;
    margin-bottom: -0;
width: 135px;
    height: 135px;
		
		transition: 0.5s; 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.home1 h2 {
	font-family: 'font3'; font-size: 35px; text-align: left; font-weight: 500;
	
	
	transition: 0.8s; 
}
.home1 h3 {
	font-family: font2; font-weight: 600; letter-spacing: 1px; font-size: 25px;
}
.home1 p {
	font-size: 17px; font-family: Atlassian Sans; font-weight: 600; text-align: justify; color: rgb(150,150,150);
}
.home1 span {
	color: #fff; font-size: 20px; font-family: Atlassian Sans;
}
.home1 i {
    width: 50px;
    height: 50px;
    text-align: center;
    font-size: 50px;
    color: #fff;
    transform: rotate(-45deg);
		
		
		transition: 0.5s; 
}






.home1.show-more{
	
	margin-top: -350px;
	transform: translateY(0px); 
	opacity: 1; 
	
}



.home1 .pad:hover {

    background: #ed1d26;
		box-shadow: inset 500px 0 0 0 rgba(0, 0, 0, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);

}

.home1 .pad2:hover  {
    background: #ed1d26;
		box-shadow: inset 500px 0 0 0 rgba(0, 0, 0, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);
}


.home1 .pad:hover .sq {
    background: #ed1d26;
}

.home1 .pad2:hover .sq {
    background: #ed1d26;
}

.home1 .pad:hover h2, .home1 .pad2:hover h2{
	
	color: #ed1d26;

}


.home1 .pad:hover .sq, .home1 .pad:hover i{
	
    transform: rotate(0deg);
		
		color: black; 

}

.home1 .pad2:hover .sq, .home1 .pad2:hover i{
	
    transform: rotate(0deg);
		
		color: black; 

}



.home-affiliates {
    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: 104%;
    background-repeat: repeat;
    background-position: right;
}

.home-affiliates .container {
padding: 100px 50px 100px 50px; background: #fff;
}


.home-affiliates .affiliate-content {
    padding: 50px 25px 50px 25px;
    border: 4px solid #ff0000; background: #fff;
    box-shadow: 10px 10px 0px 0px #000;
    border-top-left-radius: 50px;
}

.home-affiliates h2 {
	font-family: font3; font-size: 25px; text-align: center;
}

.home-affiliates h2 span {
	color: #ed1d26; font-size: 40px; margin-left: -25px;
}
.home-affiliates img {
	max-width: 75%;
	
	transition: 0.5s; 
}


.home-affiliates img:hover {


	max-width: 90%; 

}
.home-services {
	padding: 0px 0px 00px 0px;    background: linear-gradient(to right, #f3f3f347, #f3f3f347), url(/img/homepage/trees3.png);
    background-size: 100%;
    background-repeat: repeat;
}
.home-services .container {
	padding: 200px 75px 125px 75px; background: #DCE4E8; 
}
.home-services h2 {
	font-family: font3; font-size: 35px;
}
.home-services h3 {
	font-family: Atlassian Sans; font-weight: 500;  font-size: 20px; letter-spacing: 1px; margin-top: 50px; line-height: 40px;
}
.home-services h3 span {
	color: #ed1d26; text-decoration: underline;
}
.home-services p {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 16px; line-height: 30px;
}






.home-service-cards {
	padding: 150px 0px 150px 0px; background: #f9f9f9; margin-top: 0px; 
}
.home-service-cards .card-bawks {
	padding: 25px; border: 2px solid #000;
}
.home-service-cards .card-bawks p {
	display: block;
}
.home-service-cards .service-card {
	padding: 50px 25px 25px 25px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 12%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;
    background-repeat: repeat; border-radius: 10px;
		
		
		
}
.home-service-cards .service-card:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg,rgba(0, 0, 0, 1) 12%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;

		
		
		background-color: #ff000b !important; position: relative; transition: .5s; 
}
.home-service-cards .service-card:hover h4 {
	display: block; transition: 3s;
}
.home-service-cards .service-card:hover p {
	display: block;
}
.home-service-cards .service-card:hover i {
	color: #fff;
}


.home-service-cards .service-card2 {
	padding: 50px 25px 25px 25px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 12%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;     background-repeat: repeat; border-radius: 10px;
}
.home-service-cards .service-card2:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg,rgba(0, 0, 0, 1) 12%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;
		
		background-color: #ff000b !important; position: relative; transition: .5s;
}

.home-service-cards .service-card2:hover h4 {
	display: block; transition: 3s;
}
.home-service-cards .service-card2:hover p {
	display: block;
}
.home-service-cards .service-card2:hover i {
	color: #fff;
}



.home-service-cards h3 {
	font-family: font3; font-size: 20px; margin-left: 10px;
}
.home-service-cards h3 span {
	font-weight: 600; font-size: 23px;
	
}
.home-service-cards h4 {
	font-family: font3; margin-left: -10px; display: none; margin-top: -25px; margin-bottom: -25px; color: #fff;
}
.home-service-cards h4:hover {
	color: #ed1d26;
}
.home-service-cards p  {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 16px; line-height: 30px; margin-left: 10px; 
}
.home-service-cards i {
	    font-size: 50px;
    color: #ed1d26;
    margin-left: 35px;
    margin-right: -75px;
    margin-top: -10px;
}



.home-roofing-types {
	position: relative;
	    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-repeat: repeat;
}
.home-roofing-types .container-fluid {
	padding: 0px;
}
.home-roofing-types .type-image {
	    background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/homepage/roofing-4.jpg);
    background-size: cover; height: 100%; border-right: 7px solid #ed1d26;    box-shadow: 3px 0px 5px 0px #000;
    background-repeat: repeat;
}
.home-roofing-types .type-content {
	padding: 150px 50px 150px 50px;
}
.home-roofing-types h2 {
font-family: font3; font-size: 35px;
}
.home-roofing-types h2 span {
	font-size: 25px;     font-family: 'Atlassian Sans'; color: #ed1d26; font-weight: 600;
}
.home-roofing-types h3 {
	font-family: font3; font-size: 20px; line-height: 50px; margin-left: 150px;
}
.home-roofing-types h3 strong {
	font-size: 30px; color:  #ed1d26; text-decoration: underline;
}
.home-roofing-types h3.adjective {
	font-family: font3;
	font-size: 20px;
	line-height: 50px;
	margin-left: 150px;
	transform: translateX(-20%);
	opacity: 0;
	transition: transform 1s ease, opacity 1s ease;
}


/*.home-roofing-types h3.adjective:nth-child(2) {*/
/*	transition-delay: 200ms; */
/*}*/
/*.home-roofing-types h3.adjective:nth-child(3) {*/
/*	transition-delay: 400ms; */
/**/
/*}*/
/*.home-roofing-types h3.adjective:nth-child(4) {*/
/*	transition-delay: 600ms; */
/**/
/*}*/
/*.home-roofing-types h3.adjective:nth-child(5) {*/
/*	transition-delay: 800ms; */
/**/
/*}*/



.home-roofing-types h3.adjective.show-more {
	transform: translateX(0%);
	opacity: 1; 
	
}




.home-roofing-types p {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 17px; line-height: 35px;
}



@keyframes emergencySweep {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}


.emergency-roofing {
	padding: 50px 0px 50px 0px;    background: linear-gradient(90deg, #fff 0%, #ed1d26 50%, #fff 100%);
  background-size: 200% 100%;
  animation: emergencySweep 3s infinite linear;
   /* border-radius: 350px;*/
}
.emergency-roofing .container {
		background: #fff; border: 10px double #ed1d26;
    padding: 50px 75px 50px 75px;
   /* border-radius: 350px;*/
}
.emergency-roofing h2 {
	font-family: font3; font-size: 25px; color: #ed1d26;; line-height: 35px;
	margin-right: 30px; margin-top: 0;
}
.emergency-roofing h2 span {
	font-size: 45px; color: #000; letter-spacing: -0; margin-right: 50px; line-height: 45px;
}
.emergency-roofing h2 strong {
	font-size: 25px; color: #ed1d26; font-family: Atlassian Sans;
}
.emergency-roofing p {
	font-family: Atlassian Sans; letter-spacing: 1px; line-height: 35px; font-size: 17px; color: #000; 
}
.emergency-roofing li {
	font-family: Atlassian Sans; font-weight: 600; color: #000; letter-spacing: 1px; font-size: 20px;
}
.emergency-roofing mark {
	background: #ed1d26; padding: 25px; border-radius: 5px; font-family: font3; font-size: 17px; color: #fff; margin-left: -65px; position: relative;
}
.emergency-roofing hr {
	height: 2px; background: #000;
}
.emergency-roofing ul {
  list-style: none; /* remove default bullet */
  padding-left: 0;
}

.emergency-roofing li {
  position: relative;
  padding-left: 20px;
}

.emergency-roofing li::before {
  content: '≋';
  position: absolute;
  left: 0;
  color: #ed1d26;
}




.faq-section {
	padding: 0px 0px 0px 0px;    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-repeat: repeat;
}
.faq-section .container-fluid {
	padding: 0px;
}
.faq-section .faq-image {
	background: linear-gradient(to right, #f3f3f300, #f3f3f300), url(/img/homepage/roofing-2.jpg);
    background-size: cover; height: 100%; border-left: 7px solid #ed1d26;    box-shadow: -3px 0px 5px 0px #000;
    background-repeat: repeat;
}
.faq-accordion {
  max-width: 800px;
  margin: 0 auto;
  padding: 120px 20px 120px 20px;
  font-family: Arial, sans-serif;
}

.faq-btn {
  display: inline-block;
  background: #ed1d26; /* Adjust to site color */
  color: #fff;
  padding: 8px 12px;
  margin: 5px;
  border-radius: 5px;
  text-decoration: none;
  font-weight: bold;
}
.faq-btn:hover {
  background: #000000; color: #fff;
}

.faq-heading {
  font-size: 2em;
  margin-bottom: 20px;
   font-family: font3;
}

.faq-heading strong {
	color: #ed1d26; font-size: 45px; text-shadow: 1px 1px 1px #000;
}

.accordion-item {
  border-bottom: 1px solid #ccc;
}

.accordion-question {
  width: 100%;
  background: #DCE4E8;
  border: none;
  padding: 15px; font-family: Atlassian Sans;
  font-size: 1.1em;
  font-weight: bold;
  cursor: pointer;
  text-align: left;
  transition: background 0.3s;
}

.accordion-question:hover {
  background: #ed1d26;
}

/*.accordion-answer {*/
/*  display: none;*/
/*  padding: 15px; font-family: Atlassian Sans;*/
/*  background: #fff;*/
/*}*/
.accordion-answer {
  max-height: 0;m: 25px;
  opacity: 0;
  overflow: hidden;
  transition: max-height 1s ease, opacity 1s ease;
}
.accordion-answer.show {
  opacity: 1;
}
.accordion-answer p,
.accordion-answer ul {
  margin: 25px;
}

.accordion-answer ul {
  padding-left: 20px;
}

.accordion-answer li {
  margin-bottom: 6px;
}

.roofing-materials {
	padding: 150px 0px 150px 0px;
	background: linear-gradient(to right, #f3f3f3d9, #f3f3f3d9), url(/img/homepage/roof-silhouette-1.jpg);
    background-size: cover; height: 100%; background-position: center center;
    background-repeat: repeat;
}

.roofing-materials .pre-bawks {
	text-align: center; padding: 50px 200px 50px 200px;
}

.roofing-materials .bawks {
	padding: 50px 15px;
	
	
	
	
	/*background: #fff9;*/
	background: linear-gradient(to right, #ffffff00, #ffffff), url(/img/homepage/shingle-1.jpg);
	background-size: cover;

	
	border: 3px solid #fff; border-radius: 5px;
}



.roofing-materials .bawks.shingle2{
	/*padding: 50px 15px;*/
	
	
	
	
	/*background: #fff9;*/
	background: linear-gradient(to right, #ffffff00, #ffffff), url(/img/homepage/shingle-2.jpg);
	background-size: cover;
	
	
	/*border: 3px solid #fff; border-radius: 5px;*/
}


/* Outer element handles translateX and opacity (long transition) */
.roofing-materials .boarder1,
.roofing-materials .boarder2 {
  opacity: 0;
  transform: translateX(-25%);
  transition-property: transform, opacity, box-shadow;
  transition-duration: 1.3s, 1.3s, 0.5s;
  transition-timing-function: ease;
  box-shadow: -15px -15px 0px 0px #ed1d26;
}

.roofing-materials .boarder2 {
  transform: translateX(25%);
  box-shadow: 15px -15px 0px 0px #ed1d26;
}
.roofing-materials .boarder1:hover  {
  box-shadow: -25px -25px 0px 0px #ed1d26;

}


.roofing-materials .boarder2:hover  {
  box-shadow: 25px -25px 0px 0px #ed1d26;

}
/* Hover effect now applies to the inner element */
.roofing-materials .boarder1:hover .boarder-inner,
.roofing-materials .boarder2:hover .boarder-inner {
  transform: scale(1.05);
  transition: transform 0.5s ease;
}

/* The inner element should be set up to transition scale only */
.roofing-materials .boarder-inner {
  transition: transform 0.5s ease;
}

/* Show the card with opacity and translateX */
.roofing-materials .boarder1.show-more {
  transform: translateX(0);
  opacity: 1;
}

.roofing-materials .boarder2.show-more {
  transform: translateX(0);
  opacity: 1;
}


.roofing-materials h3 {
	font-family: font3; font-size: 30px;
}
.roofing-materials h4 {
	font-family: font3; font-size: 25px;
}
.roofing-materials h4 span {
 color: #ed1d26; text-decoration: underline;
}
.roofing-materials h5 {
	font-family: Atlassian Sans;
}
.roofing-materials p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}

/* Section layout */
.home-process {
  padding: 150px 20px;
  background: linear-gradient(to right, #f3f3f3d9, #f3f3f3d9), url(/img/homepage/roofing-5.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
	background-attachment: fixed;
}

.home-process .container {
  max-width: 1200px;
  margin: 0 auto;
}

/* Flip card container */
.flip-card {
  background: transparent;
  perspective: 1000px;
  height: 300px; /* consistent height */
  margin-bottom: 30px;
	
	
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 1s;
  transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg);
}

/* Shared front and back styling */
.flip-card-front, .flip-card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  padding: 30px ;
  border-radius: 12px;
  backface-visibility: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  text-align: center;
}

/* Front styling */
.flip-card-front {
  background: linear-gradient(to right, #ffffffd9, #ffffff00), url(/img/homepage/texture-4.png);
  background-size: cover; background-color: #fff;
  background-repeat: repeat;
}

/* Back styling */
.flip-card-back {
  background: #ed1d26;
  color: white;
  transform: rotateY(180deg);
  padding: 40px 25px;
}
.flip-card-back i{
	font-size: 4rem; opacity: 0;
	
	transform: translateY(-20%); 
	transition: opacity 3.3s ease 0.2s, transform 3.3s ease 0.2s;; 
}
.flip-card:hover .flip-card-back i{
	transform: translateY(-0%); 

	opacity: 1; 
  /*transform: rotateY(180deg);*/
}


/* Typography */
.home-process h2 {
	font-family: font3; font-size: 35px; margin-bottom: 50px; margin-left: 75px;
}
.home-process h2 span {
	font-family: font3; font-size: 65px; color: #ed1d26;
}

.home-process h3 {
  font-family: monospace;
  font-size: 22px;
  margin-top: 10px;
}

.home-process h5 {
  font-family: font3;
  font-size: 18px;
  margin: 0;
}

.home-process h5 strong {
  color: #ed1d26;
  text-decoration: underline;
  font-size: 24px;
}

.step-back h4 {
  font-size: 18px;
  font-family: sans-serif;
  line-height: 1.6;
  margin: 0;
}
/*@media (max-width: 768px) {*/
/*  .flip-card {*/
/*    height: auto;*/
/*  }*/
/**/
/*  .flip-card-front, .flip-card-back {*/
/*    position: relative;*/
/*    height: auto;*/
/*  }*/
/**/
/*  .flip-card-inner {*/
/*    transform: none !important;*/
/*  }*/
/*}*/


/**** About Section ****/
.about-intro {
	 background: linear-gradient(to right, #000000b5, #000000b5), url(/img/homepage/roofing-5.jpg) no-repeat;
    background-size: cover; padding: 	150px;
    height: 100%; background-color: #fff; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;
    background-position: center center;
}
.about-intro .bawks {
	text-align: center; padding: 100px; border: 5px solid #fff9; color: #fff;
}
.about-intro h1 {
	font-family: monospace; font-size: 30px;
}







.about-intro h1 span {
	font-family: font3; font-size: 3.3rem;
	
}

.about-intro h1 span.main-title {
  display: inline-block; /* important for transform on inline elements */
  transform: translateY(20%);
  opacity: 0;
  transition: opacity 2s ease, transform 1s ease;
}
.about-intro h1 strong {
	 color: #ed1d26; font-weight: 500;
}
.about-intro h1 u {
	text-decoration: none; font-family: Atlassian Sans; font-size: 35px;
}
.about-intro p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}

.about-intro h1 span.main-title.show-more {
  transform: translateY(0%);
  opacity: 1;
}

.about-history {
		 background: linear-gradient(to right, #ed1d26bd, #ed1d26bd), url(/img/homepage/texture-4.png) no-repeat;
    background-size: cover; padding: 50px 0px 50px 0px;
    height: 100%; background-color: #ed1d26;
    background-position: center center; color: #fff;
}
.about-history .container-fluid {
	padding-left: 150px;
}
.about-history .boarder {
	border-right: 5px solid #fff;
}
.about-history h2 {
	font-family: font3; font-size: 65px; text-align: center; margin-left: -15px;
	
}
.about-history p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; margin-left: 100px; margin-right: -100px; margin-top: 75px;
}
.about-history mark {
	    padding: 35px;
    position: relative;
    left: 25%;
    top: 50%;
    font-family: font3;
    font-size: 25px;
    color: #ed1d26;
    border: 4px solid #000;
    background: #fff;
}
.about-benefits {
	padding: 100px; background: #f9f9f9; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;  border-bottom: 10px solid #ed1d26;
}
.about-benefits .sq {
	padding: 25px; border: 2px dashed #ed1d26; margin: 15px 0px 15px 0px; background: #fff;
	
	transform: translateY(25%);
	opacity:0;
	
	transition: 1s; 
}





.about-benefits .sq p {
	font-size: 15px; line-height: 30px; text-align: left;
}

.about-benefits .sq:hover {
	border-color: black;
	
	
}

.about-benefits .sq:hover h4{
	font-size: 2.05rem;
	
}
.about-benefits h3 {
	font-family: font3; font-size: 2rem; text-align: center;
}
.about-benefits h4 {
	font-family: font4;
	
	transition: 0.55s; 

}
.about-benefits p {
	font-family: Atlassian Sans; line-height: 35px; font-size: 17px; text-align: center;
}
.about-benefits i {
	font-size: 35px; color: #D31B21;
}
.about-benefits img {
	box-shadow: 15px -15px 0px 0px #ed1d26;
}


.about-benefits .sq.show-more {
	
	
	transform: translateY(0);
	
	opacity: 1; 
}


.about-choose {
	background: linear-gradient(to right, #161515bd, #161515bd), url(/img/homepage/texture-4.png) no-repeat;
    background-size: cover; padding: 150px 0px 150px 0px;
    height: 100%; background-color: #4449;
    background-position: center center; color: #fff
}

.about-choose .why-card {
	padding: 75px 15px; text-align: center; background: #0009;
}

.about-choose h2 {
	font-family: font3; font-size: 45px; 
	
}

.about-choose h3 {
	font-family: font4; font-size: 25px;  color: #ED1D26;
	
}

.about-choose h4 {
	font-family: font4; font-size: 35px;  line-height: 75px; margin-bottom: 25px;
	
}

.about-choose p {
	font-family: Atlassian Sans; line-height: 35px; font-size: 17px; 
}

.about-services {
	padding: 100px; background: #f9f9f9; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;  border-bottom: 10px solid #ed1d26;
}
.about-services .service-bawks {
	margin-left: 50px; margin-right: -50px;
}
.about-services .sq {
	padding: 25px; border: 2px dashed #ed1d26; margin: 15px 0px 15px 0px; background: #fff;
	
	transform: translateY(25%);
	opacity:0;
	
	transition: 1s; 
}





.about-services .sq p {
	font-size: 15px; line-height: 30px; text-align: left;
}

.about-services .sq:hover {
	border-color: black;
	
	
}

.about-services .sq:hover h4{
	font-size: 2.05rem; color: #ed1d26;
	
}
.about-services .sq:hover i {
	color: #000;
}
.about-services h2 {
	font-family: font3; font-size: 45px; letter-spacing: 1px;
}
.about-services h3 {
	font-family: font3; font-size: 45px; letter-spacing: 1px; margin:75px 0px 75px 0px; color: #ed1d26; text-align: center;
}
.about-services h4 {
	font-family: font4;
	
	transition: 0.55s; 

}
.about-services p {
	font-family: Atlassian Sans; line-height: 35px; font-size: 17px; 
}
.about-services i {
	font-size: 35px; color: #D31B21;
}
.about-services img {
	box-shadow: 15px -15px 0px 0px #ed1d26;
}


.about-services .sq.show-more {
	
	
	transform: translateY(0);
	
	opacity: 1; 
}

/**** Services Section ****/
.service-intro {
	padding: 150px 100px 150px 100px;     background-image: linear-gradient(#ed1d26, #ed1d267d), url(/img/homepage/tr-1.png); color: #fff;
}

.service-intro h1 {
	font-family: font3; font-size: 35px;
	
}
.service-intro h2 {
	font-family: font2; font-size: 25px; padding: 10px; text-align: center; color: #ed1d26;
}
.service-intro h2:hover {
	color: #fff; background: #ed1d26; border-radius: 10px; font-weight: 600;
}
.service-intro  p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}

.service-intro .intro-content {
}
.service-intro .intro-legend {
	background: #fff; padding: 25px; border-radius: 15px;
}

.service-hub {
	position: relative; padding: 100px 0px 100px 0px; background: #f5f5f5;
}

.service-hub .link-card {
	background: #fff; border: 2px solid #ed1d26; height: auto; position: relative;
	
	/*height: 650px;*/
	height:700px;
	
	
	
	margin: 25px 0px 25px 0px;
	
	
	
		/*transform: translateX(300px); */
	transition: transform 1.5s, opacity 1.5s, box-shadow 1s, background-color 0.5s;;
	border-radius: 0.8rem; 
	overflow: hidden;
	padding: 0;
	
	
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center; 
}

.service-hub .link-card h3 {
	font-family: font3; 
	color: #fff;
	font-size:1.2rem;
}

.service-hub .link-card img {
	height: 325px; width: 100%;
}
.service-hub .link-card:hover {
	 background: #ed1d26; color: #fff;
}

.service-hub .link-card:hover h2 {
	font-family: font3; 
	color: #fff;
}

.service-hub .link-card:hover p {
	color: #fff;
}

.service-hub .link-card:hover mark {
	display: block;
}



.service-hub .link-card .card-data{
	position: absolute;
	display: flex;
	flex-direction: column; 
	justify-content: center;
	align-items: center; 
	
	
	bottom: -6rem;
	width: 100%;
	height: 75px; ; 
    left: 0%;
    transform: translate(-50%, -50%);
	border: 2px solid white;
	border-radius: 0.8rem;
	background: black;;
	padding: 20px;
	box-shadow: 1px 1px 8px black;; 
	margin-inline: auto; 	
	/*opacity: 0;*/
	transform: translateY(100%);
		transition: 1s;
		
		
		color: white;
		font-family: 'font3'; 

}

.service-hub .link-card:hover .card-data{
	opacity: 1;
	transform: translateY(-0%);
	animation: show-data 1s forwards ;
	
}
.service-hub .link-card:hover {
	animation: remove-overflow 1s forwards ;
}


.service-hub .link-card:not(:hover) {
	animation: show-overflow 1s forwards ;
}

.service-hub .link-card:not(:hover) .card-data{
	animation: remove-data 1s forwards ;
}





/*CARD ANIMATIONS START -------------------------*/


@keyframes show-data{
	50%{	
		transform: translateY(-7rem); 
	}

	100%{
		transform: translateY(-4rem); 
	}
}

@keyframes remove-overflow{
	to{
		overflow: initial; 
	}
}


@keyframes remove-data{
	
	0%{
			transform: translateY(-2rem);
	}
	50%{
			transform: translateY(-7rem);
	}
	100%{
			transform: translateY(0.5rem);
	}
	
}

@keyframes show-overflow{
	
	0%{
		overflow: initial;
		pointer-events: none; 
	}
	
	100%{	
		overflow: hidden; 
	}
	
	
}

/*CARD ANIMATIONS END -------------------------*/






.service-hub h2 {
    font-family: font3;
    text-align: center;
    padding: 15px 0px 15px 0px;
    color: #ed1d26;
    font-size: 25px;
}

.service-hub  p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center; margin: 0px 35px 0px 35px; 
}

.service-hub a {
	color: inherit;
}

.service-hub mark {
    padding: 15px;
    text-align: center;
    font-family: font3;
    color: #fff;
    background: #000;
    display: none;
    font-weight: 500;
    position: absolute;
    width: 100%;
    font-size: 20px;
    bottom: 0;
}
.service-body ul{
    list-style-type:none;
	padding: 0;
}
.service-body ul li p{
    font-size: 1.35rem;

}

.service-body {
	position: relative;background-image: linear-gradient(#ffffffb0, #ffffffb0), url(/img/homepage/tr-1.png);
    background-size: cover;
}

.service-body .container-fluid {
	padding: 0px;
}

.service-body h3 {
	font-family: font3; font-size: 35px;
	color: #245695; margin-bottom: 15px;
}
.service-body p {
font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.service-body p i {
	color: #7c5b0f; font-family: font2;
}
.service-body .residential-roofing-content {
	padding: 125px 50px 125px 50px;
}
.service-body .residential-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/roofer-01.jpg);
    background-size: cover;
}
.service-body .commercial-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/cr-1.jpg);
    background-size: cover;
}
.service-body .emergency-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/claim-1.jpg);
    background-size: cover;
}
.service-body .gutter-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/roof-gutter-1.jpg);
    background-size: cover;
}
.service-body .inspection-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/ri-1.jpg);
    background-size: cover;
}
.service-body .claims-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/claim-form-1.jpg);
    background-size: cover;
}
.service-body .repair-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/rr-1.jpg);
    background-size: cover;
}
.service-body .replacement-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/rr-2.jpg);
    background-size: cover;
}
.service-cards {
	padding: 100px 10px;
	background-image: linear-gradient(#fcfcfcde, #fcfcfcde), url(/img/homepage/roof-shingle-1.jpg);
    background-size: cover; background-position: center center; background-attachment: fixed;
}

.service-cards .cardy {
	padding: 25px; background: #245695d4; border-radius: 15px; margin: 25px 35px 25px 35px; color: #fff;    height: 370px;
	display:flex;
	flex-direction: column;
	justify-content: center; 

	
}

.service-cards .cardy:hover {
	background: #b2985b; box-shadow: 1px 1px 10px 1px #000;   
}
.service-cards h2 {
	font-family: font3; font-size: 2.7rem; text-align: center;
}
.service-cards h3 {
	font-family: font3; font-size: 25px;
	text-align: center;
}

.service-cards p {
font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}



.service-choose {
	padding: 100px;background-image: linear-gradient(#b2985b17, #b2985b17), url(/img/homepage/tr-1.png);
    background-size: cover;
}
.service-choose ul{
    list-style-type:none; 
}
.service-choose h2 {
	font-family: font3; font-size: 35px; text-align: center;
}
.service-choose h2 span {
	color: #245695; font-weight: 600;
}
.service-choose p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}
.service-choose mark {
	padding: 15px; border-radius: 5px; font-family: font2; font-size: 20px; text-align: center; color: #fff; background: #245695;
}
.service-choose mark:hover {
	background: #fff; color: #245695; box-shadow: 0px 0px 0px 2px #245695; font-weight: 600;
}


/*INSTALLS START*/
.service-welcome {
	padding: 100px 0px 100px 0px;
}
.service-welcome h1 {
	font-family: font3; font-size: 30px; 
}
.service-welcome h1 strong {
	font-family: Atlassian Sans; color: #ed1d26; font-size: 20px;
}
.service-welcome h1 span {
	font-size: 20px;    font-family: 'Atlassian Sans';
    letter-spacing: 2px;
}
.service-welcome h1 u {
	color: #ed1d26;
}
.service-welcome h4 {
	font-family: font3;  font-size: 23px;
}
.service-welcome p  {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.service-welcome .cawd {
	
	position:relative; 
	padding: 25px; border: 1px dotted #ed1d26; margin: 10px 0px 10px 0px;
	
		overflow:hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
	opacity: 0; 
	transform: scale(0.1); 
	transition: opacity 1s, transform 1.4s; 
}


.service-welcome .cawd::before {
  content: "\f00c"; /* hammer icon */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 30px;
  position: absolute;
  top: -40%;
  left: 95%;
  transform: translate(-50%, -0%) rotate(0deg);
  z-index: 0; /* behind the text */
  pointer-events: none;
		background: black;
	color:white; 
	padding: 5px; 
	transition: 0.5s; 
}

.service-welcome .cawd:hover::before {

  top: 0%;
  transform: translate(-50%, -0%) rotate(0deg);

	
	
	
}


.service-welcome .cawd p {
	font-size: 15px; line-height: 25px;
}


.service-welcome .cawd .link {
	
    left: 50%;
    transform: translateX(-50%);
    top: 100%;
    width: 50%;
	position: absolute;
	/*top:100%;*/
    display: flex;
    flex-direction: column;
    justify-content: center;
	padding: 10px 0;
	
	transition: 0.5s;
	
	background: black;
	color: white;
	width: 100%;
			text-align: center; 
font-family: font3;

}
.service-welcome .cawd .link a{
	
font-family: font3;
    font-size: 1rem;
		color: white;
		width: 100%;
		text-align: center; 
}
.service-welcome .cawd:hover .link {
	
		top:82%;
/*height: 90px;*/
    padding: 10px 0;
	
}





.service-welcome .cawd.zoom-in {
	

	transform: scale(1);
	opacity: 1; 
	
	
}











.service-welcome img {
	box-shadow: 20px -20px 0px 0px #ed1d26; border: 1px solid #000;
}
.service-start-install {
	background: linear-gradient(to right, #000000b5, #000000b5), url(/img/homepage/roofing-5.jpg) no-repeat;
    background-size: cover; padding: 	150px;
    height: 100%; background-color: #fff; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;
    background-position: center center;
}
.service-start-install .start-content {
	    padding: 50px 15px 50px 15px; height: 100%;
    border: 2px solid #ed1d26; color: #fff;
}

.service-start-install .start-content {
	    padding: 50px 15px 50px 15px; height: 100%;
    border: 2px solid #ed1d26; color: #fff;
}

.service-start-install .start-content .phone{


	opacity: 0;
	
	
	transition: 0.7s; 
}

.service-start-install .start-content .phone a{
padding: 20px;
display: inline-flex;
background: #ed1d26;
color: white;
    font-family: font3;
		
		
		box-shadow: 1px -1px 0px 0px #ed1d26;;
		transition: 0.4s;

}
.service-start-install .start-content .phone a:hover{

	background: white;
	color: #ed1d26;
	transform: scale(1.05); 
		box-shadow: 5px 10px 2px 2px #ed1d26;;

	
}
.service-start-install:hover .start-content .phone{
	
	opacity: 1; 
}


.service-start-install .start-legend {
	
	position: relative; 
	    padding: 75px 15px 75px 15px; height: 100%;
    border: 2px solid #fff; color: #ed1d26;
		
		overflow: hidden; 
}



.service-start-install .start-legend .side-link{
	position: absolute;
	top: 75%;
	
	left: 100%;
	
	transition: 0.7s;
	
	
	width: 100%;
	
	background: #ed1d26;
	color: white;
	padding: 10px ;
}
.service-start-install .start-legend a {
	color: white;
	font-family: font3;
	width:100%; 
}

.service-start-install:hover .start-legend .side-link{

	
	left: 10%; 
}




.service-start-install h2 {
	font-family: font3; font-size: 30px;
	
}
.service-start-install h3 {
	font-family: font3; font-size: 20px;  line-height: 40px; color: #ed1d26;
}
.service-start-install p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; 
}
.roof-install-process {
  padding: 80px 20px;
  background-color: #f9f9f9;
}

.process-title {
  font-size: 32px;
  margin-bottom: 40px;
  color: #222; font-family: font3;
}

.process-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
}

.process-step {
     background: linear-gradient(90deg, #f0e5e6bf 12%, #f0e5e6bf 12%), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important;
    color: #000;
    background-repeat: repeat;
  padding: 20px; margin: 15px 0px 15px 0px;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.06);
  transition: transform 0.3s ease, background-size 0.85s;

}

.process-step:hover {
  transform: translateY(-5px);
    background-size: 130%;

}

.process-step:hover h3 {


	font-size: 1.5rem; 

}

.process-step i {
font-size: 45px;
    background: #ed1d26;
    margin-bottom: 15px;
    padding: 10px;
    color: #fff;
    border-top-right-radius: 15px;
		border-bottom-left-radius: 15px;
    position: relative;
    left: 84.5%;
    top: -20%;
}

.process-step h2 {
    font-size: 80px;
    text-align: left;
    margin-top: -20px;
    margin-left: -20px; margin-bottom: 25px;
    border-top-left-radius: 10px;
		 border-bottom-right-radius: 10px;
    padding: 0px 10px 0px 10px;
    background: #000;
    color: #fff;
    width: fit-content;
}

.process-step h3 {
  font-size: 20px; font-family: font3;
  margin-bottom: 10px; 
  color: #333;
	
	
	transition: 1s; 
}

.process-step p {
  font-size: 15px;
  color: #444;    font-family: Atlassian Sans;
  line-height: 1.6;
}
.roof-install-process img {
	border-radius: 10px; box-shadow: 1px 1px 10px 1px #000; margin-top: 75px;
}
.roof-types-materials {
	position: relative;    background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-color: #F9F9F9 !important;
    background-repeat: repeat;
		
		
}



.roof-types-materials:hover {
    /*background-size: 110%;*/

		
		
}



.roof-types-materials .container-fluid {
/*	padding: 0px;*/
}
.roof-types-materials .row {
	 /*   --bs-gutter-x: 0;*/ 
}
.roof-types-materials .roof-types {
	/*	background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/services/roofing-types-1.jpg) no-repeat;
    background-size: cover;
		background-position: center center;
		background-color: #fff; */
		padding: 300px 0px 00px 0px;
    height: 100%; 
    
}
.roof-types-materials .roof-types h2 {
	margin-left: 80px;
}
.displayer1 {
	padding: 25px; background: #000000cf; width: 100%; color: #fff; margin-left: 0px;
}
    .triangle-up {
      width: 0;
      height: 0;
      border-left: 250px solid transparent;
      border-right: 250px solid transparent;
      border-bottom: 300px double  #000000cf;
    }
.roof-types-materials .roof-materials {
/*		background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/services/roofing-materials-1.jpg) no-repeat;
    background-size: cover;
		background-color: #fff; 
    background-position: center center;*/
		padding: 300px 0px 0px 0px;
    height: 100%; 
}
.roof-types-materials h2 {
	   font-family: font3;
    font-size: 30px;
    color: #ed1d26;
    letter-spacing: 3px;
    margin-bottom: -175px;
    margin-left: 55px;
}
.roof-types-materials h3 {
    font-family: font3;
    font-size: 18px;
    margin-left: 25px;
    margin-right: -50px;
    line-height: 35px;
}
.roof-types-materials h3 span {
	color: #ed1d26;
}
.roof-types-materials p {
	font-size: 17px; line-height: 35px;     font-family: Atlassian Sans;
}
.roof-types-materials hr {
	    width: 135%; opacity: 25%;
   border-bottom: 5px dashed red;
    margin-top: -50px;
    margin-bottom: 50px;
}
.service-pick {
background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/services/re-roof-1.jpg);
    background-size: cover; height: 100%; background-position: bottom center; padding: 100px 0px 100px 0px;
}
.service-pick .container-fluid {
	padding: 0px;
}
.service-pick .services-content {
	padding: 100px 75px 100px 75px; background: #0009; color: #fff; border-radius: 10px;
}
.service-pick h2 {
	font-family: font3; font-size: 35px;
}
.service-pick h2 strong {
	font-family: Atlassian Sans; color: #ed1d26; font-size: 25px;
}
.service-pick p {
	font-size: 17px; line-height: 35px;     font-family: Atlassian Sans;
}
.service-reasons {
  list-style: none;
  padding: 0;
  margin-top: 30px;
}

.service-reasons li {
  position: relative;
  padding-left: 25px; margin-left: 50px;
  margin-bottom: 18px;  font-family: Atlassian Sans;
  font-size: 16px;
  line-height: 1.6;
  color: #fff;
}

.service-reasons li::before {
  content: '✔';
  position: absolute;
  left: 0;
  color: #ed1d26;
  font-weight: bold;
}

/*INSTALLS END*/

/**** Gallery Section ****/
.gallery-page {
	padding: 75px 0 50px 0;	background: rgb(249,249,249);
}
.gallery-page h1 {
	font-size: 3rem; font-weight: 600; font-family: 'font3'; padding-bottom: 40px; text-align: center; color: #ed1d26;
}

.gallery-page h2 {
	font-family: font3; font-size: 35px;
}

.gallery-page h3 {
	font-family: font4; font-size: 25px;
}
.gallery-page p {
	font-size: 17px; line-height: 35px;     font-family: Atlassian Sans;
}
.gallery-page li {
	font-size: 15px; line-height: 35px;     font-family: Atlassian Sans; 
}
.gallery-page li strong {
	color: #ed1d26;
}

.gallery-page a {
	color: #ed1d26;
}

/**** Areas We Service Section ****/

.locations {
	padding: 100px 0px 100px 0px; background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/services/service-location-1.jpg);
    background-size: cover; height: 100%; background-position: center center; text-align: center;
}

.locations h1 {
	font-family: font3; font-size: 40px; letter-spacing: 2px;
}
.locations h1 span {
	font-size: 20px; color: #ed1d26;
}
.locations h4 {
	font-family: font3; font-size: 23px; text-align: center;
	padding: 35px 15px 35px 15px; background: #fff; border: 1px dotted #ed1d26; color: #ed1d26;
}
.locations h4:hover {
	background: #000; color: #fff;
}
.locations p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; margin: 25px 350px 75px 350px;
}
.area1 {
	padding: 75px 0 75px 0; background: rgb(255,255,255);
	
}

.area1 a{
	background: #ed1d26 ;
	color: black;
	
	font-family: font3;
	font-weight: 700;
	padding: 15px;
	display:inline-block;;
	
	
	border-radius: 10px;
	box-shadow: 0px 2px 4px black;
	font-size:1.3rem;

}
.area2 {
	padding: 75px 0 75px 0; background: rgb(245,245,245);
	

}
.area1 h2, .area2 h2 {
	font-size: 30px; font-family: font3; font-weight: 500; color: #000; 
}
.area1 h2 span, .area2 h2 span {
	color: #ed1d26;
}
.area1 h4, .area2 h4 {
	font-size: 15px; font-family: Atlassian Sans; color: rgb(75,75,75); margin: 15px 0px 15px 0px;
}
.area1 h4 strong, .area2 h4 strong {
	font-size: 20px;color: #ed1d26;
}
.area1 p, .area2 p {
	font-size: 17px; text-align: justify; color: rgb(12,12,12); font-family: Atlassian Sans;
}


.area1 iframe{
	    box-shadow: 7px -7px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem; transition: box-shadow 0.5s; 
}
.area2 iframe{
	    box-shadow: -7px -7px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem; transition: box-shadow 0.5s; 
}

.area2 a{
	background: #ed1d26 ;
	color: black;
	
	font-family: font3;
	font-weight: 700;
	padding: 15px;
	display:inline-block;;
	
	border-radius: 10px;
	box-shadow: 0px 2px 4px black;
	font-size:1.3rem;
}
.area1:hover iframe{
	    box-shadow: 17px -17px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem;
}
.area2:hover iframe{
	    box-shadow: -17px -17px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem;
}

.location-map {
	margin-top: 25px;
}
.location-intro {
	padding: 100px 0px 100px 0px;     background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover; background-attachment: fixed;
    background-color: #fff;
    background-repeat: repeat;
}
.location-intro .spanner img {
    max-width: 70%;
    margin-left: 45px;
    margin-top: 15px;
}
.location-intro h1 {
	font-family: font3; font-size: 35px;
}
.location-intro h1 span {
	font-size: 20px;
}
.location-intro h1 strong {
	color: #ed1d26; font-family: Atlassian Sans; font-size: 25px;
}
.location-intro h2 {
	font-family: font3; font-size: 25px; color: #ed1d26;
}
.location-intro h4 {
  position: relative;
  font-family: font3;
  font-size: 20px;
  text-align: center;
  padding: 25px;
  background: #ed1d26;
  margin: 10px;
  width: 250px;
  color: #fff;
  z-index: 1;
  overflow: hidden; /* ensures pseudo-elements don't spill out */
}

.location-intro h4::before {
  content: "\f6e3"; /* hammer icon */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 100px;
  color: rgba(255, 255, 255, 0.1); /* subtle watermark effect */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-15deg);
  z-index: 0; /* behind the text */
  pointer-events: none;
}



.location-intro p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.location-intro img {
	max-width: 35%; margin-left: 350px; margin-bottom: 100px;
}
.location-intro .location-content {
	padding: 75px 50px 50px 50px;    border: 2px solid #000;
    height: 100%;
}
.location-intro .location-services {
	padding: 25px; 
}
/* Highlight active tab */
.tab-buttons h4 {
  cursor: pointer;
  transition: background 0.3s ease;
}

.tab-buttons h4.active {
  background: #000;
  color: #fff;
}

/* Tab content box */
.tab-content {
  font-family: Atlassian Sans;
  font-size: 16px;
  line-height: 28px;
  padding: 20px;
  border-left: 3px solid #ed1d26;
  background: #f9f9f9;
  margin-top: 10px;
  display: none;
}

.location-body {
	padding: 100px 0px 100px 0px;     background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/homepage/roofing-2.jpg);
    background-size: cover; background-position: bottom center; background-attachment: fixed;
    background-repeat: repeat;
}
.location-body .location-card {
/*	padding: 50px 25px 50px 25px; border-radius: 5px; background: #fff; margin: 15px 0px 15px 0px; border: 2px solid #000;*/
}
.location-body h2 {
	font-family: font3; font-size: 25px; color: #ed1d26;
}
.location-body p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.location-body i {
	    font-size: 50px;
    left: 80%;
    margin-top: -25px;
}


.location-body .view1 {
	padding: 5px;
	background-color: #0000009e;
	color: #000;
	position: relative;
	overflow: hidden;
margin: 15px 0px;
	border-radius: 10px;
    position: relative;
    overflow: hidden;
    z-index: 20;
	transition: 1s; 
}
.location-body .view1:hover {

	transform: scale(1.03); 

}
.location-body .view1::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
    /*height: 600px;*/
    /*width: 200px;*/
    height: 000px;
    width: 0%;
    background: #ed1d26;
    box-shadow: 0 0 10px #ed1d26, 0 0 40px #ed1d26, 0 0 80px #ed1d26;
	
	
	pointer-events: none; 
    /*animation: rotate_border 6s linear infinite;*/
	
	transition: 1s; 
}

.location-body .view1:hover::after {
	
    height: 2000px;
    width: 15%;	
	
	
	animation: rotate_border 8s linear infinite;
}

#in {
    height: 100%;
    width: 100%;
    background-color: #fff;
    border-radius: 10px;
    position: relative;
    z-index: 99;
	    padding: 50px 25px; 
}
.location-body .view1:hover #in {
	background: #fff;
}

@keyframes rotate_border{
	
	100%{
		transform: translate(-50%,-50%) rotate(360deg); 
	}
	
}


.location-choose {
	padding: 100px 0px 100px 0px;background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover;
    background-color: #0009;
    background-repeat: repeat;
}
.location-choose .cawd {
	position:relative; 
	padding: 25px; background: #fff; margin: 15px 0px 15px 0px;
	
	opacity: 0;
	transition: 1.5s;
	/*z-index: 3; */
}
.location-choose .cawd::before {
	
	position:absolute;
	top:0%;
	left: 0%;
	
	/*transform:translate(-50%,-50%); */
	
	/*z-index: 0; */

  content: "\f6e3"; 
  font-family: "Font Awesome 6 Free"; 
  font-weight: 900; 
  font-size: 24px;
  margin-right: 10px;
  color: #ed1d26;
	padding:5px;
	
	background: black; 
}








.location-choose .cawd.left {
		transform: translateX(-20%);

}
.location-choose .cawd.right {
		transform: translateX(20%);
}

.location-choose h3 {
	font-family: font3; font-size: 35px;  text-align: center; margin-bottom: 100px;
}
.location-choose h3 strong {
	font-size: 25px; font-family: Atlassian Sans; color: #ed1d26;
}
.location-choose h4 {
	font-family: font3; font-size: 23px;  text-align: center;
}
.location-choose p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}
.location-choose img {
	box-shadow: 1px 1px 10px 1px #000;
}



.location-choose .cawd.left.show-more {
	transform: translateX(0);
	opacity: 1; 
}


.location-choose .cawd.right.show-more {
	/*background: black;*/
	transform: translateX(0);
	opacity: 1; 
	
	
}



/* === Full-height wrapper === */
.chevron-bar-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  z-index: 999;
  pointer-events: none;
}

/* === Vertical red bar === */
.chevron-vertical-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 100%;
  background-color: #ed1d26;
  z-index: 1;
}

/* === Chevron button container (centered) === */
.chevron-button-wrapper {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  pointer-events: auto;
}

/* === Chevron button styling === */
.chevron-button {
  background-color: #ed1d26;
  color: white;
  padding: 20px 20px;
  font-size: 15px;
  font-weight: bold;
  font-family: Atlassian Sans;
  
  line-height: 1.4;
  width: 170px;
  clip-path: polygon(0 0, 85% 0, 100% 50%, 85% 100%, 0 100%);
  cursor: pointer;
  transition: background 0.3s ease;
  box-shadow: 2px 4px 12px rgba(0,0,0,0.2);
  z-index: 2;
  position: relative;
}

.chevron-button:hover {
  
}

/* === Hover panel === */
.chevron-panel {
  position: absolute;
  top: 0; margin-top: -50px;
  left: 100%;
  margin-left: -3px;
  background-color: #fff;
  color: #333;
  border-radius: 0 10px 10px 0;
  padding: 20px;
  box-shadow: 4px 6px 20px rgba(0, 0, 0, 0.15);
  min-width: 400px;
  display: flex;
  gap: 30px;
	font-family: Atlassian Sans;

  /* Hidden by default */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/* === Show panel on hover === */
.chevron-button-wrapper:hover .chevron-panel {
  opacity: 1;
  pointer-events: auto;
}

/* === Panel content layout === */
.chevron-column {
  flex: 1;
  min-width: 180px;
}

.chevron-column h4 {
  font-size: 16px;
  margin-bottom: 10px; font-family: font3; 
  color: #ed1d26;
  border-bottom: 1px solid #ddd;
  padding-bottom: 4px;
}

.chevron-column ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.chevron-column ul li {
  padding: 6px 0;
  font-size: 14px;
  border-bottom: 1px solid #eee;
}

.chevron-column ul li:last-child {
  border-bottom: none;
}

.chevron-panel mark {
	padding: 10px; background: #ed1d26; color: #fff; border-radius: 3px; margin-left: -15px;
}
.chevron-panel mark:hover {
	background: #000;
}
.chevron-panel a {
	color: inherit;
}
.chevron-panel a:hover {
	color: #ed1d26; text-decoration: underline !important; font-weight: 600;
}
/**** Contact Section ****/


/**** Testimonials Section ****/
.testimonials {
	padding: 75px 0 75px 0; background: rgb(255,255,255);
}


.homepage-reviews {
	background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover;
    background-repeat: repeat;
}
.homepage-reviews .review-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 30px; padding: 100px 0px 100px 0px;
  margin-top: 30px;
}

.homepage-reviews .review-card {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  padding: 20px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: none; /* JS controls visibility */
  border-top: 4px solid #ed1d26;
}

.homepage-reviews .review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

.homepage-reviews h2 {
	font-family: font3; font-size: 45px; letter-spacing: 1px; text-align: center; margin-top: 50px;
}

.homepage-reviews .review-card p {
  font-size: 0.95em;
  line-height: 1.6;
  color: #333;
  margin-bottom: 15px;
}

.homepage-reviews .review-meta {
  font-size: 0.85em;
  color: #555;
}

.homepage-reviews .review-meta .review-rating {
  color: #f7c200;
  display: block;
  margin-bottom: 5px;
}

.homepage-reviews .review-meta .review-author a {
  color: #ed1d26;
  text-decoration: none;
}

.homepage-reviews .review-meta .review-author a:hover {
  text-decoration: underline;
}

.homepage-reviews .review-meta .review-date {
  display: block;
  margin-top: 5px;
  color: #888;
}

.homepage-reviews #loadMoreReviews {
  display: block;
  margin: 40px auto 40px auto;
  padding: 12px 25px;
  background-color: #ed1d26;
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 1em;
  border-radius: 4px;
  transition: background-color 0.3s ease;
}

.homepage-reviews #loadMoreReviews:hover {
  background-color: #33345e;
}

/**** Sections On Every Page ****/
.contact-section {
	padding: 50px 0 50px 0;background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover;
    background-color: #fff; 
    background-repeat: repeat;
}
.contact-section h2 {
	font-family: font3;
}
.contact-section p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.contact-section h3 {
	font-size: 20px; font-family: Atlassian Sans; font-weight: 500; color: #000; line-height: 40px;
}

.contact-section h3 strong {
	color: #ed1d26;
}
.contact-form-section {
	padding: 100px 0px 100px 0px;    background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover;
    background-color: #4449;
    background-repeat: repeat;
}
.contact-form-section .form-box {
	background: #fff; border: 2px solid #000; padding: 50px;
}
/* ========================================== */
/* === Misc. Section ======================== */
/* ========================================== */

/****  Referrals Owl Carousel ****/
.owl-carousel .owl-stage-outer {
	padding: 40px 0;
}
.owl-nav {
	position: absolute; width: 100%; top: 10%; display: none;
}
.owl-carousel .item {
	display: block; height: 100%;
}
.owl-carousel .owl-item span {
	font-size: 20px; font-weight: 500;
}
.owl-nav .owl-prev,
.owl-nav .owl-next {
	position: absolute;
}
.owl-nav .owl-prev:hover,
.owl-nav .owl-next:hover {
	background: transparent !important; color: #212121 !important; opacity: .5 !important;
}
.owl-nav .owl-next {
	left: 100%;
}
.owl-nav .owl-prev {
	right: 100%;
}
.owl-nav .owl-prev span,
.owl-nav .owl-next span {
	font-size: 3em; display: block;
}
.owl-carousel .owl-nav button.owl-next, .owl-carousel .owl-nav button.owl-prev, .owl-carousel button.owl-dot {
	outline: none;
}

/**** Default Classes ****/
body {
	font-family: 'Montserrat', sans-serif;
}
body#barbajs {
	visibility: visible;
}
a, button, .btn {
	-webkit-transition: all .30s ease; -moz-transition: all .30s ease; -o-transition: all .30s ease; transition: all .30s ease;
}
a {
	cursor:pointer;	text-decoration: none !important;
}
a:hover {
	color: #252525; text-decoration: underline;
}
.btn {
	cursor: pointer; border-radius: 0;
}
.btn.alert-trigger {
	color: #fdfdfd; background-color:#333;
}
.btn:hover {
	opacity: 0.9;
}
.inner-content-section .btn {
	background:rgba(135,170,188);	border-color: #949494; color: rgba(255,255,255,1);
}
.inner-content-section .btn:hover {
	background-color: rgba(135,170,188,0.4); color: #fff;
}
.btn-primary:not([disabled]):not(.disabled).active,
.btn-primary:not([disabled]):not(.disabled):active,
.show>.btn-primary.dropdown-toggle {outline: none;box-shadow: none;background-color: #444;border-color: #949494;color: #fff;}
.btn-primary:hover {
	border-color: #949494;
}
.btn.focus, .btn:focus {
	outline:none; box-shadow: none;
}
.section-divider {
	position: relative; padding: 200px 0;
}
.estimate-section-divider .alert, .estimate-section-divider .alert p {
    text-align: left; font-size: inherit;
}
.block-overlay {
	position: absolute; display: inline-block; background:rgba(0, 0, 0, 0.6); width: 100%; height: 100%; top: 0; left: 0; right: 0; bottom: 0; z-index: 0;
}
.fadeDiv {
	position: fixed; display: inline-block; z-index: 1050; color: #fff; background: #300e87; padding: 50px; top: 150px; bottom: 150px; left: 300px; right: 300px; transform:scale(0,0); box-shadow: 0px 0px 20px -1px #000; transition: all .20s cubic-bezier(0.65, 0.05, 0.36, 1);
}
.menu-scaler {
	position: fixed; display: inline-block; padding: 50px; z-index: 1050; top: 150px; bottom: 150px; left: 300px; right: 300px; transform: scale(1,1);
}
.fadeDiv .fadeDiv-close {
	position: absolute; right: 20px; top: 10px; font-weight: 900; font-size: 2em; font-family: 'Lato'; cursor: pointer;
}
.navbar-collapse ul {
	width: 100%; justify-content: center; align-items: center;
}
.overlay {
	height: 100%; width: 100%; background: #ffffffbf;
}
#myBtn {
	display: block; width: 50px; height: 50px; position: fixed; top: 100%; right: 30px; z-index: 99; border: none; outline: none; background-color: #000000; color: #ffffff; cursor: pointer; font-size: 14px; padding-top: 0; border-radius: 0px; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; transition: all .3s ease;
}
#myBtn i {
	color: white;
}
#myBtn:hover {
	background-color: #424242; color: #fff;
}

/**** Gallery Function Section ****/
#portfolio input {
	display: flex; flex-direction: column; justify-content: center; align-items: center; position: absolute; margin: 0; top: 0; left: -60px; z-index: 2; width: 60px; height: 60px; -webkit-appearance: none; background-image: url(/img/icons/close-btn-icon-red.png); background-repeat: no-repeat; background-color: transparent; background-size: contain; color: #ffffff; border: none; cursor: pointer; outline: none !important; -webkit-transition: all .30s ease; -moz-transition: all .30s ease; -o-transition: all .30s ease; transition: all .30s ease;
}
#portfolio input:hover {
	background-color: #fff;	opacity: .;
}
button.mfp-close, button.mfp-arrow {
	outline :none !important;
}
#portfolio {
	display: flex; padding: 0; overflow: hidden; flex-wrap: wrap; justify-content: center;
}
#portfolio li {
	display: flex; justify-content: center; align-items: center; float: left; position: relative; overflow: hidden; margin: 0 10px 20px;
}
#portfolio li a {
	transform: scale(1,1); display: block; width: 100%; height: 295px; width: 490px; overflow: hidden; -o-transition:all .30s ease; -moz-transition:all .30s ease; -webkit-transition:all .30s ease; transition:all .30s ease;
}
#portfolio li a:hover {
	transform: scale(1.1,1.1) !important;
}
#portfolio li a img {
	display: block; position: absolute; top: 0%; bottom: 0%; left: 0%; right: 0%; margin: auto; width: 100%; height: auto; transform: scale(1,1);
}
#portfolio li:hover .block-overlay {
	background-color: #000000cc;
}
#portfolio li:hover input {
	left: 0;
}
#portfolio .block-overlay {
	background: rgb(0,0,0,0.1); z-index: 1; -webkit-transition: all .30s ease; -moz-transition: all .30s ease; -o-transition: all .30s ease; transition: all .30s ease;
}

.mfp-ready .mfp-figure {
	opacity: 0; margin-left: -100px;
}
.mfp-zoom-in .mfp-figure, .mfp-zoom-in .mfp-iframe-holder .mfp-iframe-scaler {
	opacity: 0; margin-left: -100px; -webkit-transition: all 0.3s ease-out; transition: all 0.3s ease-out; -webkit-transform: scale(0.95); -ms-transform: scale(0.95); transform: scale(0.95);
}
.mfp-zoom-in.mfp-bg,
.mfp-zoom-in .mfp-preloader {
	opacity: 0; -webkit-transition: all 0.3s ease-out; transition: all 0.3s ease-out;
}
.mfp-zoom-in.mfp-image-loaded .mfp-figure, .mfp-zoom-in.mfp-ready .mfp-iframe-holder .mfp-iframe-scaler {
	opacity: 1; margin-left: 0; -webkit-transform: scale(1); -ms-transform: scale(1); transform: scale(1);
}
.mfp-zoom-in.mfp-ready.mfp-bg,
.mfp-zoom-in.mfp-ready .mfp-preloader {
	opacity: 0.8;
}
.mfp-zoom-in.mfp-removing .mfp-figure, .mfp-zoom-in.mfp-removing .mfp-iframe-holder .mfp-iframe-scaler {
	-webkit-transform: scale(0.95);	-ms-transform: scale(0.95); transform: scale(0.95); opacity: 0; margin-left: -100px;
}
.mfp-zoom-in.mfp-removing.mfp-bg,
.mfp-zoom-in.mfp-removing .mfp-preloader {
	opacity: 0; margin-left: -20px;
}
.mfp-iframe-scaler {
	overflow: visible; /*so the close button is shown*/
}
.mfp-zoom-out-cur {
	cursor: auto;
}
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
	cursor: pointer;
}

/**** Reviews Function ****/
.carousel-indicators li {
	position: relative; top: 51px; -ms-flex: 0 1 auto; flex: 0 1 auto; width: 30px;	height: 3px; margin-right: 3px;	margin-left: 3px; text-indent: -999px; background-color: rgb(191, 190, 190);
}
.carousel-indicators .active {
	background-color: #0f8029;
}

/* ========================================== */
/* === Footer Section ======================= */
/* ========================================== */
.footer-section .vms-link-wrapper img {
	width: 50%;
}
.footer-section .vms-link-wrapper a {
	width: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center;
}
.footer-section {
	padding: 0 0 10px; background: linear-gradient(to right, #fffffff2, #fffffff2), url(/img/homepage/texture-1.png);
    background-size: cover;
    background-repeat: repeat; ; font-size: 18px; font-weight: 400;
}

.footer-section p {
 font-size: 15px; font-family: Atlassian Sans;
}
.footer-section p strong {
	color: #ed1d26;
}
.footer-section a {
	color: inherit; font-size: 16px;
}
.footer-section .service-cities p {
	margin: 0 0 3px;
	line-height: 20px;;
}
.footer-section .upper-footer {
	position: relative; background: #fff; 
}
.footer-section .upper-footer h5 {
	padding: 25px; background: #000; color: #fff; font-family: font3; text-align: center; margin-bottom: 0px;
}
.footer-section .upper-footer h5:hover {
	background: #ed1d26;
}
.footer-section .upper-footer .container-fluid {
	padding: 0px;
}
.footer-section .upper-footer .row {
	    --bs-gutter-x: 1px;
}
.service-cities {
	margin-bottom: 1em;
}
.service-cities img {
max-width: 50%; margin-bottom: 200px;
}
.service-cities h5 {
	line-height: 8px;
}
.service-cities h4 {
	font-size: 20px; font-family: 'font3'; 
}
.service-cities h3 {
	font-size: 25px; font-family: 'font3'; 
}
.bottom-footer {
	padding: 25px 0px 15px 0px; background: #000;
}
.bottom-footer .vms-link-wrapper {
	position: relative; top: -10px;
}
.bottom-footer div[class*='col-']:nth-child(2) {
	display: flex; flex-direction: column; justify-content: center; align-items: center;
}
.bottom-footer div[class*='col-']:nth-child(3) {
	display: flex; justify-content: flex-end; font-size: 14px;
}
.bottom-footer div[class*='col-']:nth-child(3) a {
	display: flex; justify-content: center;	align-items: center; border: 1px solid #fff; border-radius: 100px; height: 28px; width: 28px; margin: 0 4px;
}
.bottom-footer div[class*='col-']:nth-child(3) a:hover {
	background: #0a0a0a; text-decoration: none !important; color: #929292;
}
.trademark-disclaimer {
	padding: 10px 0 0 0 ; background: #ed1d26; margin-bottom: -15px;
}
.trademark-disclaimer p {
	font-size: 8px; text-align: center; color: rgb(255,255,255);
}

/* Button Styling */
.service-area-buttons {
  /*text-align: center;*/
  margin-bottom: 30px;
}
.service-area-buttons button {
  background-color: #ed1d26;
  color: white;
  padding: 12px 25px;
  margin: 10px;
  border: none; font-family: monospace;
  border-radius: 6px;
  font-size: 16px;
  cursor: pointer;
}

/* Modal Overlay */
.modal-overlay {
  display: none;
  position: fixed;
  z-index: 999;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background-color: rgba(0,0,0,0.6);
  justify-content: center;
  align-items: center;
}

/* Modal Box */
.modal-content {
  background: #fff;
  max-width: 750px;
  width: 90%;
  padding: 30px;
  border-radius: 10px;
  position: relative;
  text-align: center;
  max-height: 80vh;
  overflow-y: auto;
}

/* Close Button */
.close-modal {
  position: sticky;
  right: 20px;
  top: 15px;
	margin-left: 95%;
  font-size: 24px;
  font-weight: bold;
  color: #BC0909;
  cursor: pointer;
}

/* List Styling */
.modal-list {
  list-style: none;
  padding: 0;
  margin: 20px 0 0 0;
  text-align: left;
}
.modal-list li {
  padding: 8px 0;
  border-bottom: 1px solid #eee;
  font-size: 16px;
}




/* === Lg. Laptop CSS Section ================= */
@media screen and (max-width : 1440px) {
	/*** Don't place anything here, unless absolutely necessary ***/
	
.top-header .header-contact_info {
    padding: 5px;
    text-align: center;
    background: #ed1d26;
    width: auto;
    color: #fff;
    font-family: font3;
    letter-spacing: 2px;
    border-radius: 5px;
}
.video-overlay {
    position: absolute;
    padding: 50px 100px 200px 100px;
    background: url(/img/homepage/metal-5.png);
    background-size: cover;
    background-color: #0000001c;

	top:0%; height: 83.5%;
	width: 100%;
	
/*    margin-top: -1075px;
    width: 100%;
    height: 1068px;*/
}
.video-overlay h1 {
	font-family: font3; font-size: 35px; color: #fff; font-weight: 500;  line-height: 50px; text-shadow: 0px 0px 1px #000;
	text-transform: uppercase;
}
.video-overlay h1 strong {
	font-size: 45px; letter-spacing: 3px; color: #b2985b;
}
.video-overlay h1 span {
font-size: 25px;
    font-family: Atlassian Sans;
    color: #f9f9f9; letter-spacing: 2px;
    font-weight: 600; text-shadow: 1px 1px 1px #000;
}
.video-overlay h1 u {
	font-family: Atlassian Sans; text-decoration: none; text-transform: lowercase; font-size: 1.4rem;
}
.video-overlay p {
	font-family: Atlassian Sans; font-size: 20px; line-height: 35px; color: #fff;  margin: 0px 10px 0px 10px;
}
.video-overlay a.estimate {
	padding: 25px; color: white; font-weight: 800;
	font-family: font3;
	background:  #ed1d26;
	border-radius: 10px;
	width:max-content; 
	box-shadow: 2px 2px 5px black ;
	margin-top: 100px; position: relative;
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);;
	transition: box-shadow 0.7s; margin-left: -0;
}
.video-overlay a.estimate:hover {	
	box-shadow: inset 480px 0 0 0 rgba(255, 255, 255, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);;
	color: #ed1d26;
}

.video-overlay h3 {
	font-size: 20px; font-family: font3; line-height: 30px; margin-left: 15px; text-align: left; color: #fff;
}

.video-overlay h4 {
	padding: 35px; border-radius: 10px; color: #fff; font-size: 20px; letter-spacing: 2px;
	background: #b2985b; text-align: center; font-family: font5; font-weight: 500; text-transform: uppercase;
}
.video-overlay h4:hover {
	background: #245695;
}
.video-overlay hr {
	background: #ed1d26; height: 3px;
}
.video-overlay img {
	max-width: 35%;
}
.background-slider {
  position: absolute;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100vw;
  z-index: 0;
  overflow: hidden;
}

.background-slider .slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.background-slider .slide.active {
  opacity: 1;
}

.nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  padding: 10px 15px;
  cursor: pointer;
  z-index: 3;
}

.nav-btn.prev {
  left: 30px;
}

.nav-btn.next {
  right: 30px;
}


.home1.show-more {
    margin-top: -0px;
    transform: translateY(0px);
    opacity: 1;
}





.home-service-cards {
	padding: 150px 0px 150px 0px; background: #f9f9f9; margin-top: 0px; 
}
.home-service-cards .card-bawks {
	padding: 25px; border: 2px solid #000;
}
.home-service-cards .card-bawks p {
	display: block;
}
.home-service-cards .service-card {
	padding: 50px 25px 25px 25px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 12%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;
    background-repeat: repeat; border-radius: 10px;
		
		
		
}
.home-service-cards .service-card:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg,rgba(0, 0, 0, 1) 12%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;

		
		
		background-color: #ff000b !important; position: relative; transition: .5s; 
}
.home-service-cards .service-card:hover h4 {
	display: block; transition: 3s;
}
.home-service-cards .service-card:hover p {
	display: block;
}
.home-service-cards .service-card:hover i {
	color: #fff;
}


.home-service-cards .service-card2 {
	padding: 50px 25px 25px 25px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 12%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;     background-repeat: repeat; border-radius: 10px;
}
.home-service-cards .service-card2:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg,rgba(0, 0, 0, 1) 12%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;
		
		background-color: #ff000b !important; position: relative; transition: .5s;
}

.home-service-cards .service-card2:hover h4 {
	display: block; transition: 3s;
}
.home-service-cards .service-card2:hover p {
	display: block;
}
.home-service-cards .service-card2:hover i {
	color: #fff;
}



.home-service-cards h3 {
	font-family: font3; font-size: 20px; margin-left: 10px;
}
.home-service-cards h3 span {
	font-weight: 600; font-size: 23px;
	
}
.home-service-cards h4 {
	font-family: font3; margin-left: -10px; display: none; margin-top: -25px; margin-bottom: -25px; color: #fff;
}
.home-service-cards h4:hover {
	color: #ed1d26;
}
.home-service-cards p  {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 16px; line-height: 30px; margin-left: 10px; 
}
.home-service-cards i {
	    font-size: 2rem;
    color: #ed1d26;
    margin-left: 35px;
    margin-right: -35px;
    margin-top: -10px;
}

}
/* === Sm. Laptop CSS Section ================= */
@media screen and (max-width: 1024px) {
	
}
/* === Tablet CSS Section ===================== */
@media screen and (max-width: 991px) {
.top-header img {
    margin-left: 0;
    margin-right: -0;
    margin-top: -0;
    margin-bottom: 0;
}
.top-header .header-contact_info {
    padding: 15px;
    text-align: center;
    background: transparent;
    width: fit-content;
    color: #fff;
    font-family: font3;
    letter-spacing: -5px;
    border-radius: 5px;
}
/**** Top Header Section ****/
.mobile-top-header {
	display:block !important; padding: 0 30px 0; background: rgb(135,170,188); z-index: 10; overflow: visible;
}
.mobile-menu {
	text-align: center; position: fixed; height: 100%; width: 100%;	display: block;	padding-top: 6em; top: 100%; border: 0;	background: #232323; border-radius: 0; z-index: 1100; overflow: auto; -webkit-transition-property: all;	-webkit-transition-duration: .30s; -webkit-transition-timing-function: ease-in-out; transition-property: all; transition-duration: .30s; transition-timing-function: ease-in-out;
}
.mobile-menu .nav-link {
	font-size: 2em;	color: #c5c5c5 !important;
}
.mobile-menu-custom-show {
	top: 0%;
}
.mobile-menu-top-hero {
	background-size: cover;	padding: 40px 0 0; top:0; left:0; width: 100%; text-align: center;
}
.mobile-menu-top-hero h2 {
	padding: 0 25px;
}
#mobile-menu-header {
	margin-top: 0; background: #ffffff00; box-shadow: none;
}
#mobile-menu-header ul {
	list-style: none; padding: 0 20px; margin-top: 8em; position: relative; width: inherit;
}
#mobile-menu-header ul li a {
	color:#ffffff; padding: 20px 20px;
}
.header-contact_info a {
	color: rgb(255,255,255); margin: 0;
}
.top-header a, .top-header i, .top-header p {
	color: rgb(0,0,0);
}
.top-header-animate a, .top-header-animate i, .top-header-animate p {
	color: rgb(0,0,0);
}
.top-header {
	background: white; display: none;
}
.header-contact_info {
	font-size: 1.5em;
}
.navbar-scroll {
	display: none;
}
.header-contact_info .navbar-brand {
	font-size: 1.3em;
}
.top-header div[class*='col-']:first-child {
	justify-content: flex-start;
}
.top-header div[class*='col-'] {
	display: flex; justify-content: left; width: 33.333%; padding: 15px 0;
}
.top-header div[class*='col-']:nth-child(3) {
	display: flex; justify-content: flex-end; width: 33.333%; padding: 15px 0;
}
.top-header div[class*='col-']:nth-child(2) {
	background: none; margin: 0; display: flex; justify-content: center; align-items: center;
}
.top-header div[class*='col-']:nth-child(1) a {
	font-size: 1.5em;
}
.top-header div[class*='col-']:nth-child(2) p {
	font-size: inherit; line-height: inherit;
}


/**** Navigation Section ****/
.dropdown-wrapper {
	margin: 0; padding: 0;
}
.navbar-sidebar .dropdown-menu-mobile, .navbar-sidebar .dropdown-menu-mobile-2{
    position: relative;
    display: none;
    top: 0;
    left: 0;
    z-index: 1000;
    float: left;
    height: 0px;
    margin: 0;
    width: 100%;
    padding: 0;
    font-size: 18px;
    color: #e6e6e6 !important;
    text-align: left;
    list-style: none;
    background-color: rgb(200 200 200 / 37%);
    border: 0;
    visibility: hidden;
    border-radius: 0;
    transform: scale(1,0);
    -webkit-transition: all .30s ease;
    -moz-transition: all .30s ease;
    -o-transition: all .30s ease;
    transition: all .30s ease;
}
.dropdown-menu-animate, .dropdown-menu-animate-2 {
	display: inline-block !important; transform: scale(1,1) !important; padding: 25px 0 !important; height: auto !important; visibility: visible !important;
}
.navbar-sidebar .dropdown-menu-mobile a, .navbar-sidebar .dropdown-menu-mobile-2 a {
	color: black; font-weight:600 !important; font-size: 1rem; font-family: 'font3'; text-align: left;
	padding: 10px; 
}
.navbar-sidebar {
	padding-top: 110px; height: 100%; width: 200px; background-color: rgb(250,250,250); position: fixed !important; z-index: 5; overflow: auto;
}
.bar-block .dropdown-hover, .bar-block .dropdown-click {
	width: 100%;
}
.bar-block .dropdown-hover .dropdown-content, .bar-block .dropdown-click .dropdown-content {
	min-width: 100%;
}
.bar-block .dropdown-hover .button, .bar-block .dropdown-click .button {
	width: 100%; text-align: left; padding: 8px 16px;
}
.main, #main {
	transition: margin-left .4s;
}
.modal {
	display: none; padding-top: 100px; position: fixed; left: 0; top: 0; width: 100%; height: 100%;	overflow: auto; background-color: rgb(0,0,0); background-color: rgba(0,0,0,0.4);
}
.modal-content {
	margin: auto; background-color: #fff; position: relative; padding: 0; outline: 0; width: 1200px;
}
.bar {
	width: 100%; overflow: hidden;
}
.center .bar {
	display: inline-block; width: auto;
}
.bar .bar-item {
	padding: 8px 16px; float: left; width: auto; border: none; display: block; outline: 0;
}
.bar .dropdown-hover, .bar .dropdown-click {
	position: static; float: left;
}
.bar .button {
	white-space: normal;
}
.bar-block .bar-item {
	width: 100%; display: block; padding: 8px 16px; text-align: left; border: none; white-space: normal; float: none; outline: 0;
	
	
	font-family: font3;
	
	font-size:1.15rem;
	color: black; 
	font-weight: 700; 
}

.nav-link{
	font-family: font3;
	font-weight: 700; 
	font-size:1.15rem;

	color: black; 
	
}
.bar-block.center .bar-item {
	text-align: center;
}
.block {
	display: block; width: 100%;
}

/**** Home Section ****/
.home-header-section {
	padding-top: 125px;
}
.dropdown-menu {
	position: absolute; top: 100%; left: 0; z-index: 1000; display: none; float: left; min-width: 10rem; padding: .5rem 0; margin: .125rem 0 0; font-size: 1rem; color: rgb(33, 37, 41); text-align: left; list-style: none; background-color: rgb(87, 86, 87); background-clip: padding-box; border: 1px solid rgba(0,0,0,.15); border-radius: .25rem;
}
.dropdown-item {
	display: block;	width: 100%; padding: .25rem 1.5rem; clear: both; color: rgb(255,255,255); text-align: inherit;	white-space: nowrap; background: 0 0; border: 0;
}
.dropdown-item.active, .dropdown-item:active {
	color: rgb(255, 255, 255); text-decoration: none; background-color: rgb(22,22,22) !important;
}
.showcase {
    position: relative;
    /*height: 120vh;*/
		
		min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.background-video {
    /*margin-bottom: 377px;*/
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%;
    height: 100%;
    overflow: hidden;
    object-fit: cover;

	
}
.video-overlay {
    position: absolute;
    padding: 50px 10px 50px 10px;
    background: url(/img/homepage/metal-5.png);
    background-size: cover;
    background-color: #0000001c;

	top:0%; height: auto;
	width: 100%;
	
/*    margin-top: -1075px;
    width: 100%;
    height: 1068px;*/
}
.video-overlay h1 {
	font-family: font3; font-size: 2rem; color: #fff; font-weight: 500;  line-height: 30px; text-shadow: 0px 0px 1px #000;
	text-transform: uppercase;
}
.video-overlay h1 strong {
	font-size: 2rem; letter-spacing: 3px; color: #b2985b;
}
.video-overlay h1 span {
    font-size: 1.2rem;
    font-family: Atlassian Sans;
    color: #f9f9f9;
    letter-spacing: 2px;
    font-weight: 600;
    text-shadow: 1px 1px 1px #000;
}
.video-overlay h1 u {
	font-family: Atlassian Sans; text-decoration: none; text-transform: lowercase; font-size: 25px;
}
.video-overlay p {
	font-family: Atlassian Sans; font-size: 1rem; line-height: 27px; color: #fff;  margin: 0px 20px 0px 20px;
}
.video-overlay a.estimate {
    padding: 25px;
    color: white;
    font-weight: 800;
    font-family: font3;
    background: #ed1d26;
    border-radius: 10px;
    width: max-content;
    box-shadow: 2px 2px 5px black;
    margin-top: 0;
    position: relative;
    box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);
    transition: box-shadow 0.7s;
    margin-left: 0;
}
.video-overlay a.estimate:hover {	
	box-shadow: inset 480px 0 0 0 rgba(255, 255, 255, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);;
	color: #ed1d26;
}

.video-overlay h3 {
    font-size: 20px;
    font-family: font3;
    line-height: 20px;
    margin-left: 35px;
    text-align: left;
    color: #fff;
}

.video-overlay h4 {
	padding: 35px; border-radius: 10px; color: #fff; font-size: 20px; letter-spacing: 2px;
	background: #b2985b; text-align: center; font-family: font5; font-weight: 500; text-transform: uppercase;
}
.video-overlay h4:hover {
	background: #245695;
}
.video-overlay hr {
	background: #ed1d26; height: 3px;
}
.video-overlay img {
	max-width: 60%;
}
.background-slider {
  position: absolute;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100vw;
  z-index: 0;
  overflow: hidden;
}

.background-slider .slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.background-slider .slide.active {
  opacity: 1;
}

.nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  padding: 10px 15px;
  cursor: pointer;
  z-index: 3;
}

.nav-btn.prev {
  left: 0px;
}

.nav-btn.next {
  right: 0px;
}

.home1 {
	padding: 0; position: relative; margin-top: -100px; margin-bottom: -110px;
	
	opacity: 0;
	transform: translateY(100px); 
	transition: 0.5s;
	
}
.home1 .row {
	--bs-gutter-x: 0;
	    /*--bs-gutter-x: 0; margin-left: -100px; margin-right: -100px; border: 3px solid #fff;    box-shadow: 1px 1px 10px 1px #000;*/
}
.home1 .pad {
	padding: 25px; background: #ed1d26;
	
	
	
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);
	transition: all 0.5s ;
	
	
	height: 270px;
	display: flex;
	flex-direction: column;
	justify-content: center; 

	
}
.home1 .pad2 {
	padding: 25px; background: #ed1d26; border-right: 1px solid #fff; border-left: 1px solid #fff;
	
	
	
	box-shadow: inset 0 0 0 0 #ed1d26, 3px 2px 5px rgb(0 0 0 / 50%);
	transition: all 0.5s ;
	
	height: 270px;
	display: flex;
	flex-direction: column;
	justify-content: center; 
}
.home1 .sq {
    padding: 5px;
    background: #000;
    transform: rotate(45deg);
border-radius: 50px;
    margin-left: 0;
    margin-top: 5px; border: 2px solid #fff;
    margin-bottom: -0;
width: 135px;
    height: 135px;
		
		transition: 0.5s; 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.home1 h2 {
	font-family: 'font3'; font-size: 35px; text-align: center; font-weight: 500;
	
	
	transition: 0.8s; 
}
.home1 h3 {
	font-family: font2; font-weight: 600; letter-spacing: 1px; font-size: 25px;
}
.home1 p {
	font-size: 17px; font-family: Atlassian Sans; font-weight: 600; text-align: justify; color: rgb(150,150,150);
}
.home1 span {
	color: #fff; font-size: 20px; font-family: Atlassian Sans;
}
.home1 i {
    width: 50px;
    height: 50px;
    text-align: center;
    font-size: 50px;
    color: #fff;
    transform: rotate(-45deg);
		
		
		transition: 0.5s; 
}






.home1.show-more{
	
        margin-top: 150px;
	transform: translateY(0px); 
	opacity: 1; 
	
}



.home1 .pad:hover {

    background: #ed1d26;
		box-shadow: inset 500px 0 0 0 rgba(0, 0, 0, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);

}

.home1 .pad2:hover  {
    background: #ed1d26;
		box-shadow: inset 500px 0 0 0 rgba(0, 0, 0, 0.97), 3px 2px 5px rgb(0 0 0 / 50%);
}


.home1 .pad:hover .sq {
    background: #ed1d26;
}

.home1 .pad2:hover .sq {
    background: #ed1d26;
}

.home1 .pad:hover h2, .home1 .pad2:hover h2{
	
	color: #ed1d26;

}


.home1 .pad:hover .sq, .home1 .pad:hover i{
	
    transform: rotate(0deg);
		
		color: black; 

}

.home1 .pad2:hover .sq, .home1 .pad2:hover i{
	
    transform: rotate(0deg);
		
		color: black; 

}




.home-affiliates {
    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: 104%;
    background-repeat: repeat;
    background-position: right;
		text-align: center;
}

.home-affiliates .container {
padding: 50px 10px 50px 10px; background: #fff;
}


.home-affiliates .affiliate-content {
    padding: 20px 15px 20px 15px;
    border: 4px solid #ff0000; background: #fff;
    box-shadow: 10px 10px 0px 0px #000;
    border-top-left-radius: 50px;
		        border-radius: 50px;
}

.home-affiliates h2 {
	font-family: font3; font-size: 1.4rem;
}

.home-affiliates h2 span {
	color: #ed1d26; font-size: 2rem; margin-left: -5px;
}
.home-affiliates img {
	max-width: 100%;
}
.home-services {
	padding: 0px 0px 00px 0px;    background: linear-gradient(to right, #f3f3f347, #f3f3f347), url(/img/homepage/trees3.png);
    background-size: 100%;
    background-repeat: repeat;
		text-align: center;
}
.home-services .container {
	padding: 200px 15px 125px 15px; background: #DCE4E8; 
}
.home-services h2 {
	font-family: font3; font-size: 35px;
}
.home-services h3 {
	font-family: Atlassian Sans; font-weight: 500;  font-size: 20px; letter-spacing: 1px; margin-top: 50px; line-height: 40px;
}
.home-services h3 span {
	color: #ed1d26; text-decoration: underline;
}
.home-services p {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 16px; line-height: 30px;
}
.home-service-cards {
	padding: 150px 0px 150px 0px; background: #f9f9f9; margin-top: 0px; 
}
.home-service-cards .card-bawks {
	padding: 25px; border: 2px solid #000;
}
.home-service-cards .card-bawks p {
	display: block;
}
.home-service-cards .service-card {
	padding: 50px 15px 25px 15px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;
    background-repeat: repeat; border-radius: 10px;
		
		text-align: center;

		
}
.home-service-cards .service-card:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg, rgb(0 0 0) 0%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;

		
		
		background-color: #ff000b !important; position: relative; transition: .5s; 
}
.home-service-cards .service-card:hover h4 {
	display: none; transition: 3s;
}
.home-service-cards .service-card:hover p {
	display: block;
}
.home-service-cards .service-card:hover i {
	color: #fff;
}


.home-service-cards .service-card2 {
	padding: 50px 15px 25px 15px;         background: linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgb(240 229 230 / 75%) 12%), url(/img/homepage/4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important; color: #000;     background-repeat: repeat; border-radius: 10px;
		text-align: center;

}
.home-service-cards .service-card2:hover {
	box-shadow: 1px 1px 10px 1px #000;background: linear-gradient(90deg,rgba(0, 0, 0, 1) 0%, rgba(237, 29, 38, 0.75) 12%), url(/img/homepage/4.png);
    background-size: 130%;
		
		background-color: #ff000b !important; position: relative; transition: .5s;
		
		
}

.home-service-cards .service-card2:hover h4 {
	display: none; transition: 3s;
}
.home-service-cards .service-card2:hover p {
	display: block;
}
.home-service-cards .service-card2:hover i {
	color: #fff;
}



.home-service-cards h3 {
	font-family: font3; font-size: 20px; margin-left: 10px;
}
.home-service-cards h3 span {
	font-weight: 600; font-size: 23px;
	
}
.home-service-cards h4 {
	font-family: font3; margin-left: -10px; display: none; margin-top: -25px; margin-bottom: -25px; color: #fff;
}
.home-service-cards h4:hover {
	color: #ed1d26;
}
.home-service-cards p  {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 16px; line-height: 30px; margin-left: 10px; 
}
.home-service-cards i {
	    font-size: 50px;
    color: #ed1d26;
    margin-left: 0;
    margin-right: -0;
    margin-top: -10px;
}
.home-roofing-types {
	position: relative;
	    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-repeat: repeat;
}
.home-roofing-types .container-fluid {
	padding: 0px;
}
.home-roofing-types .type-image {
	    background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/homepage/roofing-4.jpg);
    background-size: cover; height: 100%; border-right: 7px solid #ed1d26;    box-shadow: 3px 0px 5px 0px #000;
    background-repeat: repeat;
}
.home-roofing-types .type-content {
	padding: 50px 10px 50px 10px;
	text-align: center;
}
.home-roofing-types h2 {
font-family: font3; font-size: 35px;
}
.home-roofing-types h2 span {
	font-size: 25px;     font-family: 'Atlassian Sans'; color: #ed1d26; font-weight: 600;
}
.home-roofing-types h3 {
	font-family: font3; font-size: 20px; line-height: 50px; margin-left: 150px;
}
.home-roofing-types h3 strong {
	font-size: 30px; color:  #ed1d26; text-decoration: underline;
}
.home-roofing-types h3.adjective {
	font-family: font3;
	font-size: 20px;
	line-height: 50px;
	margin-left:  0px;
	transform: translateX(-20%);
	opacity: 0;
	transition: transform 1s ease, opacity 1s ease;
}

.home-roofing-types h3.adjective.show-more {
	transform: translateX(0%);
	opacity: 1; 
	
}




.home-roofing-types p {
	font-family: Atlassian Sans; letter-spacing: 1px; font-size: 17px; line-height: 35px;
}



.faq-section {
	padding: 0px 0px 0px 0px;    background: linear-gradient(to right, #f3f3f3cf, #f3f3f3cf), url(/img/homepage/texture-4.png);
    background-size: cover;
    background-repeat: repeat;
}
.faq-section .container-fluid {
	padding: 0px;
}
.faq-section .faq-image {
	background: linear-gradient(to right, #f3f3f300, #f3f3f300), url(/img/homepage/roofing-2.jpg);
    background-size: 100%; height: 100%; border-left: 7px solid #ed1d26;    box-shadow: -3px 0px 5px 0px #000;
    background-repeat: repeat;
}
.faq-accordion {
  max-width: 800px;
  margin: 0 auto;
  padding: 120px 20px 120px 20px;
  font-family: Arial, sans-serif;
}

.faq-heading {
  font-size: 1.5rem;
  margin-bottom: 20px;
   font-family: font3;
}

.faq-heading strong {
	color: #ed1d26; font-size: 2rem; text-shadow: 1px 1px 1px #000;
}

.accordion-item {
  border-bottom: 1px solid #ccc;
}

.accordion-question {
  width: 100%;
  background: #DCE4E8;
  border: none;
  padding: 15px 5px; font-family: Atlassian Sans;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  text-align: left;
  transition: background 0.3s;
}

.accordion-question:hover {
  background: #ed1d26;
}

/*.accordion-answer {*/
/*  display: none;*/
/*  padding: 15px; font-family: Atlassian Sans;*/
/*  background: #fff;*/
/*}*/
.accordion-answer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 1s ease, opacity 1s ease;
}
.accordion-answer.show {
  opacity: 1;
	        padding: 5px;
}
.accordion-answer p,
.accordion-answer ul {
  margin: 10px 0;
}

.accordion-answer ul {
  padding-left: 20px;
}

.accordion-answer li {
  margin-bottom: 6px;
}

.roofing-materials {
	padding: 50px 0px 50px 0px;
	background: linear-gradient(to right, #f3f3f3d9, #f3f3f3d9), url(/img/homepage/roof-silhouette-1.jpg);
    background-size: cover; height: 100%; background-position: center center;
    background-repeat: repeat;
		
		
		
}

.roofing-materials .pre-bawks {
	text-align: center; padding: 50px 10px 50px 10px;
}

.roofing-materials .bawks {
	padding: 50px 30px;
	
	background: linear-gradient(to left, #ffffff00, #ffffff), url(/img/homepage/shingle-1.jpg);
	
	border: 3px solid #fff; border-radius: 5px;
}
.roofing-materials .bawks.shingle2{
	/*padding: 50px 15px;*/
	
	
	
	
	/*background: #fff9;*/
	background: linear-gradient(to left, #ffffff00, #ffffff), url(/img/homepage/shingle-2.jpg);
	background-size: cover;
	
	
	/*border: 3px solid #fff; border-radius: 5px;*/
}

/* Outer element handles translateX and opacity (long transition) */
.roofing-materials .boarder1,
.roofing-materials .boarder2 {
  opacity: 0;
  transform: translateX(-25%);
  transition-property: transform, opacity, box-shadow;
  transition-duration: 1.3s, 1.3s, 0.5s;
  transition-timing-function: ease;
  box-shadow: -15px -15px 0px 0px #ed1d26;
}

.roofing-materials .boarder2 {
  transform: translateX(25%);
  box-shadow: 15px -15px 0px 0px #ed1d26;
	
	
}
.roofing-materials .boarder1:hover  {
  box-shadow: -15px -15px 0px 0px #ed1d26;

}


.roofing-materials .boarder2:hover  {
  box-shadow: 15px -15px 0px 0px #ed1d26;

}
/* Hover effect now applies to the inner element */
.roofing-materials .boarder1:hover .boarder-inner,
.roofing-materials .boarder2:hover .boarder-inner {
  transform: scale(1.05);
  transition: transform 0.5s ease;
}

/* The inner element should be set up to transition scale only */
.roofing-materials .boarder-inner {
  transition: transform 0.5s ease;
}

/* Show the card with opacity and translateX */
.roofing-materials .boarder1.show-more {
  transform: translateX(0);
  opacity: 1;
}

.roofing-materials .boarder2.show-more {
  transform: translateX(0);
  opacity: 1;
}


.roofing-materials h3 {
	font-family: font3; font-size: 1.5rem;
}
.roofing-materials h4 {
	font-family: font3; font-size: 1.2rem;
}
.roofing-materials h4 span {
 color: #ed1d26; text-decoration: underline;
}
.roofing-materials h5 {
	font-family: Atlassian Sans;
}
.roofing-materials p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}

.emergency-roofing {
    padding: 50px 0px 50px 0px;
    background: linear-gradient(90deg, #fff 0%, #ed1d26 50%, #fff 100%);
    background-size: 200% 100%;
    animation: emergencySweep 3s infinite linear;
    /* border-radius: 350px; */
		
		text-align: center;
}


.emergency-roofing .container {
    background: #fff;
    border: 10px double #ed1d26;
    padding: 50px 15px 50px 15px;
    /* border-radius: 350px; */
}
.emergency-roofing h2 span {
    font-size: 2.5rem;;
    color: #000;
    letter-spacing: -0;
    margin-right: 0px;
    line-height: 45px;
}

.emergency-roofing h2 {
    font-family: font3;
    font-size: 25px;
    color: #ed1d26;
    line-height: 35px;
    margin-right:  0px;
    margin-top: 0;
}
.emergency-roofing mark {
    background: #ed1d26;
    padding: 25px;
    border-radius: 5px;
    font-family: font3;
    font-size: 17px;
    color: #fff;
    margin-left: -0px;
    position: relative;
}



/* Typography */
.home-process h2 {
	font-family: font3; font-size: 2rem; margin-bottom: 30px; margin-left: 0px;
}
.home-process h2 span {
	font-family: font3; font-size: 3rem; color: #ed1d26;
}

.home-process h3 {
  font-family: monospace;
  font-size: 1.1rem;
  margin-top: 10px;
}

.home-process h5 {
  font-family: font3;
  font-size: 1rem;
  margin: 0;
}

.home-process h5 strong {
  color: #ed1d26;
  text-decoration: underline;
  font-size: 1.35rem;
}

.step-back h4 {
  font-size: 1rem;
  font-family: sans-serif;
  line-height: 1.6;
  margin: 0;
}


.home-process {
    padding: 50px 10px;
    background: linear-gradient(to right, #f3f3f3d9, #f3f3f3d9), url(/img/homepage/roofing-5.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
		text-align: center;
}






/* Flip card container */
.flip-card {
  background: transparent;
  perspective: 1000px;
  height: 300px; /* consistent height */
  margin-bottom: 30px;
	
	
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 1s;
  transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg);
}

/* Shared front and back styling */
.flip-card-front, .flip-card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  padding: 30px 5px;
  border-radius: 12px;
  backface-visibility: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  text-align: center;
}

/* Front styling */
.flip-card-front {
  background: linear-gradient(to right, #ffffffd9, #ffffff00), url(/img/homepage/texture-4.png);
  background-size: cover; background-color: #fff;
  background-repeat: repeat;
}

/* Back styling */
.flip-card-back {
  background: #ed1d26;
  color: white;
  transform: rotateY(180deg);
  padding: 40px 25px;
}
.flip-card-back i{
	font-size: 4rem; opacity: 0;
	
	transform: translateY(-20%); 
	transition: opacity 3.3s ease 0.2s, transform 3.3s ease 0.2s;; 
}
.flip-card:hover .flip-card-back i{
	transform: translateY(-0%); 

	opacity: 1; 
  /*transform: rotateY(180deg);*/
}












.contact-section {
    padding: 50px 0 50px 0;
		text-align: center; 
}


.contact-section h3 {
    font-size: 1rem;
    font-family: font2;
    font-weight: 800;
    text-align: center;
    color: rgb(12,12,12);
}



.section-divider {
    position: relative;
    padding: 50px 0 50px;
}

.service-cities {
    margin-bottom: 0.5rem;
}
.service-cities img {
    max-width: 50%;
    margin-bottom: 00px;
}
.service-cities a {
    font-size: 18px;
    line-height: 10px;
    color: black; 
}


/**** About Section ****/
.about-intro {
	 background: linear-gradient(to right, #000000b5, #000000b5), url(/img/homepage/roofing-5.jpg) no-repeat;
    background-size: cover; padding: 	50px 10px;
    height: 100%; background-color: #fff; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;
    background-position: center center;
}
.about-intro .bawks {
	text-align: center; padding: 40px 10px; border: 5px solid #fff9; color: #fff;
}
.about-intro h1 {
	font-family: monospace; font-size: 30px;
}







.about-intro h1 span {
	font-family: font3; font-size: 2rem;
	
}

.about-intro h1 span.main-title {
  display: inline-block; /* important for transform on inline elements */
  transform: translateY(20%);
  opacity: 0;
  transition: opacity 2s ease, transform 1s ease;
}
.about-intro h1 strong {
	 color: #ed1d26; font-weight: 500;
}
.about-intro h1 u {
	text-decoration: none; font-family: Atlassian Sans; font-size: 2rem;
}
.about-intro p {
	font-family: Atlassian Sans; font-size: 1rem; line-height: 35px;
}

.about-intro h1 span.main-title.show-more {
  transform: translateY(0%);
  opacity: 1;
}

.about-history {
		 background: linear-gradient(to right, #ed1d26bd, #ed1d26bd), url(/img/homepage/texture-4.png) no-repeat;
    background-size: cover; padding: 50px 0px 50px 0px;
    height: 100%; background-color: #ed1d26;
    background-position: center center; color: #fff;
		text-align: center;
}
.about-history .container-fluid {
	padding-left: 0px;
}
.about-history .boarder {
	border-right: 5px solid #fff;
}
.about-history h2 {
	font-family: font3; font-size: 3rem; text-align: center; margin-left: -0px;
	
}
.about-history p {
	font-family: Atlassian Sans; font-size: 1rem; line-height: 35px; margin-left: 0; margin-right: -0; margin-top: 15px;
}
.about-history mark {
	    padding: 35px 5px;
    position: relative;
    left: 0%;
    top: 50%;
    font-family: font3;
    font-size: 25px;
    color: #ed1d26;
    border: 4px solid #000;
    background: #fff;
}
.about-benefits {
	padding: 100px 10px; background: #f9f9f9; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;  border-bottom: 10px solid #ed1d26;
}
.about-benefits .sq {
	padding: 25px 5px; border: 2px dashed #ed1d26; margin: 15px 0px 15px 0px; background: #fff;
	
	transform: translateY(25%);
	opacity:0;
	
	transition: 1s;
	text-align: center;
}





.about-benefits .sq p {
	font-size: 15px; line-height: 30px; text-align: center;
}

.about-benefits .sq:hover {
	border-color: black;
	
	
}

.about-benefits .sq:hover h4{
	font-size: 2.05rem;
	
}
.about-benefits h3 {
	font-family: font3; font-size: 2rem; text-align: center;
}
.about-benefits h4 {
	font-family: font4;
	
	transition: 0.55s; 

}
.about-benefits p {
	font-family: Atlassian Sans; line-height: 35px; font-size: 17px; text-align: center;
}
.about-benefits i {
	font-size: 35px; color: #D31B21;
}
.about-benefits img {
	box-shadow: 15px -15px 0px 0px #ed1d26;
}


.about-benefits .sq.show-more {
	
	
	transform: translateY(0);
	
	opacity: 1; 
}

/**** Services Section ****/
.service-intro {
	padding: 50px 10px 50px 10px;     background-image: linear-gradient(#ed1d26, #ed1d267d), url(/img/homepage/tr-1.png); color: #fff;
}

.service-intro h1 {
	font-family: font3; font-size: 2rem;
	
}
.service-intro h2 {
	font-family: font2; font-size: 1.5rem; padding: 10px; text-align: center; color: #ed1d26;
}
.service-intro h2:hover {
	color: #fff; background: #ed1d26; border-radius: 10px; font-weight: 600;
}
.service-intro  p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}

.service-intro .intro-content {
}
.service-intro .intro-legend {
	background: #fff; padding: 25px 5px; border-radius: 15px;
}

.service-hub {
	position: relative; padding: 50px 0px 50px 0px; background: #f5f5f5;
}

.service-hub .link-card {
	background: #fff; border: 2px solid #ed1d26; height: auto; position: relative; height: auto; margin: 25px 0px 25px 0px;
	
	
	
		/*transform: translateX(300px); */
	transition: transform 1.5s, opacity 1.5s, box-shadow 1s, background-color 0.5s;;
	border-radius: 0.8rem; 
	overflow: hidden;
	padding: 0;
	height: 100%;
}

.service-hub .link-card h3 {
	font-family: font3; 
	color: #fff;
	font-size:1.2rem;
}

.service-hub .link-card img {
	height: auto; width: 100%;
}
.service-hub .link-card:hover {
	 background: #ed1d26; color: #fff;
}

.service-hub .link-card:hover h2 {
	font-family: font3; 
	color: #fff;
}

.service-hub .link-card:hover p {
	color: #fff;
}

.service-hub .link-card:hover mark {
	display: block;
}



.service-hub .link-card .card-data{
	position: absolute;
	display: flex;
	flex-direction: column; 
	justify-content: center;
	align-items: center; 
	
	
	bottom: -6rem;
	width: 100%;
	height: 75px; ; 
    left: 0%;
    transform: translate(-50%, -50%);
	border: 2px solid white;
	border-radius: 0.8rem;
	background: black;;
	padding: 20px;
	box-shadow: 1px 1px 8px black;; 
	margin-inline: auto; 	
	/*opacity: 0;*/
	transform: translateY(100%);
		transition: 1s;
		
		
		color: white;
		font-family: 'font3'; 

}

.service-hub .link-card:hover .card-data{
	opacity: 1;
	transform: translateY(-0%);
	animation: show-data 1s forwards ;
	
}
.service-hub .link-card:hover {
	animation: remove-overflow 1s forwards ;
}


.service-hub .link-card:not(:hover) {
	animation: show-overflow 1s forwards ;
}

.service-hub .link-card:not(:hover) .card-data{
	animation: remove-data 1s forwards ;
}





/*CARD ANIMATIONS START -------------------------*/


@keyframes show-data{
	50%{	
		transform: translateY(-7rem); 
	}

	100%{
		transform: translateY(-4rem); 
	}
}

@keyframes remove-overflow{
	to{
		overflow: initial; 
	}
}


@keyframes remove-data{
	
	0%{
			transform: translateY(-2rem);
	}
	50%{
			transform: translateY(-7rem);
	}
	100%{
			transform: translateY(0.5rem);
	}
	
}

@keyframes show-overflow{
	
	0%{
		overflow: initial;
		pointer-events: none; 
	}
	
	100%{	
		overflow: hidden; 
	}
	
	
}

/*CARD ANIMATIONS END -------------------------*/






.service-hub h2 {
    font-family: font3;
    text-align: center;
    padding: 15px 0px 15px 0px;
    color: #ed1d26;
    font-size: 25px;
}

.service-hub  p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center; margin: 0px 10px 0px 10px; 
}

.service-hub a {
	color: inherit;
}

.service-hub mark {
    padding: 15px;
    text-align: center;
    font-family: font3;
    color: #fff;
    background: #000;
    display: none;
    font-weight: 500;
    position: absolute;
    width: 100%;
    font-size: 20px;
    bottom: 0;
}
.service-body ul{
    list-style-type:none;
	padding: 0;
}
.service-body ul li p{
    font-size: 1.35rem;

}

.service-body {
	position: relative;background-image: linear-gradient(#ffffffb0, #ffffffb0), url(/img/homepage/tr-1.png);
    background-size: cover;
}

.service-body .container-fluid {
	padding: 0px;
}

.service-body h3 {
	font-family: font3; font-size: 35px;
	color: #245695; margin-bottom: 15px;
}
.service-body p {
font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.service-body p i {
	color: #7c5b0f; font-family: font2;
}
.service-body .residential-roofing-content {
	padding: 125px 50px 125px 50px;
}
.service-body .residential-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/roofer-01.jpg);
    background-size: cover;
}
.service-body .commercial-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/cr-1.jpg);
    background-size: cover;
}
.service-body .emergency-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/claim-1.jpg);
    background-size: cover;
}
.service-body .gutter-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/roof-gutter-1.jpg);
    background-size: cover;
}
.service-body .inspection-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/ri-1.jpg);
    background-size: cover;
}
.service-body .claims-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/homepage/claim-form-1.jpg);
    background-size: cover;
}
.service-body .repair-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/rr-1.jpg);
    background-size: cover;
}
.service-body .replacement-roofing-image {
	height: 100%;
	background-image: linear-gradient(#b2985b00, #b2985b00), url(/img/services/rr-2.jpg);
    background-size: cover;
}
.service-cards {
	padding: 100px 10px;
	background-image: linear-gradient(#fcfcfcde, #fcfcfcde), url(/img/homepage/roof-shingle-1.jpg);
    background-size: cover; background-position: center center; background-attachment: fixed;
}

.service-cards .cardy {
	padding: 25px; background: #245695d4; border-radius: 15px; margin: 25px 35px 25px 35px; color: #fff;    height: 370px;
	display:flex;
	flex-direction: column;
	justify-content: center; 

	
}

.service-cards .cardy:hover {
	background: #b2985b; box-shadow: 1px 1px 10px 1px #000;   
}
.service-cards h2 {
	font-family: font3; font-size: 2.7rem; text-align: center;
}
.service-cards h3 {
	font-family: font3; font-size: 25px;
	text-align: center;
}

.service-cards p {
font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}



.service-choose {
	padding: 100px;background-image: linear-gradient(#b2985b17, #b2985b17), url(/img/homepage/tr-1.png);
    background-size: cover;
}
.service-choose ul{
    list-style-type:none; 
}
.service-choose h2 {
	font-family: font3; font-size: 35px; text-align: center;
}
.service-choose h2 span {
	color: #245695; font-weight: 600;
}
.service-choose p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}
.service-choose mark {
	padding: 15px; border-radius: 5px; font-family: font2; font-size: 20px; text-align: center; color: #fff; background: #245695;
}
.service-choose mark:hover {
	background: #fff; color: #245695; box-shadow: 0px 0px 0px 2px #245695; font-weight: 600;
}


/*INSTALLS START*/
.service-welcome {
	padding: 40px 0px 40px 0px; text-align: center;
}
.service-welcome h1 {
	font-family: font3; font-size: 30px; 
}
.service-welcome h1 strong {
	font-family: Atlassian Sans; color: #ed1d26; font-size: 20px;
}
.service-welcome h1 span {
	font-size: 20px;    font-family: 'Atlassian Sans';
    letter-spacing: 2px;
}
.service-welcome h1 u {
	color: #ed1d26;
}
.service-welcome h4 {
	font-family: font3;  font-size: 23px;
}
.service-welcome p  {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.service-welcome .cawd {
	
	position:relative; 
	padding: 25px; border: 1px dotted #ed1d26; margin: 10px 0px 10px 0px;
	
		overflow:hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
	opacity: 0; 
	transform: scale(0.1); 
	transition: opacity 1s, transform 1.4s; 
}


.service-welcome .cawd::before {
  content: "\f00c"; /* hammer icon */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 30px;
  position: absolute;
  top: -40%;
  left: 95%;
  transform: translate(-50%, -0%) rotate(0deg);
  z-index: 0; /* behind the text */
  pointer-events: none;
		background: black;
	color:white; 
	padding: 5px; 
	transition: 0.5s; 
}

.service-welcome .cawd:hover::before {

  top: 0%;
  transform: translate(-50%, -0%) rotate(0deg);

	
	
	
}


.service-welcome .cawd p {
	font-size: 15px; line-height: 25px;
}


.service-welcome .cawd .link {
	
    left: 50%;
    transform: translateX(-50%);
    top: 100%;
    width: 50%;
	position: absolute;
	/*top:100%;*/
    display: flex;
    flex-direction: column;
    justify-content: center;
	padding: 10px 0;
	
	transition: 0.5s;
	
	background: black;
	color: white;
	width: 100%;
			text-align: center; 
font-family: font3;

}
.service-welcome .cawd .link a{
	
font-family: font3;
    font-size: 1rem;
		color: white;
		width: 100%;
		text-align: center; 
}
.service-welcome .cawd:hover .link {
	
		top:86%;
/*height: 90px;*/
    padding: 10px 0;
	
}





.service-welcome .cawd.zoom-in {
	

	transform: scale(1);
	opacity: 1; 
	
	
}











.service-welcome img {
	box-shadow: 10px -10px 0px 0px #ed1d26; border: 1px solid #000;
}
.service-start-install {
	background: linear-gradient(to right, #000000b5, #000000b5), url(/img/homepage/roofing-5.jpg) no-repeat;
    background-size: cover; padding: 	50px 10px;
    height: 100%; background-color: #fff; border-left: 10px solid #ed1d26;  border-right: 10px solid #ed1d26;
    background-position: center center;
}
.service-start-install .start-content {
	    padding: 50px 15px 50px 15px; height: 100%;
    border: 2px solid #ed1d26; color: #fff;
}

.service-start-install .start-content {
	    padding: 50px 15px 50px 15px; height: 100%;
    border: 2px solid #ed1d26; color: #fff;
		
		text-align:center;
}

.service-start-install .start-content .phone{


	opacity: 0;
	
	
	transition: 0.7s; 
}

.service-start-install .start-content .phone a{
padding: 20px;
display: inline-flex;
background: #ed1d26;
color: white;
    font-family: font3;
		
		
		box-shadow: 1px -1px 0px 0px #ed1d26;;
		transition: 0.4s;

}
.service-start-install .start-content .phone a:hover{

	background: white;
	color: #ed1d26;
	transform: scale(1.05); 
		box-shadow: 5px 10px 2px 2px #ed1d26;;

	
}
.service-start-install:hover .start-content .phone{
	
	opacity: 1; 
}


.service-start-install .start-legend {
	
	position: relative; 
	    padding: 45px 15px 45px 15px; height: 100%;
    border: 2px solid #fff; color: #ed1d26;
		
		overflow: hidden;
		
				text-align:center;

}



.service-start-install .start-legend .side-link{
	position: absolute;
	top: 75%;
	
	left: 100%;
	
	transition: 0.7s;
	
	
	width: 100%;
	
	background: #ed1d26;
	color: white;
	padding: 10px ;
}
.service-start-install .start-legend a {
	color: white;
	font-family: font3;
	width:100%; 
}

.service-start-install:hover .start-legend .side-link{

	
	left: 10%; 
}




.service-start-install h2 {
	font-family: font3; font-size: 30px;
	
}
.service-start-install h3 {
	font-family: font3; font-size: 20px;  line-height: 40px; color: #ed1d26;
}
.service-start-install p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; 
}
.roof-install-process {
  padding: 80px 20px;
  background-color: #f9f9f9;
			text-align:center;

}

.process-title {
  font-size: 32px;
  margin-bottom: 40px;
  color: #222; font-family: font3;
}

.process-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
}

.process-step {
     background: linear-gradient(90deg, #f0e5e6bf 12%, #f0e5e6bf 12%), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-color: #f5e2e2 !important;
    color: #000;
    background-repeat: repeat;
  padding: 20px; margin: 15px 0px 15px 0px;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.06);
  transition: transform 0.3s ease, background-size 0.85s;

}

.process-step:hover {
  transform: translateY(-5px);
    background-size: 130%;

}

.process-step:hover h3 {


	font-size: 1.5rem; 

}

.process-step i {
        font-size: 45px;
        background: #ed1d26;
        margin-bottom: 15px;
        padding: 10px;
        color: #fff;
        border-top-right-radius: 15px;
        border-bottom-left-radius: 15px;
        position: relative;
        left: 0;
        top: 0;
    
}

.process-step h2 {
    font-size: 40px;
    text-align: left;
    margin-top: 0;
    margin-left: 0;
    margin-bottom: 0;
    border-top-left-radius: 10px;
    border-bottom-right-radius: 10px;
    padding: 0px 10px 0px 10px;
    background: #000;
    color: #fff;
    width: fit-content;
}

.process-step h3 {
  font-size: 20px; font-family: font3;
  margin-bottom: 10px; 
  color: #333;
	
	
	transition: 1s; 
}

.process-step p {
  font-size: 15px;
  color: #444;    font-family: Atlassian Sans;
  line-height: 1.6;
}
.roof-install-process img {
	border-radius: 10px; box-shadow: 1px 1px 10px 1px #000; margin-top: 75px;
}


.roof-types-materials {
	position: relative;    background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/homepage/texture-4.png);
    background-size: 100%;
    background-color: #F9F9F9 !important;
    background-repeat: repeat;
		
		
}



.roof-types-materials:hover {
    /*background-size: 110%;*/

		
		
}



.roof-types-materials .container-fluid {
/*	padding: 0px;*/
}
.roof-types-materials .row {
	 /*   --bs-gutter-x: 0;*/ 
}
.roof-types-materials .roof-types {
	/*	background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/services/roofing-types-1.jpg) no-repeat;
    background-size: cover;
		background-position: center center;
		background-color: #fff; */
		padding: 100px 0px 00px 0px;
    height: 100%; 
    
}
.roof-types-materials .roof-types h2 {
	margin-left: 10px;
	
        text-align: center;

	
}
.displayer1 {
	padding: 25px; background: #000000cf; width: 100%; color: #fff; margin-left: 0px; text-align: center;
}
    .triangle-up {
      width: 0;
      height: 0;
      border-left: 250px solid transparent;
      border-right: 250px solid transparent;
      border-bottom: 300px double  #000000cf;
			        display: none;
    }
.roof-types-materials .roof-materials {
/*		background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/services/roofing-materials-1.jpg) no-repeat;
    background-size: cover;
		background-color: #fff; 
    background-position: center center;*/
		padding: 100px 0px 0px 0px;
    height: 100%; 
}
.roof-types-materials h2 {
	   font-family: font3;
    font-size: 30px;
    color: #ed1d26;
    letter-spacing: 1px;
    margin-bottom: -0;
    margin-left: 0;
        text-align: center;
}
.roof-types-materials h3 {
    font-family: font3;
    font-size: 18px;
    margin-left: 0px;
    margin-right: -0px;
    line-height: 35px;
}
.roof-types-materials h3 span {
	color: #ed1d26;
}
.roof-types-materials p {
	font-size: 17px; line-height: 35px;     font-family: Atlassian Sans;
}
.roof-types-materials hr {
	    width: 135%; opacity: 25%;
   border-bottom: 5px dashed red;
    margin-top: -50px;
    margin-bottom: 50px;
	display: none; 
}
.service-pick {
background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/services/re-roof-1.jpg);
    background-size: cover; height: 100%; background-position: bottom center; padding: 100px 0px 100px 0px;
}
.service-pick .container-fluid {
	padding: 0px;
}
.service-pick .services-content {
	padding: 50px 15px 50px 15px; background: #0009; color: #fff; border-radius: 10px;
	text-align: center; 
}
.service-pick h2 {
	font-family: font3; font-size: 35px;
}
.service-pick h2 strong {
	font-family: Atlassian Sans; color: #ed1d26; font-size: 25px;
}
.service-pick p {
	font-size: 17px; line-height: 35px;     font-family: Atlassian Sans;
}
.service-reasons {
  list-style: none;
  padding: 0;
  margin-top: 30px;
}

.service-reasons li {
  position: relative;
  padding-left: 25px; margin-left:  0px;
  margin-bottom: 18px;  font-family: Atlassian Sans;
  font-size: 16px;
  line-height: 1.6;
  color: #fff;
}

.service-reasons li::before {
  content: '✔';
  position: absolute;
  left: 0;
  color: #ed1d26;
  font-weight: bold;
}

/*INSTALLS END*/

/**** Gallery Section ****/
.gallery-page {
	padding: 75px 0 50px 0;	background: rgb(249,249,249);
}
.gallery-page h1 {
	font-size: 3rem; font-weight: 600; font-family: 'font2'; padding-bottom: 40px; text-align: center; color: rgb(129,141,148);
}

/**** Areas We Service Section ****/

.locations {
	padding: 100px 0px 100px 0px; background: linear-gradient(90deg, #cdcdcdbf 12%, #cdcdcdbf 12%), url(/img/services/service-location-1.jpg);
    background-size: cover; height: 100%; background-position: center center; text-align: center;
}

.locations h1 {
	font-family: font3; font-size: 40px; letter-spacing: 2px;
}
.locations h1 span {
	font-size: 20px; color: #ed1d26;
}
.locations h4 {
	font-family: font3; font-size: 23px; text-align: center;
	padding: 35px 15px 35px 15px; background: #fff; border: 1px dotted #ed1d26; color: #ed1d26;
}
.locations h4:hover {
	background: #000; color: #fff;
}
.locations p {
	font-family: Atlassian Sans; font-size: 1rem; line-height: 35px; margin: 25px 10px 25px 10px;
}
.area1 {
	padding: 45px 0 45px 0; background: rgb(255,255,255);
	text-align: center; 
	
}
.area2 {
	padding: 45px 0 45px 0; background: rgb(245,245,245);
		text-align: center; 

}
.area1 h2, .area2 h2 {
	font-size: 30px; font-family: font3; font-weight: 500; color: #000; 
}
.area1 h2 span, .area2 h2 span {
	color: #ed1d26;
}
.area1 h4, .area2 h4 {
	font-size: 15px; font-family: Atlassian Sans; color: rgb(75,75,75); margin: 15px 0px 15px 0px;
}
.area1 h4 strong, .area2 h4 strong {
	font-size: 20px;color: #ed1d26;
}
.area1 p, .area2 p {
	font-size: 17px; text-align: justify; color: rgb(12,12,12); font-family: Atlassian Sans;
}


.area1 iframe{
	    box-shadow: 7px -7px 0px 0px #ed1d26; width: 100%; height: 400px; border-radius: 0.8rem; transition: box-shadow 0.5s; 
}
.area2 iframe{
	    box-shadow: -7px -7px 0px 0px #ed1d26; width: 100%; height: 400px; border-radius: 0.8rem; transition: box-shadow 0.5s; 
}


.area1:hover iframe{
	    box-shadow: 17px -17px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem;
}
.area2:hover iframe{
	    box-shadow: -17px -17px 0px 0px #ed1d26; width: 100%; height: 100%; border-radius: 0.8rem;
}

.location-map {
	margin-top: 25px;
}
.location-intro {
	padding: 100px 0px 100px 0px;     background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover; background-attachment: fixed;
    background-color: #fff;
    background-repeat: repeat;
}
.location-intro .spanner img {
    max-width: 100%;
    margin-left: 0;
    margin-top: 15px;
}
.location-intro h1 {
	font-family: font3; font-size: 35px;
}
.location-intro h1 span {
	font-size: 20px;
}
.location-intro h1 strong {
	color: #ed1d26; font-family: Atlassian Sans; font-size: 25px;
}
.location-intro h2 {
	font-family: font3; font-size: 25px; color: #ed1d26;
}
.location-intro h4 {
  position: relative;
  font-family: font3;
  font-size: 20px;
  text-align: center;
  padding: 25px;
  background: #ed1d26;
  margin: 10px;
  width: auto;
  color: #fff;
  z-index: 1;
  overflow: hidden; /* ensures pseudo-elements don't spill out */
}

.location-intro h4::before {
  content: "\f6e3"; /* hammer icon */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 100px;
  color: rgba(255, 255, 255, 0.1); /* subtle watermark effect */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-15deg);
  z-index: 0; /* behind the text */
  pointer-events: none;
}



.location-intro p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.location-intro img {
	max-width: 100%; margin-left: 0; margin-bottom: 100px;
}
.location-intro .location-content {
	padding: 50px 10px 50px 10px;    border: 2px solid #000;
    height: 100%;
		text-align: center; 
}
.location-intro .location-services {
	padding: 25px 5px; 
}
/* Highlight active tab */
.tab-buttons h4 {
  cursor: pointer;
  transition: background 0.3s ease;
}

.tab-buttons h4.active {
  background: #000;
  color: #fff;
}

/* Tab content box */
.tab-content {
  font-family: Atlassian Sans;
  font-size: 16px;
  line-height: 28px;
  padding: 20px;
  border-left: 3px solid #ed1d26;
  background: #f9f9f9;
  margin-top: 10px;
  display: none;
}

.location-body {
	padding: 40px 0px 40px 0px;     background: linear-gradient(to right, #ffffff00, #ffffff00), url(/img/homepage/roofing-2.jpg);
    background-size: cover; background-position: bottom center; background-attachment: fixed;
    background-repeat: repeat;
}
.location-body .location-card {
/*	padding: 50px 25px 50px 25px; border-radius: 5px; background: #fff; margin: 15px 0px 15px 0px; border: 2px solid #000;*/
}
.location-body h2 {
	font-family: font3; font-size: 25px; color: #ed1d26;
}
.location-body p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px;
}
.location-body i {
	    font-size: 50px;
    left: 80%;
    margin-top: -25px;
}


.location-body .view1 {
	padding: 5px;
	background-color: #0000009e;
	color: #000;
	position: relative;
	overflow: hidden;
margin: 15px 0px;
	border-radius: 10px;
    position: relative;
    overflow: hidden;
    z-index: 20;
	transition: 1s; 
}
.location-body .view1:hover {

	transform: scale(1.03); 

}
.location-body .view1::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
    /*height: 600px;*/
    /*width: 200px;*/
    height: 000px;
    width: 0%;
    background: #ed1d26;
    box-shadow: 0 0 10px #ed1d26, 0 0 40px #ed1d26, 0 0 80px #ed1d26;
	
	
	pointer-events: none; 
    /*animation: rotate_border 6s linear infinite;*/
	
	transition: 1s; 
}

.location-body .view1:hover::after {
	
    height: 2000px;
    width: 15%;	
	
	
	animation: rotate_border 8s linear infinite;
}

#in {
    height: 100%;
    width: 100%;
    background-color: #fff;
    border-radius: 10px;
    position: relative;
    z-index: 99;
	    padding: 50px 25px; 
}
.location-body .view1:hover #in {
	background: #fff;
}

@keyframes rotate_border{
	
	100%{
		transform: translate(-50%,-50%) rotate(360deg); 
	}
	
}


.location-choose {
	padding: 100px 0px 100px 0px;background: linear-gradient(to right, #ffffffd9, #ffffffd9), url(/img/homepage/9.png);
    background-size: cover;
    background-color: #0009;
    background-repeat: repeat;
}
.location-choose .cawd {
	position:relative; 
	padding: 25px; background: #fff; margin: 15px 0px 15px 0px;
	
	opacity: 0;
	transition: 1.5s;
	/*z-index: 3; */
}
.location-choose .cawd::before {
	
	position:absolute;
	top:0%;
	left: 0%;
	
	/*transform:translate(-50%,-50%); */
	
	/*z-index: 0; */

  content: "\f6e3"; 
  font-family: "Font Awesome 6 Free"; 
  font-weight: 900; 
  font-size: 24px;
  margin-right: 10px;
  color: #ed1d26;
	padding:5px;
	
	background: black; 
}








.location-choose .cawd.left {
		transform: translateX(-20%);

}
.location-choose .cawd.right {
		transform: translateX(20%);
}

.location-choose h3 {
	font-family: font3; font-size: 35px;  text-align: center; margin-bottom: 100px;
}
.location-choose h3 strong {
	font-size: 25px; font-family: Atlassian Sans; color: #ed1d26;
}
.location-choose h4 {
	font-family: font3; font-size: 23px;  text-align: center;
}
.location-choose p {
	font-family: Atlassian Sans; font-size: 17px; line-height: 35px; text-align: center;
}
.location-choose img {
	box-shadow: 1px 1px 10px 1px #000;
}



.location-choose .cawd.left.show-more {
	transform: translateX(0);
	opacity: 1; 
}


.location-choose .cawd.right.show-more {
	/*background: black;*/
	transform: translateX(0);
	opacity: 1; 
	
	
}



/* === Full-height wrapper === */
.chevron-bar-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  z-index: 999;
  pointer-events: none;
	        display: none;
}

/* === Vertical red bar === */
.chevron-vertical-bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 100%;
  background-color: #ed1d26;
  z-index: 1;
}

/* === Chevron button container (centered) === */
.chevron-button-wrapper {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  pointer-events: auto;
}

/* === Chevron button styling === */
.chevron-button {
  background-color: #ed1d26;
  color: white;
  padding: 20px 20px;
  font-size: 15px;
  font-weight: bold;
  font-family: Atlassian Sans;
  
  line-height: 1.4;
  width: 170px;
  clip-path: polygon(0 0, 85% 0, 100% 50%, 85% 100%, 0 100%);
  cursor: pointer;
  transition: background 0.3s ease;
  box-shadow: 2px 4px 12px rgba(0,0,0,0.2);
  z-index: 2;
  position: relative;
}

.chevron-button:hover {
  
}

/* === Hover panel === */
.chevron-panel {
  position: absolute;
  top: 0; margin-top: -50px;
  left: 100%;
  margin-left: -3px;
  background-color: #fff;
  color: #333;
  border-radius: 0 10px 10px 0;
  padding: 20px;
  box-shadow: 4px 6px 20px rgba(0, 0, 0, 0.15);
  min-width: 400px;
  display: flex;
  gap: 30px;
	font-family: Atlassian Sans;

  /* Hidden by default */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/* === Show panel on hover === */
.chevron-button-wrapper:hover .chevron-panel {
  opacity: 1;
  pointer-events: auto;
}

/* === Panel content layout === */
.chevron-column {
  flex: 1;
  min-width: 180px;
}

.chevron-column h4 {
  font-size: 16px;
  margin-bottom: 10px; font-family: font3; 
  color: #ed1d26;
  border-bottom: 1px solid #ddd;
  padding-bottom: 4px;
}

.chevron-column ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.chevron-column ul li {
  padding: 6px 0;
  font-size: 14px;
  border-bottom: 1px solid #eee; 
}

.chevron-column ul li:last-child {
  border-bottom: none;
}

.chevron-panel mark {
	padding: 10px; background: #ed1d26; color: #fff; border-radius: 3px; margin-left: -15px;
}
.chevron-panel mark:hover {
	background: #000;
}
.chevron-panel a {
	color: inherit;
}
.chevron-panel a:hover {
	color: #ed1d26; text-decoration: underline !important; font-weight: 600;
}


.footer-section {
    padding: 0 0 10px;
    background: linear-gradient(to right, #fffffff2, #fffffff2), url(/img/homepage/texture-1.png);
    background-size: cover;
    background-repeat: repeat;
    font-size: 18px;
    font-weight: 400;
		text-align: center; 
}
.contact-form-section .form-box {
    background: #fff;
    border: 2px solid #000;
    padding: 50px 10px;
}

}

/* === Mobile CSS Section ===================== */
@media screen and (max-width: 425px) {


/**** About Section ****/


/**** Services Section ****/


/**** Gallery Section ****/
.gallery-page {
	padding: 75px 0 50px 0;	background: rgb(249,249,249);
}
.gallery-page h1 {
	font-size: 3rem; font-weight: 600; font-family: 'font2'; padding-bottom: 40px; text-align: center; color: rgb(129,141,148);
}

/**** Areas We Service Section ****/
.area:nth-child(odd) {
	padding: 75px 0 75px 0; background: rgb(255,255,255);
}
.area:nth-child(even) {
	padding: 75px 0 75px 0; background: rgb(245,245,245);
}
.area h2 {
	font-size: 2.5rem; font-family: font2; font-weight: 800; color: rgb(196,41,56);
}
.area h4 {
	font-size: 1.5rem; font-family: font2; color: rgb(75,75,75);
}
.area p {
	font-size: 17px; text-align: justify; color: rgb(12,12,12);
}
.area iframe {
	width: 100%; height: 100%; border-radius: 0.8rem; box-shadow: 1px 1px 10px 1px rgb(0,0,0);
}

/**** Testimonials Section ****/
.testimonials {
	padding: 30px 0 30px 0; background: rgb(255,255,255);
}

/**** Contact Section ****/


/**** Sections On Every Page ****/



/**** Footer Section ****/


/**** Misc. Section ****/
.btn {
	background: rgb(249,78,1); width: 50%; padding: 10px 0px; color: #ffffff; cursor: pointer; outline: none; border: none;
}
.alert h1,
.alert p {
	top: 2em; opacity: 0; position:relative;
}
.alert h1 {
	margin-top: 0; color: #2b1663;
}
.custom-show {
	position: fixed; transform: scale(1,1); border: 0; background: white; border-radius: 0; z-index: 1100; overflow: inherit; -webkit-transition-property: all; -webkit-transition-duration: .30s; -webkit-transition-timing-function: ease-in-out; transition-property: all; transition-duration: .30s; transition-timing-function: ease-in-out;
}
.alert-dismissible .close {
	position: absolute; top: 0; right: 0; background: transparent; border: none; padding: 0.75rem 1.25rem; color: rgb(80,80,80); font-family: 'font2'; outline: none; z-index: 3;
}
.alert-dismissible .close span {
	font-size: 35px;
}
.lnr {
	display: inline-block; fill: currentColor; width: 1em; height: 1em; vertical-align: -0.2em; cursor: pointer;
}

}
/* === Sm. Mobile CSS Section ================= */
@media screen and (max-width: 375px) {

}