*{
	margin: 0;
	padding: 0;
}
:root {
    --background: 0 0% 100%;
    --foreground: 215 25% 27%;
    --card: 0 0% 100%;
    --card-foreground: 215 25% 27%;
    --popover: 0 0% 100%;
    --popover-foreground: 215 25% 27%;
    --primary: 214 85% 40%;
    --primary-foreground: 0 0% 100%;
    --primary-hover: 214 85% 35%;
    --secondary: 214 25% 96%;
    --secondary-foreground: 215 25% 27%;
    --muted: 214 20% 96%;
    --muted-foreground: 215 16% 47%;
    --accent: 0 72% 51%;
    --accent-foreground: 0 0% 100%;
    --accent-hover: 0 72% 45%;
    --success: 142 71% 45%;
    --success-foreground: 0 0% 100%;
    --destructive: 0 84% 60%;
    --destructive-foreground: 0 0% 100%;
    --border: 214 20% 90%;
    --input: 214 20% 90%;
    --ring: 214 85% 40%;
    --radius: .5rem;
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1);
    --transition-base: all .2s ease-in-out;
    --transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);
    --sidebar-background: 0 0% 98%;
    --sidebar-foreground: 240 5.3% 26.1%;
    --sidebar-primary: 240 5.9% 10%;
    --sidebar-primary-foreground: 0 0% 98%;
    --sidebar-accent: 240 4.8% 95.9%;
    --sidebar-accent-foreground: 240 5.9% 10%;
    --sidebar-border: 220 13% 91%;
    --sidebar-ring: 217.2 91.2% 59.8%;
     --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);
}
body{
	margin: 0;
	padding: 0;	
	font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
}
h1,h2,h3,h4,h5,h6, p{
	margin: 0;
	padding: 0;
}
ul li, ul, a{
	margin: 0;
	padding: 0;
	text-decoration: none;
	list-style: none;
}
a:hover{
	text-decoration: none;
    color: #fff;
}
img{
	margin: 0;
	padding: 0;
	width: 100%;
}
button:focus, .btn:focus, .form-control:focus{
	outline: none;
	box-shadow: 0 0 0 0.0rem rgba(0,123,255,.25);
}
.navbar-toggler:focus{
    box-shadow: none !important;
}

.def h3 {
    color: hsl(215 25% 25% / 1);
    margin-bottom: 20px;
    font-weight: 700;
}
.def h4 {
    color: hsl(215 25% 25% / 1);
    font-weight: 600;
    margin-bottom: 20px;
    font-size: 22px;
}
.def p {
    font-size: 1.125rem;
    line-height: 1.75rem;
    margin-bottom: 15px;
    color: hsl(214.74deg 15.97% 46.67%);
}
.def li {
    list-style: disc !important;
    margin-bottom: 10px !important;
    margin-left: 23px !important;
    font-size: 1.125rem;
}
.def ul {
    margin-bottom: 15px !important;
}
.container{
	max-width: 80rem;
	        padding-left: 2rem;
        padding-right: 2rem;
}

header nav{
	background-color: #fffffff2;
}
header .navbar-brand img{
	height: 6.5rem;
}
header ul.navbar-nav li a{
    color: hsl(var(--foreground));
    margin-left: 4px;
    padding-right: 1rem !important;
    padding-left: 1rem !important;
    padding-top: .5rem !important;
    padding-bottom: .5rem !important;
    font-weight: 600 !important;
    border-radius: var(--bs-border-radius) !important;
    font-size: .875rem;
    line-height: 1.25rem;
        border: 0 !important;
}
header ul.navbar-nav li a:hover{
	background-color: #f2f4f7;
}
.text-sm {
    font-size: .875rem;
    line-height: 1.25rem;
}
header ul.navbar-nav li a:hover{
	background-color: #f2f4f7;
}
header ul.navbar-nav li a.active, header ul.navbar-nav li.current-menu-item a{
	background-color: #0f5abd;
	color: #fff;
}
.header-button a{
	height: 2.75rem;
}
.header-button a:hover{
	background-color: hsl(var(--accent-hover));
}
.bg-accent {
    background-color: hsl(var(--accent));
}
.item-list ul li a:hover{
	color: hsl(var(--primary)) !important;
}
.social-list ul li a:hover{
	color: hsl(var(--primary)) !important;
}

/* NEW: Give height to each slider item */
.banner-slide {
    height: 600px !important;
    position: relative;
}

/* NEW: Overlay for each slide */
.banner-slide:after {
    position: absolute;
    content: '';
    left: 0;
    top: 0;
    background-color: #00000080;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.banner-sec .slick-dots {
    position: absolute;
    bottom: 10px;
}
.banner-content{
	position: relative;
	z-index: 9;
}
.banner-sec .slick-dotted.slick-slider {
    margin-bottom: 0px !important;
}
.banner-slider .slick-dots li button:before {
    font-size: 16px;       
    color: #ffffff !important;
    opacity: 0.4;    
}

.banner-slider .slick-dots li button:hover:before {
    opacity: 0.8;
}

.banner-slider .slick-dots li.slick-active button:before {
    opacity: 1;
    color: #ffffff !important; 
}
.max-w-3xl {
    max-width: 48rem;
}
.banner-button a{
	line-height: 1.75rem;
}
.banner-button a:hover{
	background-color: hsl(var(--accent-hover));
}
.text-foreground {
    color: hsl(var(--foreground));
}
.banner-button a.border-2{
	border: 2px solid hsl(var(--input));;
}
.banner-button a.border-2:hover{
	background-color: hsl(var(--accent)) !important;
	color: hsl(var(--accent-foreground));
}
.animate-scroll {
    animation: scroll 30s linear infinite;
}
@keyframes scroll {
	0% {
	    transform: translate(0);
	}
	100% {
	    transform: translate(-50%);
	}
}


.info-sec{
	background-color: hsl(var(--secondary) / .3);
}
.text-muted-foreground {
    color: hsl(var(--muted-foreground));
}
.icon-box{
	width: 4rem;
	height: 4rem;
}
.icon-box i{
	font-size: 1.8rem;	
    color: hsl(var(--primary));
}
.py-24 {
    padding-top: 6rem;
    padding-bottom: 6rem;
}
.offer-sec{
	background-image: url('../images/banner.jpg');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;	
}
.offer-sec:after{
	position: absolute;
	content: '';
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
/*	background-color: hsl(214 85% 35% / .9);*/
	background: linear-gradient(90deg,rgba(16, 96, 204, 0.9) 0%, rgba(13, 77, 166, 0.9) 100%);
}
.info-content{
	z-index: 9;
}
.max-w-3xl {
    max-width: 48rem;
}
.info-content p{
	color: hsl(var(--primary-foreground) / .9);
}
.info-btn-box .btn-1, .info-btn-box .btn-2{
	font-size: 1.125rem;
    line-height: 1.75rem;
        padding-top: 1.5rem;
    padding-bottom: 1.5rem;
        height: 2.75rem;
}
.info-btn-box .btn-1:hover{
	background-color: hsl(var(--secondary) / .8) !important;
	color: hsl(var(--foreground));
}

.py-6{
	padding-top: 5rem;
  padding-bottom: 5rem;
}
.mb-6{
	margin-bottom: 4rem;
}
.text-muted-foreground {
    color: hsl(var(--muted-foreground));
}

.service-img{
	height: 14rem;
}
.service-img img{
	object-fit: cover;
	animation-duration: .5s;
	transform: scale(1.0);
	transition-duration: .5s;
}
.service-card:hover .service-img img{
	transform: scale(1.1);
}
.service-card{
	transition: all 300ms;
}
.service-card:hover{
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}
.service-img:after{
	position: absolute;
	content: '';
	width: 100%;
	height: 100%;
	left: 0;
	bottom: 0;
	background: linear-gradient(0deg,rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 100%);
}
.service-content{
	background-color: hsl(var(--card));
}
.text-primary {
    color: hsl(var(--primary)) !important;
}
.service-icon-box{
	z-index: 9;
	left: 1rem;
	bottom: 1rem;
	width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.service-icon-box svg{
	width: 3rem;
    height: 3rem;
}
.line-clamp-3{
	overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}
a.service-btn i{
	transition: all 600ms;
}
a.service-btn:hover i{
	margin-left: 0.5rem;
}
a.service-btn:hover{
	color: hsl(var(--accent)) !important;
}


.project-box img{
	height: 290px;
	object-fit: cover;
	transform: scale(1.0);
	transition: all 300ms;
}
.project-box:hover img{
	transform: scale(1.1);
}



.testimonial-sec{
	background-color: hsl(var(--secondary) / .3);
}
.testimonial-content svg{
	width: 2.5rem;
    height: 2.5rem;
}
.testimonial-slider .slick-list {
	padding: 2rem 0px;
}
.testimonial-slider .slick-track{
	display: flex;
    justify-content: center;
}
.testimonial-slider .testimonial-content {
  margin-right: 2rem;
}
.testimonial-slider .slick-slide:last-child {
  margin-right: 0;
}

.page-form{
background-color: hsl(var(--card));
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    border-radius: var(--radius);
    padding: 2rem;
}
input.form-control{
	padding-left: 2.5rem;
}
.form-control{
	    font-size: 0.875rem;
    line-height: 1.25rem;
    padding-left: 0.5rem;
    padding-top: 0.7rem;
    padding-bottom: 0.7rem;
    border-color: hsl(var(--input));
}
.page-form p{
	position: relative;
}
.page-form i{
	color: hsl(var(--muted-foreground));
    position: absolute;
    left: 10px;
    top: 45px;
    z-index: 9;
}
.form-btn{
	background-color: hsl(var(--primary));
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
    color: hsl(var(--primary-foreground));
    --tw-ring-offset-color: hsl(var(--background));
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.15s;
    border-radius: calc(var(--radius) - 2px);
    white-space: nowrap;
    gap: 0.5rem;
    width: 100%;
    height: 2.75rem;
    display: inline-flex;
    border: 0;
}
.wpcf7-spinner{
	position: absolute;
}
textarea.form-control{
	height: 120px;
	resize: none;
}
.page-form select{
	appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%236c757d' viewBox='0 0 320 512'%3E%3Cpath d='M143 352l-136-136c-9.4-9.4-9.4-24.6 0-34s24.6-9.4 34 0L160 289.9l119-107.9c9.4-9.4 24.6-9.4 34 0s9.4 24.6 0 34L177 352c-9.4 9.4-24.6 9.4-34 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 0.55rem;
}
.cta-sec{
	background: linear-gradient(90deg, rgba(16, 96, 204, 1) 0%, rgba(13, 77, 166, 1) 100%);
}

footer{
	background-color: hsl(var(--secondary));
	    

}
.footer-logo img{
	height: 4rem;
    width: auto;
}
.w-4 {
    width: 1rem;
}
.h-4 {
    height: 1rem;
}
.footer-wrap ul li{
	font-size: 0.75rem;
    line-height: 1rem;
    gap: 0.5rem;
    color: hsl(var(--muted-foreground));
        margin-right: 0.75rem;
    margin-bottom: 0.75rem;
}
.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}
.announce-bar {
    background-color: #0f5abd !important;
}
.footer-widget li.menu-item a,.info a {
    color: #6374a6;
    margin-bottom: 8px;
    display: block;
}
.info a,.address p,.bottom p {
    color: #6374a6;
    display: block;
}
.footer-widget li.menu-item a:hover,.info a:hover,.info .social i:hover {
    color: #0f5abd;
}
.tel,.address,.email {
    display: flex;
    column-gap: 10px;
}
.info i {
    position: relative;
    top: 6px;
    color: #0f5abd;
}
.bottom {
    padding-top: 28px;
    border-top: 1px solid #dfe4eb;
    margin-top: 40px;
    text-align: center;
}
.tel,.email {
    margin-bottom: 8px;
}
.social {
    display: flex;
    align-content: center;
    align-items: center;
    column-gap: 10px;
}
.info .social i{
   color: #6374a6 !important;
    display: block;
    font-size:18px;
    top:5px;
}
.dropdown-menu a.nav-link {
    margin-left: 0px;
    font-weight: 400 !important;
}
ul.dropdown-menu {
    padding-left: 5px;
    padding-right: 5px;
    padding-top: 5px;
    padding-bottom: 5px;
}
header ul.navbar-nav .dropdown-menu li a:hover {
    background-color: #db2727;
    color: #fff;
}

.navbar-nav .dropdown-toggle::after {
    display: inline-block;
    font-family: "Font Awesome 7 Free";
    font-weight: 900;
    content: "\f107";
    margin-left: 8px;
    border: none;
    vertical-align: middle;
    font-size: 14px !important;
    position: relative;
    top: -1px;
}

.navbar-nav .dropdown.show > .dropdown-toggle::after {
    transform: rotate(180deg);
    transition: transform 0.2s ease;
}
.banner-button {
    display: flex;
    justify-content: center;
    column-gap: 20px;
}
.inner-hero {
    height: 400px;
    position: relative;
}
.inner-hero:before {
    content: "";
    background-color: #000000b3;
    position: absolute !important;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.inner-content {
    position: relative;
    z-index: 2;
}
.display-3 {
    font-size: 3.75rem;
    line-height: 1;
}
.text-m {
    font-size: 1.25rem;
    line-height: 1.75rem;
}
.text-m.text-white {
    color: #ffffffe6 !important;
}
.fs-8 {
    max-width: 850px;
    font-size: 1.125rem;
    line-height: 1.625;
}
section.apart {
    background: #fcfcfc;
}
.display-7 {
    font-size: 2.25rem;
    line-height: 2.5rem;
}
.speciality-box {
    padding: 2rem;
    border: 1px solid #dfe4eb;
    border-radius: 10px;
    background: #fff;
    transition: all 300ms;
}

.speciality-box:hover{
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}
section.apart.py-6 {
    padding-bottom: 3rem;
}
.py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
}
.char-box {
    background: #fcfcfc;
    padding: 1rem;
    text-align: center;
    border-radius: 10px;
}
.get {
    max-width: 840px;
    margin: auto;
}
.testimonial-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}
.testimonial-grid .testimonial-content {
    border: 1px solid #dfe4eb;
}
.italic {
    font-style: italic;
}
.text-light-blue {
    color: #b7cceb;
}
.text-secondary-red {
    color: #db2727;
    margin-bottom: 14px !important;
}
.testimonial-grid .testimonial-content {
    transition: all 300ms;
   padding: 2rem !important;
}
.contact-info .info-box,.hover-sh .project-box{
   transition: all 300ms;
}
.testimonial-grid .testimonial-content:hover,.contact-info .info-box:hover,.hover-sh .project-box:hover{
	box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}
.light-bg{
   background :#fcfcfc;
}
.contact-info .info-box p.text-muted-foreground {
    min-height: 48px;
}
.contact-info .info-box a p:hover {
    color: #0f5abd;
}
.inner-service .speciality-box p {
    min-height: 46px;
}
.p-2 {
    padding: 3rem !important;
}
ul li{
   color: hsl(var(--muted-foreground));
}
.list-disc {
    list-style-type: disc;
    margin-top: 1.3rem;
}
.list-inside {
    list-style-position: inside;
}
.list-disc li {
    color: hsl(var(--muted-foreground));
    margin-bottom: 0.6rem;
    list-style: disc;
    margin-left: 20px;
}
.g-3, .gy-3 {
    --bs-gutter-y: 1.5rem;
}
.g-3, .gx-3 {
    --bs-gutter-x: 1.5rem;
}
.success {
    background: #e4f5eb;
    border: 1px solid #bcebce;
}
.text-success {
    color: #21c45d !important;
    font-weight: 600;
    font-size: 16px;
}
.mt-8 {
    margin-top: 80px;
}
.bg-primary-10 {
    background: #e4eaf5;
    border: 1px solid #b9cdeb;
}
.offer-info {
    border-radius: 10px;
}
.page-form.contact-form {
    box-shadow: none;
    border: 1px solid #dfe4eb;
    padding: 3rem;
}
section.form-sec {
    padding-top: 1rem;
}
.contact-form .form-btn {
    background-color: #db2727;
}
.contact-form .form-btn:hover {
    background-color: #c52020;
}
.text-secondary-red i.fa-solid.fa-star {
    color: #db2727;
}
.text-primary i.fa-solid.fa-star {
    color: hsl(var(--primary)) !important;
}
.other-wrapper input.form-control {
    padding-left: 0.5rem;
}
section.offer.def {
    padding-top: 50px;
    padding-bottom: 50px;
}
.offcanvas-header .btn-close {
    text-align: right;
    margin-left: auto;
}
.map-box {
    padding-bottom: 20px;
}
.row.oth {
    margin-top: 45px;
}
section.service-areas {
    padding-top: 1rem;
}
#store-locations-container {
  display: flex;
  gap: 25px;
  margin-top: 40px;
}

/* Left Panel */
#location-list {
  width: 35%;
}

.location-item {
  border: 1px solid #ddd;
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
  cursor: pointer;
}

.location-header {
  padding: 15px;
  background: #f5f5f5;
  font-weight: bold;
  color: #333;
  transition: 0.3s;
}

.location-item.active .location-header {
  background: #dc2828;
  color: #fff;
}

.location-content {
  display: none;
  padding: 15px;
  background: white;
  border-top: 1px solid #ddd;
}

.location-item.active .location-content {
  display: block;
}

/* Right Panel - Map */
#location-map {
  width: 100%;
  height: 500px;
  border: 0;
  border-radius: 15px;
  
}
#location-list {
    width: 35%;
    height: 500px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #bfbfbf #f0f0f0;
    padding-right: 15px;
}

/* Chrome, Edge, Safari */
#location-list::-webkit-scrollbar {
    width: 6px;
}

#location-list::-webkit-scrollbar-track {
    background: #f0f0f0;
}




@media (min-width:768px) and (max-width:1024px){
    ul#menu-primary-menu {
    display: block;
    align-items: flex-start !important;
    margin-bottom: 20px;
}
header ul.navbar-nav li a {
    color: #fff;
}
.navbar-nav .dropdown-menu {
    background: #ffffff1a;
    position: static;
}
.header-button {
    margin-left: 15px;
}
.footer-widget {
    margin-top: 20px;
}
.display-3 {
    font-size: 2.75rem;
}
.testimonial-grid {
    grid-template-columns: repeat(2, 1fr);
}
.info-box {
    margin-bottom: 20px;
}
}

@media (max-width:767px){
    ul#menu-primary-menu {
    display: block;
    align-items: flex-start !important;
    margin-bottom: 20px;
}
header ul.navbar-nav li a {
    color: #fff;
}
.navbar-nav .dropdown-menu {
    background: #ffffff1a;
    position: static;
}
.header-button {
    margin-left: 15px;
}
.footer-widget {
    margin-top: 20px;
}
.email-part {
    display: none;
}
section.project-sec {
    padding-top: 0px;
}
.project-sec .g-4,.project-sec .gy-4 {
    --bs-gutter-y: 1rem;
}
.project-sec .g-4,.project-sec .gx-4 {
    --bs-gutter-x: 0.5rem;
}
.project-box img {
    height: 200px;
}
.display-3 {
    font-size: 1.75rem;
    line-height: 1.3;
}
.display-7 {
    font-size: 1.5rem;
    line-height: 2rem;
}
.container {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}
.speciality-box {
    padding: 1.5rem;
}
.p-2 {
    padding: 1.5rem !important;
}
.testimonial-grid {
    grid-template-columns: repeat(1, 1fr);
}
.testimonial-grid .testimonial-content {
    padding: 1.5rem !important;
}
.info-box {
    margin-bottom: 20px;
}
.page-form.contact-form {
    padding: 1.5rem;
}
.banner-button {
    column-gap: 10px;
}
footer.py-5 {
    padding-bottom: 1.5rem !important;
}
.bottom {
    padding-top: 20px;
}
#store-locations-container {
        flex-direction: column;
        gap: 15px;
    }

    /* Left Panel */
    #location-list {
        width: 100%;
        height: auto;
        max-height: none;
        overflow-y: visible; /* remove scroll on mobile */
        padding-right: 0;
    }

    .location-item {
        margin-bottom: 10px;
    }

    .location-header {
        padding: 12px;
        font-size: 15px;
    }

    .location-content {
        padding: 12px;
        font-size: 14px;
    }

    /* Right Panel - Map */
    #location-map {
        width: 100%;
        height: 350px; /* reduced height for mobile */
        border-radius: 10px;
    }

    /* Hide Scrollbar in Mobile for cleaner UI */
    #location-list::-webkit-scrollbar {
        display: none;
    }
    #location-list {
        -ms-overflow-style: none; /* IE/Edge */
        scrollbar-width: none; /* Firefox */
    }
    .map-frame {
    width: 100% !important;
}
#location-map {
        width: 100%;
        height: 300px;
        margin-top: 10px;
        border-radius: 10px;
    }
}