/* Fixed WhatsApp & Call Icons */
.fixed-contact-icons {
	position: fixed;
	left: 18px;
	bottom: 90px;
	z-index: 9999;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.fixed-contact-icons.right {
	left: auto;
	right: 18px;
}
.fixed-contact-icons a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 4px 16px rgba(1,61,148,0.12);
	font-size: 2rem;
	color: #25d366;
	transition: background 0.2s, color 0.2s, transform 0.2s;
	border: 2px solid #25d366;
}
.fixed-contact-icons a.fixed-call {
	color: #116760;
	border-color: #116760;
}
.fixed-contact-icons a.fixed-call-red {
	color: #fff;
	background: #e53935;
	border-color: #e53935;
	box-shadow: 0 4px 16px rgba(229,57,53,0.18);
	transition: background 0.2s, color 0.2s, transform 0.2s;
}
.fixed-contact-icons a.fixed-call-red:hover {
	background: #b71c1c;
	color: #fff;
	border-color: #b71c1c;
}
.fixed-contact-icons a:hover {
	background: #25d366;
	color: #fff;
	transform: scale(1.08);
}
.fixed-contact-icons a.fixed-call:hover {
	background: #116760;
	color: #fff;
}

/* Footer Gradient Brand with White Shadow */
.footer-modern .footer-gradient-title {
	background: linear-gradient(90deg, rgb(1,61,148) 0%, rgb(17,135,96) 33%, rgb(254,183,54) 66%, rgb(195,43,16) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	color: transparent;
	font-family: 'Segoe UI', 'Poppins', Arial, sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
	line-height: 1.1;
	display: inline-block;
	text-shadow: 0 2px 8px #fff, 0 1px 0 #fff;
}
/* Service Details Blog/Product Style */
.service-details-hero {
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.service-details-hero h1 {
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.service-detail-blog .card {
	border-radius: 1.5rem;
	border: none;
	background: #fff;
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	overflow: hidden;
}
.service-detail-blog .card img {
	border-radius: 0;
	object-fit: cover;
	width: 100%;
	height: 100%;
	min-height: 320px;
	max-height: 420px;
}
.service-detail-blog .badge {
	font-size: 1rem;
	border-radius: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.5px;
}
.service-detail-blog ul {
	padding-left: 1.2rem;
}
.service-detail-blog li {
	font-size: 1.08rem;
	margin-bottom: 0.5rem;
}
@media (max-width: 991.98px) {
	.service-detail-blog .row {
		flex-direction: column;
	}
	.service-detail-blog .col-md-6 {
		max-width: 100%;
		margin-bottom: 1.5rem;
	}
	.service-detail-blog .card img {
		min-height: 180px;
		max-height: 260px;
	}
}
/* Contact Page Modern Layout */
.contact-section .card {
	border-radius: 1.5rem;
	border: none;
	background: #fff;
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	padding: 2rem 1.5rem;
}
.contact-section .form-label {
	color: var(--brand-blue);
	font-weight: 500;
}
.contact-section .btn-success {
	background: var(--brand-green);
	border: none;
	font-weight: 600;
	letter-spacing: 1px;
}
.contact-section .btn-success:hover {
	background: var(--brand-blue);
	color: #fff;
}
.contact-section .top-header-icon {
	font-size: 1.5rem;
	color: var(--brand-blue);
	margin-right: 0.5rem;
	transition: color 0.2s, transform 0.2s;
}
.contact-section .top-header-icon:hover {
	color: var(--brand-yellow);
	transform: scale(1.15);
}
.contact-section iframe {
	border-radius: 1rem;
	min-height: 180px;
}
@media (max-width: 991.98px) {
	.contact-section .row {
		flex-direction: column;
	}
	.contact-section .col-lg-6 {
		max-width: 100%;
		margin-bottom: 2rem;
	}
}
/* About, Services, Contact Banners */
.about-banner,
.services-section-banner,
.contact-section-banner {
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 260px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.about-banner h1,
.services-section-banner h1,
.contact-section-banner h1 {
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.18);
}

/* Modern Service Card */
.service-card-modern {
	border-radius: 1.5rem;
	border: none;
	background: #fff;
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	transition: transform 0.2s, box-shadow 0.2s;
	backdrop-filter: blur(2px);
}
.service-card-modern:hover {
	transform: translateY(-6px) scale(1.03);
	box-shadow: 0 8px 40px rgba(1,61,148,0.16);
}
.service-card-modern .btn-warning {
	color: var(--brand-blue);
	background: var(--brand-yellow);
	border: none;
	font-weight: 600;
}
.service-card-modern .btn-warning:hover {
	background: var(--brand-red);
	color: #fff;
}

/* Modern Contact Card */
.contact-section .card {
	border-radius: 1.5rem;
	border: none;
	background: #fff;
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	padding: 2rem 1.5rem;
}
.contact-section .form-label {
	color: var(--brand-blue);
	font-weight: 500;
}
.contact-section .btn-success {
	background: var(--brand-green);
	border: none;
	font-weight: 600;
	letter-spacing: 1px;
}
.contact-section .btn-success:hover {
	background: var(--brand-blue);
	color: #fff;
}
/* Top header: show/hide mobile/desktop blocks correctly */
@media (max-width: 600px) {
	.top-header-bar .top-header-info,
	.top-header-bar .top-header-desktop {
		display: none !important;
	}
	.top-header-bar .top-header-mobile {
		display: flex !important;
	}
}
@media (min-width: 601px) {
	.top-header-bar .top-header-mobile {
		display: none !important;
	}
	.top-header-bar .top-header-info,
	.top-header-bar .top-header-desktop {
		display: flex !important;
	}
}
@media (max-width: 600px) {
	.hero-section-video {
		padding-top: 50px !important;
	}
	.top-header-bar .top-header-info {
		display: none !important;
	}
	.top-header-bar .top-header-mobile {
		display: flex !important;
	}
}
/* Responsive Navbar Tweaks */
@media (max-width: 991.98px) {
	.navbar .main-nav-menu {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 0.7rem !important;
		width: 100%;
		margin-top: 0.5rem;
	}
	.navbar .main-nav-menu .nav-link {
		width: 100%;
		text-align: left;
		padding-left: 1.5rem;
		font-size: 1.1rem;
		border-radius: 0.5rem;
	}
	.navbar .logo img {
		height: 44px !important;
	}
	.navbar .brand-gradient-title {
		font-size: 1.1rem !important;
	}
}
@media (max-width: 600px) {
	.navbar .logo img {
		height: 36px !important;
	}
	.navbar .brand-gradient-title {
		font-size: 0.98rem !important;
	}
}
/* Top Header Bar Gradient & Icons */
.top-header-bar {
	background: linear-gradient(90deg, rgb(1,61,148) 0%, rgb(17,135,96) 60%, rgb(254,183,54) 100%);
	color: #fff;
	font-family: 'Poppins', 'Segoe UI', Arial, sans-serif;
	font-size: 0.98rem;
}
.top-header-link {
	color: #fff;
	text-decoration: underline dotted;
	transition: color 0.2s;
}
.top-header-link:hover {
	color: rgb(254,183,54);
}
.top-header-icon {
	color: #fff;
	font-size: 1.35rem;
	margin-right: 0.1rem;
	transition: color 0.2s, transform 0.2s;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.top-header-icon:hover {
	color: rgb(254,183,54);
	transform: scale(1.18);
}
.top-header-bar .gap-3 {
	gap: 1.2rem !important;
}
.top-header-bar .gap-4 {
	gap: 1.5rem !important;
}
/* Gradient Brand Title */
.brand-gradient-title {
	background: linear-gradient(90deg, rgb(1,61,148) 0%, rgb(17,135,96) 33%, rgb(254,183,54) 66%, rgb(195,43,16) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	color: transparent;
	font-family: 'Segoe UI', 'Poppins', Arial, sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
	line-height: 1.1;
	display: inline-block;
}
/* Responsive Tweaks for Home Page */
@media (max-width: 991.98px) {
	.hero-section-video .row {
		flex-direction: column-reverse !important;
		min-height: 320px !important;
	}
	.hero-section-video .col-lg-7, .hero-section-video .col-lg-5 {
		max-width: 100%;
		flex: 0 0 100%;
		margin-bottom: 1.5rem;
	}
	.hero-section-video .carousel {
		margin-bottom: 1.5rem;
	}
	.hero-section-video h1 {
		font-size: 2rem;
	}
	.hero-section-video p {
		font-size: 1.05rem;
	}
	.why-choose-us-section .row > div,
	.services-section .row > div,
	.team-section .row > div,
	.awards-section .row > div,
	.testimonials-section .row > div {
		margin-bottom: 1.5rem;
	}
	.footer-modern .row > div {
		margin-bottom: 2rem;
	}
	.faq-section .accordion-button {
		font-size: 1rem;
	}
}

@media (max-width: 600px) {
	.hero-section-video {
		min-height: 220px;
	}
	.hero-section-video .hero-bg-video {
		min-height: 220px;
	}
	.hero-section-video h1 {
		font-size: 1.2rem;
	}
	.hero-section-video p {
		font-size: 0.98rem;
	}
	.main-nav-menu .nav-link {
		font-size: 1rem;
		padding: 0.5rem 1rem;
	}
	.brand-multicolor-title span {
		font-size: 0.98rem;
	}
	.footer-modern {
		padding: 20px 0 0 0;
	}
}
/* Multicolor Brand Title */
.brand-multicolor-title {
	font-family: 'Segoe UI', 'Poppins', Arial, sans-serif;
	font-weight: 800;
	letter-spacing: 1px;
	line-height: 1.1;
	display: inline-block;
}
.brand-multicolor-title span {
	font-family: inherit;
	font-weight: 800;
	font-size: 1.5rem;
	letter-spacing: 1px;
}

/* Main Nav Menu */
.main-nav-menu {
	gap: 1.1rem;
}
.main-nav-menu .nav-link {
	color: #111;
	font-family: 'Poppins', 'Segoe UI', Arial, sans-serif;
	font-weight: 600;
	font-size: 1.08rem;
	letter-spacing: 0.5px;
	padding: 0.35rem 0.7rem;
	border-radius: 0.6rem;
	transition: background 0.2s, color 0.2s;
}
.main-nav-menu .nav-link.active, .main-nav-menu .nav-link:hover {
	background: var(--brand-yellow);
	color: var(--brand-blue);
}

@media (max-width: 991.98px) {
	.main-nav-menu {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 0.5rem;
	}
	.main-nav-menu .nav-link {
		width: 100%;
		text-align: left;
		padding-left: 1.5rem;
		font-size: 1.1rem;
	}
	.brand-multicolor-title span {
		font-size: 1.1rem;
	}
}
/* Hero Section Video */
.hero-section-video {
	position: relative;
	min-height: 520px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero-section-video .hero-bg-video {
	object-fit: cover;
	width: 100vw;
	height: 100%;
	min-height: 520px;
	filter: brightness(0.7) contrast(1.1);
}
.hero-section-video .hero-overlay {
	background: rgba(1,61,148,0.7);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}
.hero-section-video .container {
	position: relative;
	z-index: 3;
}
.hero-section-video h1, .hero-section-video p {
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.hero-section-video .btn-warning {
	color: var(--brand-blue);
	background: var(--brand-yellow);
	border: none;
	font-weight: 600;
}
.hero-section-video .btn-warning:hover {
	background: var(--brand-red);
	color: #fff;
}
@media (max-width: 767.98px) {
	.hero-section-video {
		min-height: 320px;
	}
	.hero-section-video .hero-bg-video {
		min-height: 320px;
	}
	.hero-section-video h1 {
		font-size: 2rem;
	}
}
/* Enquiry Form Section */
#enquiry-form .card {
	border-radius: 1.5rem;
	border: none;
	background: #fff;
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	padding: 2rem 1.5rem;
}
#enquiry-form .form-label {
	color: var(--brand-blue);
	font-weight: 500;
}
#enquiry-form .btn-success {
	background: var(--brand-green);
	border: none;
	font-weight: 600;
	letter-spacing: 1px;
}
#enquiry-form .btn-success:hover {
	background: var(--brand-blue);
	color: #fff;
}

/* Contact CTA Section Banner */
.contact-cta-section {
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 340px;
}
.contact-cta-section .container {
	position: relative;
	z-index: 2;
}
.contact-cta-section h2, .contact-cta-section p {
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.contact-cta-section .btn-warning {
	color: var(--brand-blue);
	background: var(--brand-yellow);
	border: none;
	font-weight: 600;
}
.contact-cta-section .btn-warning:hover {
	background: var(--brand-red);
	color: #fff;
}
.contact-cta-section .btn-outline-light {
	border-color: #fff;
	color: #fff;
}
.contact-cta-section .btn-outline-light:hover {
	background: #fff;
	color: var(--brand-blue);
}


/* Brand Colors */
:root {
	--brand-green: rgb(17, 135, 96);
	--brand-yellow: rgb(254, 183, 54);
	--brand-red: rgb(195, 43, 16);
	--brand-blue: rgb(1, 61, 148);
}

body {
	font-family: 'Segoe UI', Arial, sans-serif;
	background: #f7f7f7;
	color: #222;
}

/* Hero Section */
.hero-section {
	background: linear-gradient(90deg, var(--brand-blue) 60%, var(--brand-green) 100%);
	min-height: 420px;
	display: flex;
	align-items: center;
	position: relative;
}
.hero-section .btn-warning {
	color: var(--brand-blue);
	background: var(--brand-yellow);
	border: none;
	font-weight: 600;
}
.hero-section .btn-warning:hover {
	background: var(--brand-red);
	color: #fff;
}

/* About Section */
.about-section img {
	max-width: 420px;
	width: 100%;
	border-radius: 12px;
	box-shadow: 0 2px 16px rgba(1,61,148,0.08);
}

/* Services Section */
.services-section .card {
	transition: transform 0.2s, box-shadow 0.2s;
	border-top: 4px solid var(--brand-green);
}
.services-section .card:hover {
	transform: translateY(-8px) scale(1.03);
	box-shadow: 0 8px 32px rgba(1,61,148,0.12);
	border-top: 4px solid var(--brand-yellow);
}
.services-section .card-img-top {
	height: 220px;
	object-fit: cover;
	border-radius: 12px 12px 0 0;
}
.services-section .btn-primary {
	background: var(--brand-blue);
	border: none;
}
.services-section .btn-primary:hover {
	background: var(--brand-green);
}
.services-section .btn-outline-primary {
	color: var(--brand-blue);
	border-color: var(--brand-blue);
}
.services-section .btn-outline-primary:hover {
	background: var(--brand-blue);
	color: #fff;
}


/* Testimonials Section - Banner, Overlay, Slider */
.testimonials-section {
	position: relative;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 480px;
}
.testimonials-section .container {
	position: relative;
	z-index: 2;
}
.testimonials-section h2 {
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.testimonial-card {
	border-radius: 1.5rem;
	border: none;
	background: rgba(255,255,255,0.85);
	box-shadow: 0 4px 32px rgba(1,61,148,0.10);
	transition: transform 0.2s, box-shadow 0.2s;
	backdrop-filter: blur(2px);
}
.testimonial-card:hover {
	transform: translateY(-6px) scale(1.03);
	box-shadow: 0 8px 40px rgba(1,61,148,0.16);
}
.testimonial-card img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	margin-bottom: 0.5rem;
	box-shadow: 0 2px 8px rgba(1,61,148,0.10);
}
.testimonial-card h6 {
	color: var(--brand-blue);
	margin-top: 0.5rem;
}
.testimonial-card .text-warning {
	letter-spacing: 2px;
}
.testimonials-section .carousel-control-prev,
.testimonials-section .carousel-control-next {
	width: 48px;
	height: 48px;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(1,61,148,0.7);
	border-radius: 50%;
	opacity: 0.85;
	transition: background 0.2s, opacity 0.2s;
}
.testimonials-section .carousel-control-prev:hover,
.testimonials-section .carousel-control-next:hover {
	background: var(--brand-blue);
	opacity: 1;
}
.testimonials-section .carousel-control-prev-icon,
.testimonials-section .carousel-control-next-icon {
	filter: invert(1) drop-shadow(0 2px 4px rgba(0,0,0,0.18));
}
.testimonials-section .carousel-indicators [data-bs-target] {
	background-color: var(--brand-yellow);
}
.testimonials-section .carousel-inner {
	min-height: 320px;
}
@media (max-width: 767.98px) {
  .testimonial-card {
	padding: 1.5rem 1rem;
  }
  .testimonials-section {
	min-height: 340px;
  }
}

/* Contact Section */
.contact-section form {
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 2px 16px rgba(17,135,96,0.08);
}
.contact-section .form-label {
	font-weight: 500;
	color: var(--brand-blue);
}
.contact-section .btn-primary {
	background: var(--brand-green);
	border: none;
}
.contact-section .btn-primary:hover {
	background: var(--brand-red);
}


/* Modern Footer */
.footer-modern {
	background: linear-gradient(120deg, var(--brand-blue) 70%, var(--brand-green) 100%);
	color: #fff;
	padding: 48px 0 0 0;
	margin-top: 40px;
	border-top: 0;
}
.footer-modern .footer-link {
	color: #fff;
	text-decoration: none;
	transition: color 0.2s;
}
.footer-modern .footer-link:hover {
	color: var(--brand-yellow);
	text-decoration: underline;
}
.footer-modern ul {
	padding-left: 0;
	list-style: none;
}
.footer-modern .text-warning {
	color: var(--brand-yellow)!important;
}
.footer-modern .btn-outline-light {
	border-color: #fff;
	color: #fff;
	transition: background 0.2s, color 0.2s;
}
.footer-modern .btn-outline-light:hover {
	background: var(--brand-yellow);
	color: var(--brand-blue);
	border-color: var(--brand-yellow);
}
.footer-modern .footer-copyright {
	background: rgba(0,0,0,0.12);
	color: #fff;
	border-top: 0;
}
@media (max-width: 767.98px) {
	.footer-modern {
		padding: 32px 0 0 0;
	}
	.footer-modern .row > div {
		margin-bottom: 2rem;
	}
}

/* Top Header Bar */
.bg-dark {
	background: var(--brand-green)!important;
	color: #fff!important;
}
.text-warning {
	color: var(--brand-yellow)!important;
}

/* Responsive Tweaks */
@media (max-width: 991px) {
	.hero-section {
		min-height: 320px;
		padding: 40px 0 0 0;
	}
	.about-section img {
		max-width: 100%;
	}
	.services-section .card-img-top {
		height: 180px;
	}
}

@media (max-width: 600px) {
	.hero-section {
		min-height: 220px;
		padding: 24px 0 0 0;
	}
	.about-section, .services-section, .testimonials-section, .contact-section {
		padding: 24px 0;
	}
}
