* {
	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;
}/* To remove the white scrollbars in the testimonials */
.reviewMainContent {
  overflow: hidden !important;   /* removes scrollbars */
  text-overflow: ellipsis;       /* optional: add ... if text overflows */
  -ms-overflow-style: none;      /* IE/Edge */
  scrollbar-width: none;         /* Firefox */
}

.reviewMainContent::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}


/* Hero Section */

/* === FORCE HERO FULLSCREEN (desktop + mobile) and center text === */
/* ===== Fullscreen hero (desktop + mobile) + centered, professional headings ===== */

.hero-short,
.banner-slide.dark-section.parallax-bg.centered.pm-bg-image.hero-short {
  height: 100vh !important;
  min-height: 100vh !important;
  max-height: 100vh !important;
  display: flex !important;
  align-items: center !important;    /* vertical center */
  justify-content: center !important;/* horizontal center */
  text-align: center !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  background-size: cover !important;
  background-position: center center !important;
}

/* Ensure inner container fills the full hero for perfect centering */
.banner-slide .container,
.banner-slide-content {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 20px !important;
}

/* --- New: constrain and visually center the heading block --- */
.banner-slide .pm-content {
  max-width: 1100px;               /* avoids overly long single-line titles on wide screens */
  width: 94%;
  padding: 0 18px;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-3vh);     /* small upward visual nudge for better perceived center */
  -webkit-transform: translateY(-3vh);
  will-change: transform;
}

/* Headline sizing and wrapping — responsive & tighter spacing */
.banner-slide .pm-content h3.reviewtext4.promin,
.banner-slide .pm-content h3,
.hero-short h3 {
  font-weight: 600;
  font-size: clamp(18px, 2.2vw, 28px) !important;
  margin: 0 !important;
  margin-bottom: 8px;         /* small gap to h1 */
  line-height: 1 !important;
  letter-spacing: .6px;
  text-transform: uppercase;
  text-align: center !important;
  color: #fff !important;
}

.banner-slide .pm-content h1,
.hero-short h1 {
  font-weight: 700;
  font-size: clamp(32px, 5.5vw, 72px) !important;
  line-height: 0.98 !important;          /* tighter so multi-line looks compact */
  margin: 6px auto 0 !important;         /* reduced top gap */
  padding: 0 !important;
  text-align: center !important;
  color: #fff !important;
  letter-spacing: .6px;
  max-width: 100%;
  word-break: break-word !important;
  white-space: normal !important;
}

/* Allow long company names to wrap nicely */
.banner-slide .pm-content h1 .no-break,
.hero-short h1 .no-break {
  white-space: normal !important;
  display: inline-block !important;
}

/* If header pushes the layout (not overlaying), JS will add .has-header-pull and set --site-header-height.
   We then pull the hero up so it visually covers the viewport (header still visible/clickable). */
.has-header-pull .hero-short {
  transform: translateY(calc(var(--site-header-height, 0px) * -1)) !important;
  padding-top: var(--site-header-height, 0px) !important;
  height: calc(100vh + var(--site-header-height, 0px)) !important;
  min-height: calc(100vh + var(--site-header-height, 0px)) !important;
}

/* Desktop-specific: slightly stronger upward nudge (visual center) */
@media (min-width: 1200px) {
  .banner-slide .pm-content { transform: translateY(-4vh) !important; }
  .banner-slide .pm-content h1 { font-size: clamp(48px, 6.5vw, 96px) !important; line-height: 1.02 !important; }
  .banner-slide .pm-content h3 { font-size: clamp(20px, 1.6vw, 32px) !important; }
}

/* Tablet */
@media (min-width: 769px) and (max-width: 1199px) {
  .banner-slide .pm-content { transform: translateY(-3.5vh) !important; }
  .banner-slide .pm-content h1 { font-size: clamp(40px, 5.5vw, 80px) !important; }
}

/* Mobile tweaks: keep hero fullscreen and tighten the copy */
@media (max-width: 480px) {
  .hero-short,
  .banner-slide.dark-section.parallax-bg.centered.pm-bg-image.hero-short {
    height: 100vh !important;
    min-height: 100vh !important;
    max-height: 100vh !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }

  .banner-slide .pm-content {
    max-width: 92%;
    transform: translateY(-1.5vh) !important;
    padding: 0 14px;
  }

  .banner-slide .pm-content h3.reviewtext4.promin,
  .banner-slide .pm-content h3,
  .hero-short h3 {
    font-size: 14px !important;
    margin-bottom: 6px !important;
  }

  .banner-slide .pm-content h1,
  .hero-short h1 {
    font-size: 28px !important;
    line-height: 1.02 !important;
    margin-top: 4px !important;
  }
}

/* Defensive: prevent next section margins creating a visible stripe */
.section, .content-section, .page-section { margin-top: 0 !important; padding-top: 0 !important; }

/* iOS safe area */
.hero-short { padding-top: env(safe-area-inset-top, 0px) !important; padding-bottom: env(safe-area-inset-bottom, 0px) !important; }






/* 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;
}

.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 { } 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;}