* {
	font-size:17px;
	line-height:28px;
	font-family:'Montserrat', sans-serif;
	font-weight:600}

html {
	color:#1b1c21; 
	background:#111112;
}

h1,h2,h3,h4,h5 {
	color:#111112; 
	font-family: 'Montserrat'; 
	font-weight:700}

.coloured {
	color:#5d5d5d !important;
}
.coloured2 {
	color:#3f9aed !important;
}

a {
	color:#3f9aed;
}
a:hover {
	color:#135edf;
}

strong, b {
	font-weight:700;
}

.header-menu ul li a {
	font-family: 'Montserrat';
}

.button {
	border:0px solid #001D3E;
	border-radius:100px;
	font-size:13px;
	font-weight:700;
	font-family: Montserrat;
	background: #001D3E; /* Old browsers */
	background: -moz-linear-gradient(left, #001D3E 0%, #001D3E 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(left, #001D3E 0%,#001D3E 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to right, #001D3E 0%,#001D3E 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#001D3E', endColorstr='#001D3E',GradientType=1 ); /* IE6-9 */
	color:#ffffff; 
	text-transform:uppercase; 
	letter-spacing:2px;
}
.button:hover {
	-webkit-box-shadow:0 0px 13px -4px rgba(44,125,232,.7),0 5px 12px -12px rgba(44,125,232,.5);
	box-shadow:0 0px 13px -4px rgba(44,125,232,.7),0 5px 12px -12px rgba(44,125,232,.5);
	color:#ffffff !important;
	border-color:#001D3E !important;
}

.button-op {
	border-radius:100px;
	font-weight:700;
	font-family: 'Montserrat';
	border: 2px solid #1b1c21;
	font-size:13px; 
	color:#1b1c21; 
	text-transform:uppercase; 
	letter-spacing:2px;
}
.button-op:hover {
	background:#1b1c21 !important;
	border-color:#1b1c21 !important;
	color:#ffffff !important;
}

.button-op-c {
	border-radius:100px;
	font-weight:700;
	font-family: 'Montserrat';
	border: 2px solid #001D3E; 
	font-size:13px; 
	color:#001D3E !important; 
	text-transform:uppercase; 
	letter-spacing:2px;
}
.button-op-c:hover {
	border-color:#001D3E !important;
	background-color:#001D3E !important;
	color:#ffffff !important;
}

.dark-section .button-op:hover, .coloured-section .button-op:hover {
	color:#001D3E !important;
	border-color:#ffffff !important;
}
.coloured-section .button-op-c:hover {
	color:#ffffff !important;
	background-color:#1b1c21 !important;
	border-color:#1b1c21 !important;
}

.page-container {
	background:#f7f8fc;
}
.header-info .header-info-item i {
	color:#5d5d5d;	
}

.white-section {
	background:#ffffff;
}
.grey-section {
	background:#f7f8fc;
}
.dark-section {
	background-color:#1b1c21;
}
.coloured-section {
	background: #5d5d5d; /* Old browsers */
	background: -moz-linear-gradient(left, #5d5d5d 0%, #5d5d5d 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(left, #5d5d5d 0%,#5d5d5d 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to right, #5d5d5d 0%,#5d5d5d 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#5d5d5d', endColorstr='#5d5d5d',GradientType=1 ); /* IE6-9 */
}

.module h1, .module h2, .module h3, .module h4, .module h5 {
	color:#111112 !important;
}
.module, .module strong {
	color:#1b1c21 !important;
}

.contact-item i {
	color:#5d5d5d;
}

.footer-section {
	background:#1b1c21;
	color:#768596;
}
.footer-social a, .footer-section ul li, .footer-section ul li a {
	color:#768596;
}

.service-box-2-title {
	font-family: 'Montserrat'; 
	font-weight:700;
}/* Hero Section */

.hero-short {
  height: 70vh; /* Shrink from full screen to 70% of viewport */
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 20px;
  position: relative;
  overflow: hidden;
}

@media (max-width: 768px) {
  .hero-short {
    height: 60vh; /* Slightly shorter on smaller screens */
  }
}



@media (max-width: 768px) {
    .hero-fullscreen h1 {
        font-size: 2.5rem;
    }

    .hero-fullscreen h3 {
        font-size: 1.5rem;
    }
}

@media (max-width: 480px) {
    .hero-fullscreen h1 {
        font-size: 2rem;
    }

    .hero-fullscreen h3 {
        font-size: 1.2rem;
    }
}


/* Services - Home Page */

.services-scroll-wrapper::-webkit-scrollbar {
height: 8px;
}

.services-scroll-wrapper::-webkit-scrollbar-thumb {
background: rgba(255,255,255,0.3);
border-radius: 4px;
}

.services-scroll-wrapper::-webkit-scrollbar-track {
background: transparent;
}

/* Brands */
#section_brands {
padding-top: 50px;
padding-bottom: 50px;
background-color: #f8f9fa;
}

@media (min-width: 850px) {
#section_brands {
padding-top: 100px;
padding-bottom: 100px;
}
}

.box-shadow-2 {
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.box-shadow-2:hover {
transform: translateY(-4px);
box-shadow: 0 10px 22px rgba(0, 0, 0, 0.15);
}

.centered-card {
margin: 0 auto;
}

.no-break {
white-space: nowrap;
display: inline-block;
}

@media (max-width: 767px) {
.no-break {
font-size: 28px;
}
}

@media (max-width: 767px) {
.fullwidth-third-content.pm-bg-image {
margin-left: 0 !important;
left: 0 !important;
margin: 0 auto !important;
display: block !important;
}
}

@media (min-width: 1025px) {
.pm-bg-image.desktop-fix {
min-height: 700px !important;
background-size: cover !important;
background-position: center !important;
}
}

/* Carousel */

.brand-scroll-wrapper {
overflow: hidden;
padding: 60px 0;
position: relative;
}

.brand-scroll-track {
display: inline-flex;
animation: scroll-logos 30s linear infinite;
width: max-content; 
}

.brand-scroll-content {
display: flex;
gap: 60px;
align-items: center;
padding: 20px 0;
}

.brand-scroll-content a {
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
width: 300px;
height: 150px;
}

.brand-scroll-content a img {
max-width: 100%;
max-height: 100%;
object-fit: contain;
filter: grayscale(0);
transition: transform 0.3s ease;
}

.brand-scroll-content a img:hover {
transform: scale(1.05);
}

@keyframes scroll-logos {
0%   { transform: translateX(0); }
100% { transform: translateX(-50%); }
}

@media (max-width: 767px) {
.parallax-bg {
background-attachment: scroll !important;
background-size: cover !important;
background-position: center center !important;
min-height: auto !important;
padding: 80px 0 !important;
}
}

.brand-scroll-track:hover {
animation-play-state: paused;
}

.home-image .container {
padding: 0 16px !important;
}

.icon-service-box,
.pm-content {
display: flex !important;
flex-direction: column !important;
margin: 0 auto !important;
max-width: 95% !important;
}

.pm-content p.textdrop {
display: none !important;
}

.reviewtext4.promin {
font-size: clamp(1.5rem, 6vw, 2.2rem) !important;
line-height: 1.2 !important;
white-space: normal !important;
word-break: break-word !important;
margin: 0.5em 0 !important;
align-items: left;
justify-content: left;
}
.reviewtext4.promin span {
display: inline-block !important;
margin: 0 0.25ch !important;
}
}

 @media (max-width: 640px) {
.fullwidth-third-content.pm-bg-image {
margin-left: 0 !important;
left: 0 !important;
}
}

.coloured-section {
background-color: #000 !important;
}

.reviewtext4  {
font-size: clamp(1.5rem, 5vw, 3rem); 
line-height: clamp(2rem, 5vw, 3rem);
}

.service-box-content {
border-radius: 40px;
}

.grid-block {
border-radius: 20px;
}

.header-logo {
max-width: 400px;
}

.header-style-1 .header-menu {
float: none; 
position: absolute;
left: 0; 
width: 100%; 
bottom: -60px;
background: #eee; 
padding: 0px 10px; 
text-align: center;
}

.header-section { 
padding: 20px 0 60px 0;
}

.header-menu-sub-menu {
background-color: #000 !important;
color: #fff !important;
}

.header-menu ul li a {
padding: 10px 15px !important; 
font-weight: 600 !important; 
background: #EEEEEE !important;
color: #121212 !important;
}

.header-menu ul li a:hover {
background: #001D3E !important; 
color: #fff !important;
}

.header-info .header-info-item i {
color: #001d3e;
}

.padt {
padding-top: 15px;
}

.padtb {
padding: 6% 0%;
}

.lift { 
position: relative; 
bottom: 10px;
}

.drop { 
position: relative; 
top: 30px;
}

.drop1 { 
position: relative; 
top: 45px;
}

.drop2 { 
position: relative; 
top: 25px;
}

.drop3 {
position: relative;
top: 25px;
}

.full {
width: 100%;
}

.textdrop {
font-size: clamp(8px, 18px, 24px);
}

.padsmall {
padding: 4px;
}

.aboutpic {
padding: clamp(2%, 3%, 4%);
}

.pad {
padding: 10% 5%;
}

.full1 {
width: 75%;
}

.pad5 {
padding-bottom: 30px;
}

.pad6 {
padding-bottom: 50px;
}

.pm-logo-container {
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap; 
gap: 200px; 
padding: 100px 0;
}

.pm-logo-container img {
max-width: 200px; 
height: auto; 
max-height: 200px; 
object-fit: contain; 
transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.logo-container img:hover {
transform: translateY(-5px); 
}

@media (max-width: 768px) {
.pm-logo-container {
flex-direction: column;
align-items: center; 
text-align: center; 
gap: 20px; 
padding: 10px 0;
}

.pm-logo-container img {
max-width: 150px; 
max-height: 60px;
}

.one-third { padding-bottom: 30px;}

.box3 {
padding: 0px; 
background-color: rgba(53,53,53, 0.67); 
border-radius: 10px;
}

.box2 {
padding: 60px 30px; 
background-color: rgba(53,53,53, 0.67); 
border-radius: 10px;
}

.box1 {
padding: 120px 60px;
}

.shade{
box-shadow: 0 18px 30px -12px rgba(50, 50, 93, .25), 0 10px 18px -18px rgba(0, 0, 0, .3);
}

.radius {
border-radius: 4px;
}

.lift3 {
position: relative; 
bottom: 120px;
}

.reviewtext1  {
font-size: clamp(1.5rem, 4vw, 2.2rem); 
line-height: clamp(1.5rem, 4vw, 2.2rem);
}

.reviewtext2  {
font-size: clamp(1.5rem, 5vw, 3rem); 
line-height: clamp(1.5rem, 5vw, 3rem);
}

.gallery-image img {
transition: transform 0.3s ease-in-out;
}

.gallery-image img:hover {
transform: scale(1.1);
}

.pm-section {
position: relative;
background-size: cover;
background-position: center;
}

.pm-section::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-image: inherit;
background-size: cover;
background-position: center;
filter: blur(10px); 
z-index: -1;
}

.reviewtext3  {
font-size: clamp(1.5rem, 4vw, 2.2rem); 
line-height: clamp(1.5rem, 4vw, 2.2rem);
}

.one-fourth {
width: 25%;
float: left;
box-sizing: border-box;
padding: 15px;
}

@media screen and (max-width: 768px) {
.one-fourth {
width: 100%;
}
}

.service-box-2 {
position: relative;
display: block;
color: white;
border-radius: 20px;
overflow: hidden;
aspect-ratio: 16/9;
background-size: cover;
background-position: center;
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
transition: transform 0.3s ease;
}

.service-box-2:hover {
transform: scale(1.03);
}

.service-box-2-content {
position: absolute;
bottom: 0;
left: 0;
padding: 20px;
background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
width: 100%;
}

.service-box-2-title {
font-size: 1.4rem;
font-weight: 700;
margin-bottom: 10px;
display: block;
}

.service-box-2-content p {
margin: 4px 0;
font-size: 0.95rem;
}

.service-box-2-accent {
position: absolute;
top: 0;
right: 0;
height: 100%;
width: 70px;
background: linear-gradient(160deg, #004aad 0%, #0075ff 100%);
transform: skewX(-20deg);
z-index: 2;
}

.service-box-2-accent-icon {
position: absolute;
top: 50%;
right: 20px;
transform: translateY(-50%);
z-index: 3;
font-size: 1.4rem;
}

textarea[name="message"] {
width: 100%;
height: 250px;
resize: none; 
}

@media (max-width: 767px) {
.service-banners-wrapper {
display: grid !important;
grid-template-columns: 1fr !important;
justify-items: center !important;
}

.banner-card {
width: 100% !important;
max-width: 300px !important;
margin: 0 auto !important;
}

.sub-banner-box {
width: 100% !important;
border-radius: 24px !important;
overflow: hidden;
box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}
}

/* Service Pages */

@media (max-width: 767px) {
.pm-section.content-section-md.white-section {
clip-path: none !important;
-webkit-clip-path: none !important;
}

.pm-section .container.full1 {
padding: 60px 16px 80px 16px !important;
}

.pm-section h1 {
font-size: clamp(36px, 10vw, 60px) !important;
text-align: center;
line-height: 1.1;
}

.pm-section h2 {
font-size: clamp(18px, 5vw, 26px) !important;
max-width: 100% !important;
text-align: center;
}

.pm-content > div {
flex-direction: column !important;
gap: 20px !important;
}

.pm-section .grid-container.lift {
padding: 0 !important;
}
}

.brand-grid {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 15px;
  justify-content: center;
  justify-items: center;
  padding-top: 10px;
}

@media (max-width: 600px) {
  .brand-grid {
    display: flex !important;         
    flex-wrap: nowrap;                /* single row */
    overflow-x: auto;                 /* horizontal scroll */
    gap: 15px;
    scroll-snap-type: x mandatory;    
    -webkit-overflow-scrolling: touch;
    padding: 10px 5px;
  }

  /* each link/logo stays fixed width */
  .brand-grid a {
    flex: 0 0 auto !important;       /* prevent shrinking */
    scroll-snap-align: center;
  }

  .brand-card {
    min-width: 140px;                 /* make sure each card is visible */
    height: 90px;
    flex: 0 0 auto;                   /* stop flex shrinking */
  }

  /* optional: hide scrollbar */
  .brand-grid::-webkit-scrollbar {
    display: none;
  }
  .brand-grid {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
}

@media (min-width: 680px) and (max-width:1260px) {.header-section {padding:10px 0 10px 0;}}@media (max-width: 680px) {.header-section {padding:10px 0 10px 0;}.header-logo {max-width:230px;}}

h1,h2,h3,h4,h5 {text-transform:uppercase;} h1 {font-size:45px;} h2 {font-size:32px;} h3 {font-size:28px;} h4 {font-size:24px;} h5 {font-size:21px;} .header-menu ul li a {font-weight:400; font-size:16px;}