@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");
body{
    margin: 0px;
    padding: 0px;
    font-family: 'Poppins';
}
.logo-main img {
    max-width: 140px;
}
.navlinks li {
	padding: 0 5px;
}
.navlinks li a {
    font-size: 16px;
    font-weight: 400;
    color: #1F2329;
	font-family: "Roboto", sans-serif;
}
.top-header {
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.5);
    padding: 2px 0px;
}
.top-header .navlinks .nav-item a:hover {
	color: #701011;
}
.logos img {
	width: 90px;
}
.f-title {
	margin: 0px;
	color: #B1B1B1;
	font-size: 13px;
	font-weight: 400;
}
.f-title a {
	color: #fff;
	text-decoration: none;
	font-weight: 500;
}
.banner-img img {
	width: 100%;
}
.t-background {
	background: #E6EAEF;
	padding: 15px;
}
.left-t h2 {
	font-size: 22px;
	text-align: center;
	color: #303133;
	margin-bottom: 22px;
}
.left-t {
	text-align: center;
	font-weight: 500;
	color: #303133;
}
.blog-items {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
	padding: 20px;
}
.blog-boxes {
	display: grid;
	grid-template-columns: 32% 32% 32%;
	gap: 2%;
}
.blog-items p {
	margin: 0px;
	color: #252525;
	font-size: 14px;
	margin-bottom: 7px;
}
.blog-items h2 {
	font-size: 24px;
	padding: 14px 0;
	margin: 0px;
}
.img-b {
	margin: 0px !important;
	position: relative;
	margin-top: 17px !important;
}
.img-b::before {
	content: "";
	background: #313131;
	width: 60px;
	height: 2px;
	position: absolute;
	top: -3px;
}
.blog-items h3 {
	font-size: 19px;
}
.blog-items img {
	width: 100%;
}
.resi-sec {
	background: #DEE4EF;
	padding: 50px 0px;
	text-align: center;
}
.resi-sec p {
	margin: 0px;
	color: #444444;
	font-size: 20px;
}
.res-text h2 {
	font-size: 27px;
}


.testimonial-slider {
	max-width: 600px;
	margin: 11px auto;
	text-align: center;
	position: relative;
}

  .testimonial {
	display: none;
	padding: 20px 50px;
	border: 1px solid #ddd;
	border-radius: 10px;
	background: #f9f9f9;
}

    .testimonial.active {
      display: block;
    }

    .review-text {
      font-style: italic;
      margin-bottom: 10px;
    }

    .review-stars {
      font-size: 20px;
      color: gold;
      margin-bottom: 10px;
    }

    .reviewer-name {
      font-weight: bold;
    }
    .slider-buttons button {
      padding: 8px 12px;
      margin: 0 5px;
      border: none;
      background-color: #333;
      color: white;
      border-radius: 5px;
      cursor: pointer;
    }

    .slider-buttons button:hover {
      background-color: #555;
    }
    .slider-buttons #prevBtn {
	position: absolute;
	left: -44px;
	top: 43%;
}
 .slider-buttons #nextBtn {
	position: absolute;
	right: -44px;
	top: 43%;
}
.roof-c h2 {
	color: #303133;
	font-size: 23px;
}
.roof-c {
	text-align: center;
	max-width: 900px;
	margin: 0 auto;
	width: 100%;
}
.blog-items ol {
	padding-left: 14px !important;
}
.blog-items button {
	position: unset !important;
	margin-top: 10px;
}
.blog-items .testimonial {
	min-height: 290px;
}
.roof-c .testimonial-slider {
	margin-top: 0px;
	margin-bottom: 0px;
}
.roof-c .testimonial-slider #prevBtn {
	left: -14px;
}
.roof-c .testimonial-slider #nextBtn {
	right: -14px;
}
.secc {
	text-align: left;
	font-size: 14px;
}
.secc h4 {
	font-size: 19px;
	margin-bottom: 0px;
	margin-top: 7px;
}
.roof-c.school-roof {
	max-width: 100%;
	text-align: left;
}
.f-sec.py-3 p {
	margin: 0px;
	font-size: 18px;
	font-weight: 500;
	color: #000;
}
.b-box {
	border: 1px solid #1E73BE;
	padding: 15px;
}
.b-box p {
	font-size: 15px;
	margin-bottom: 7px;
}
.b-box h5 {
	font-size: 20px;
}
.n-sec h2 {
	margin: 0px;
	font-size: 23px;
	color: #303133;
}
.n-sec p {
	margin: 0px;
	font-size: 15px;
}
.schl-box {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
	padding: 20px;
}
.schl-box img {
	width: 100%;
    transition: all 0.3s ease 0s;
  -webkit-transition: all 0.3s ease 0s;
}
.schl-box img:hover {
	transform: scale(0.9);
}



.gallery {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	max-width: 800px;
	margin: 50px auto;
	justify-content: center;
}
    .gallery img {
      width: 25%;
      cursor: pointer;
      border-radius: 5px;
    }

    .lightbox {
      position: fixed !important;
      top: 0; left: 0;
      width: 100%; height: 100%;
      background: rgba(0, 0, 0, 0.8);
      display: none;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      z-index: 9999;
    }

    .lightbox img {
      max-width: 90%;
      max-height: 80vh;
    }

    .lightbox .controls {
      margin-top: 15px;
    }

    .lightbox button {
      padding: 10px 20px;
      margin: 0 10px;
      font-size: 16px;
      cursor: pointer;
    }
    .close {
	position: absolute;
	top: 34px;
	right: 13px;
	border: none;
	background: none;
	color: #fff;
	font-size: 35px !important;
}
.arrow {
	background: no-repeat;
	border: none;
	color: #fff;
	font-size: 35px !important;
}
.left-icon.arrow {
	position: absolute;
	left: 0px;
	top: 0px;
	bottom: 0px;
}
.right-icon.arrow {
	position: absolute;
	right: 0px;
	top: 0px;
	bottom: 0px;
}
.reviews-text h2 {
	font-size: 32px;
}
.review-boxes {
	box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
	padding: 15px;
	margin-bottom: 15px;
}
.review-boxes h3 {
	color: #444444;
	font-size: 25px;
	margin: 0px;
}
.review-boxes .stars i {
	color: #ef9a23;
}
.review-boxes p {
	margin: 0px;
	color: #444444;
	font-size: 15px;
}
.review-boxes .stars {
	padding: 13px 0;
}
.contact-f {
	max-width: 680px;
	margin: 50px auto;
	width: 100%;
	box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
	padding: 20px;
}
.contact-f h2 {
	text-align: center;
	margin-bottom: 18px;
}
.contact-f .input-field input {
	width: 100%;
	height: 42px;
}
.contact-f .msg {
	margin-bottom: 15px;
}
.contact-f .msg textarea {
	width: 100%;
}
.contact-f .radio input {
	margin-bottom: 7px;
	margin-right: 2px;
}
.contact-f .radio label {
	margin-bottom: 7px;
}
.contact-f .input-field {
	margin-bottom: 15px;
}
.contact-f .radio p {
	margin: 0px;
	font-size: 18px;
	font-weight: 500;
	padding-bottom: 5px;
}
.submit-btn input {
	border: none;
	background: #954949;
	color: #fff;
	padding: 11px 31px;
	border-radius: 5px;
	text-transform: uppercase;
}
.top-header #navbarNav .navbar-nav .nav-item a::before {
	background: #944C4C;
	content: "";
	position: absolute;
	left: 0;
  	bottom: 0;
  	width: 0;
  	height: 2px;
  	transition: 0.5s;
}
.top-header #navbarNav .navbar-nav .nav-item.active a {
	color: #944C4C;
	font-weight: 600;
	border-bottom: 2px solid #944C4C;
}

.top-header #navbarNav .navbar-nav .nav-item.active a::before {
	height: 0px !important;
}
.top-header #navbarNav .navbar-nav .nav-item a {
	position: relative;
	font-family: "poppins";
}
.top-header #navbarNav .navbar-nav .nav-item a:hover::before {
	width: 100%;
}
@media screen and (max-width: 450px) {
        .gallery img {
        width: 100% !important;
    }
    .gallery {
        padding: 15px;
    }
}
@media screen and (min-device-width: 451px) and (max-device-width: 600px) { 
     .gallery img {
        width: 48% !important;
    }
    .gallery {
        padding: 15px;
    }
}
@media screen and (min-width: 992px) {
    .top-header #navbarNav .navbar-nav {
	max-width: 600px;
	justify-content: center;
}
.logo-main p {
	width: 452px;
}
}
@media screen and (max-width: 991px) {
.logos {
	display: none;
}
.logo-main p {
	display: none;
}
.top-header #navbarNav {
	position: absolute;
	background: #fff;
	width: 100%;
	left: 0px;
	top: 92px;
	padding-left: 11px;
}
.slider-buttons #prevBtn {
	left: -17px !important;
}
.slider-buttons #nextBtn {
	right: -17px !important;
}
}
@media screen and (max-width: 767px) {
.blog-boxes {
	display: grid;
	grid-template-columns: 100%;
	gap: 1%;
}
.f-title {
	text-align: center;
}
.logo-f.d-flex.gap-4.justify-content-end {
	text-align: center;
	justify-content: center !important;
	margin-top: 15px;
}
.roof-c h2 {
	font-size: 20px;
}
.n-sec img {
	width: 100%;
}
}
@media screen and (min-device-width: 768px) and (max-device-width: 991px) { 
.blog-boxes {
	grid-template-columns: 49% 49%;
	gap: 2%;
}
}
