@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Charmonman:wght@400;700&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

body, html {
  padding:0px;
  margin:0px;
  font-size: 17px;
  font-family: Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
  min-height: 100%;
  color: white;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  letter-spacing: 1px;
  }
  
  a {
    color: yellow;
}

.navigation a.active {border-bottom: 4px solid yellow;padding-bottom: 5px;}

.page-content {
  opacity: 0; /* Initially hidden */
  transition: opacity 0.5s ease; /* Apply fade-in and fade-out transition */
}

#full-size-page {
   min-height:100%;
   width: 100%;
   position:absolute;
   top:0;
   left: 0;
	 
}
#wrapper {
	margin: 0;
	padding-top: 0;
	padding-right: 0;
	padding-left: 0;
 
}

#footer {
	position: absolute;
	bottom: 0px;
	width: 100%;
	display: flow-root;
	color: white;
	background: rgb(0 0 0 / 59%);
	min-height: 250px;
}


#threeFooter div .logo  {font-size: 30px;font-weight: bold;color: #ffffff;text-decoration: none;text-shadow: 4px 2px 3px rgb(0 0 0 / 87%);}
 
 
 
#footer h6 {
    font-size: 23px;
    padding: 0px;
    margin: 0px;
}
#footer a {color:white;text-decoration: none;}
#infoot {max-width: 1370px;margin:auto;font-size: 17px;padding: 20px;padding-top: 0px;}

#threeFooter{text-align:center;margin:auto;padding: 30px;}                  
                  
                  
#threeFooter div:first-child{margin-left:0!important;                  
text-align:left;                  
float:left;}                  
                  
   #threeFooter ul {list-style: none;padding: 0;}

#threeFooter li a {
        text-decoration: none;
        /* margin-bottom: 5px; */
        display: block;
        padding: 7px;
        font-size: 17px;
        text-transform: lowercase;
        color: white;
}
               
#threeFooter div{width:31%;                  
overflow:hidden;                  
padding-bottom:17px;                  
margin-bottom:15px;                  
display:inline-block;                  
vertical-align:top;                  
z-index:100;                  
position:relative;}                  
                  
                  
#threeFooter h3{color: #ffffff;text-transform:capitalize;}                  
                  
                  
#threeFooter div:last-child{margin-right:0!important;                  
float:right;                  
text-align:right;} 


h1,h2,h3,h4,h5,h6 {font-size:22px; font-family: "Montserrat", sans-serif;}

#heroHolder {
	   /* Ensures the full height for centering */
	   margin: 0; /* Removes default margin */
	   /* display: flex; */
	   justify-content: center; /* Center horizontally */
	   align-items: center; /* Center vertically */
	   text-align: center; /* Centers the text inside the container */
}

.homeHero {
	  /* Adjust the width as necessary, or keep it auto */
	  color: white;
	  max-width: 1500px; /* Example width */
	  padding: 2%; /* Adds some padding inside the homeHero */
	  font-size: 25px;
	  clear: both;
	  margin: auto;
	  margin-bottom: 30px;
	  box-sizing: border-box;
	  }
	  
	  .homeHero b {color: #ffffff;text-shadow: 1px 1px 3px #00000061;font-size: 60px;text-shadow: 2px 3px 2px rgb(0 0 0);}
	  
	  .aiInputs::placeholder {font-family: "Arial", sans-serif; color:black; font-weight:normal;}
	  .aiInputs {box-sizing: border-box;border: 1px solid #0d1d5a;width: 100%;background: rgb(255 255 255);max-width: 900px;color: black;resize: none;padding:20px;font-size:22px;/* border: none; */margin-bottom: 10px;border-radius: 6px;-webkit-box-shadow: inset 5px 4px 3px 0px rgb(31 31 31 / 19%);/* box-shadow: inset 1px 0px 6px 2px hsl(0deg 0% 12.16% / 82%); */}
	  
	  
#business_info {
	min-height: 250px;
	} 
	
	  #response {position:relative;max-width: 1200px;margin:auto;text-align:left;font-size: 19px;/* background: #f7f7f7; */padding: 20px;/* border: 1px solid #ebebeb; */border-radius: 10px;margin-top: 20px;color: white;text-shadow: 2px 2px 1px #0D0D0D;}
	  
	  .introParagraph {
    padding-left: 40px;
    margin-bottom: 30px;
    border-left: 4px solid grey;
    background: rgb(0 0 0 / 21%);
    padding: 10px;
    border-radius: 0 55px 0px 0px;
    padding-left: 30px;
    padding-right: 30px;
    max-width: 900px;
    margin: auto;
}
	  .diva {
    font-weight: normal;
}
	  .divb {
    padding-left: 40px;
    margin-bottom: 30px;
    border-left: 4px solid grey;
}

#package{visibility:hidden;}

ul.bList {
  list-style-type: none; /* Remove default list styling */
   /* Optional: Removes the padding to align with the parent container */
}

ul.bList li::before {
	 font-size: 24px; /* Increase font size for dominance */
	 font-weight: bold; /* Attempt to make the tick bolder, effectiveness depends on the font */
	 content: "\2713\0020"; /* Adds a tick mark and a space before the list item text */
	 color: #FFEB3B; /* Sets the color of the tick mark */
	 margin-right: 8px; /* Optional: Adjust space between the tick mark and the text */
	 position: absolute;
	 left: -28px;
}

.bList li {
    margin-bottom: 15px;
    position: relative;
}

#bgvid video {
    width:100%;
    height:100%;
    background: url(layout/HomeBG.jpg) no-repeat;
    background-size: cover;
    }

#bgvid {
    position: fixed;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: -100;
    -ms-transform: translateX(-50%) translateY(-50%);
    -moz-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
 
}
 

#bgvid::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgb(3 21 89 / 91%); /* Adjust the color to get the desired hue */
  opacity: 0.99; /* Adjust the opacity to control the intensity of the hue */
  mix-blend-mode: normal; /* This blend mode works well for adding color to darker areas */
}


button#submitForm {
   padding: 20px;
   margin: auto;
   display: block;
   background: #ffff0b;
   width: fit-content;
   border-radius: 40px;
   color: black;
   text-decoration: none;
   font-weight: bold;
   font-size: 22px;
   text-transform: uppercase;
   border: none;
}

.oneWide
{
    max-width: 1300px;
    margin: 10px;
    display: flow-root;
} 
.twoWide {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    /* align-items: center; */
    /* max-width: 1500px; */
    margin: auto;
    margin-bottom: 50px;
    /* border-radius: 21px; */
    /* border: 1px solid #3F51B5; */
    /* align-items: center; */
}

.twoWide > div {
    padding: 30px;
    flex: 1;
    /* font-size: 22px; */
    text-align: left;
}

.twoWide.reverse > div:first-child {
    order: 2;
}

.twoWide.reverse > div {
    text-align: right;
}

.twoWide > div > a {
    /* display: inline-block; */ /* Makes the <a> tag respect parent text alignment */
    width: 100%; /* Ensures the <a> tag fills its container */
}

.twoWide > div > a > img {
    /* display: block; */ /* Ensures the img behaves according to the text-align of its parent */
    max-width: 100%; /* Adjust based on your style needs */
    margin-left: auto; /* Aligns the image to the right within the <a> tag */
    padding-top: 30px;
    padding-bottom: 30px;
}


.twoWide textarea {
  width: 100%; 
 
  box-sizing: border-box; /* Include padding and border in the height */
}


#requestForm {text-align:center;}

#requestForm input, form#requestForm button {
    font-size: 24px;
    margin-right: 20px;
    margin-bottom: 20px;
}

#requestForm button {text-transform: uppercase;background: #ffff0b;border:1px solid white;padding:10px;border-radius:12px;font-weight: bold;font-size: 22px;}

.oneWide.outro {
    text-align: center;
    font-size: 25px;
}

div#holder {
    max-width: 1200px;
    margin: auto;
    color: white;
}

.projects .twoWide {
  background: rgb(24 40 100 / 54%);
  align-items: center;
   
}

.projects  div {
  position: relative;
  /* max-height: 292px; */
  overflow: hidden;
}

.projects > div a {
  display: block;
}

.projects  div {
  padding: 0;
  /* width: 100%; */
  height: auto;
  transition: transform 0.3s ease;
  opacity:0;
}

.projects > div h4 {
  -webkit-text-stroke: white 0.8px;
  margin: 0;
  color: #fff0;
  padding: 5px 10px;
  font-size: 100px;
  font-weight: normal;
  text-shadow: 0px 6px -2px rgb(28 28 28 / 76%);
}

.projectText {padding: 57px;}


a.moreDetails {
    color: white;
    padding: 20px;
}


@-moz-keyframes fadeIn {
  0% {opacity:0;}
  100% {opacity:1;}
}

@-webkit-keyframes fadeIn {
  0% {opacity:0;}
  100% {opacity:1;}
}

@-o-keyframes fadeIn {
  0% {opacity:0;}
  100% {opacity:1;}
}

@-ms-keyframes fadeIn {
  0% {opacity:0;}
  100% {opacity:1;}
}

.fadeIn {
    animation: fadeIn 3s;
    -webkit-animation: fadeIn 2s;
    -moz-animation: fadeIn 3s;
    -o-animation: fadeIn 3s;
    -ms-animation: fadeIn 3s;
    animation-fill-mode: forwards;
}

/* Keyframes for sliding in from the left */
@keyframes slideInFromLeft {
  from {
    transform: translateX(-120%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

/* Keyframes for sliding in from the right */
@keyframes slideInFromRight {
  from {
    transform: translateX(120%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.fadeIn div h4 {
  /* Apply animation */
  animation-duration: 2s; /* Adjust time as needed */
  animation-timing-function: ease-out;
  animation-fill-mode: forwards; /* Keeps the element in the final state of the animation */
}

/* Apply the sliding animation based on the class */
.fadeIn div h4 {
  animation-name: slideInFromLeft;
}

.fadeIn.reverse div h4 {
  animation-name: slideInFromRight;
}


.whyChooseUs {
    background: #000000b0;
}
.whyChooseUs div {
    max-width: 1500px;
    margin: auto;
    padding: 30px;
}
.whyChooseUs div b {
    -webkit-text-stroke: white 0.8px;
    margin: 0;
    color: #fff0;
    padding: 5px 10px;
    font-size: 58px;
    font-weight: normal;
    text-align: center;
}

.smartQuoteButton {
    padding: 20px;
    margin: auto;
    display: block;
    background: #ffff0b;
    width: fit-content;
    border-radius: 40px;
    color: black !important;
    text-decoration: none;
    font-weight: bold;
    font-size: 22px;
}

div.projectDetails {
    max-width: 1300px;
    margin: auto;
    margin-top: 100px;
}

.projectDetails h1 {font-size:45px;-webkit-text-stroke: white 0.8px;margin: 0;color: #fff0;padding: 5px 10px;font-size: 100px;font-weight: normal;text-align: center;margin-bottom: 50px;}
 

.projectDetails img {
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	vertical-align: text-bottom;
	border: 10px solid black;
	border-radius: 30px;
	-webkit-box-shadow: 0 20px 12px 12px #242424;
	box-shadow: 0 7px 18px 7px rgb(0 0 0 / 77%);
}

.projectDescription {
    padding: 35px !important;
}

a.visitWebsite {
    padding: 20px;
    background: white;
    color: black;
    font-weight: bold;
    text-decoration: none;
    border-radius: 33px;
}

.generalWidth .twoWide {
    max-width: 1162px;
}

.generalWidth li {
    margin-bottom: 5px;
}

a.nextProject {
    /* background: yellow; */
    float: right;
    color: white;
    border-radius: 37px;
    padding: 12px;
    /* text-decoration: none; */
    text-transform: uppercase;
    /* font-weight: bold; */
    font-size: 30px;
    margin-top: 50px;
}