:root {
--navy:#06285f;
--navy2:#021f49;
--green:#16843a;
--white:#fff;
--light:#f6faff;
--text:#0b1e3f;
--muted:#1f233e;
--border:#dce6f2;
--shadow:0 15px 40px rgba(6, 40, 95, .10)
}
*, ::before, ::after {
box-sizing: border-box;
margin:0;
padding: 0;
}

/* Header height ke barabar scroll offset */
section {
    scroll-margin-top:70px;
}
#home, #about, #services, #why, #industries-sec, #contact {
    scroll-margin-top:70px;
}


.position-relative {
	position:relative
}
.pb {
	padding-bottom:0!important
}
a {
	text-decoration:none
}
html {
	scroll-behavior:smooth
}
body {
	font-family: 'Open Sans', sans-serif;
	color:var(--text);
	background:#fff;
	padding:0;
	margin:0;
}
img {
	max-width:100%;
	display:block
}
.container {
	width:100%;
	padding-left:15px;
	padding-right:15px;
	margin:auto;
}
 @media(min-width:576px) {
 .container {
 max-width:540px;
}
}
 @media(min-width:768px) {
 .container {
 max-width:720px;
}
}
 @media(min-width:992px) {
 .container {
 max-width:960px;
}
}
 @media(min-width:1280px) {
 .container {
 max-width:1280px;
}
}
 @media(min-width:1400px) {
 .container {
 max-width:1400px;
}
}
.active {
	border-bottom: 2px solid #16843a!important;
}
.accent {
	color:var(--green)
}
p {
	font-size:15px;
	line-height:1.7;
	color:var(--muted)
}
.section {
	padding:60px 0
}
.section-title {
	font-size:36px;
	line-height:1.15;
	color:var(--navy);
	font-weight:700;
	font-family: 'Montserrat', sans-serif;
}
.section-head {
	text-align:center;
	margin-bottom:42px
}
h1, h2, h3, h4, h5, h6 {
	font-family: 'Montserrat', sans-serif;
}
.underline {
	width:56px;
	height:3px;
	background:var(--green);
	margin:14px 0 20px 0
}
.m-auto {
	margin:0 auto
}
.btn-row {
	display:flex;
	gap:16px;
	flex-wrap:wrap;
	margin-top:28px
}
.btn {
	display:inline-flex;
	align-items:center;
	gap:10px;
	border-radius:6px;
	padding:14px 22px;
	text-decoration:none;
	font-weight:700;
	font-size:14px
}
.btn-primary {
	background:var(--navy);
	color:#fff
}
.btn-outline {
	border:1px solid var(--green);
	color:var(--green);
	background:#fff
}
.site-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 15px;
	background: var(--white);
	box-shadow: 0 2px 12px rgba(0, 0, 0, .08);
	position: sticky;
	top: 0;
	z-index: 1000;
}
.nav-wrap {
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap:25px
}
.logo {
	display:flex;
	align-items:center;
	gap:10px;
	font-weight:800;
	color:var(--navy);
	font-size:28px;
	line-height:.9
}
.logo-mark {
	width:48px;
	height:48px;
	border-radius:50%;
	border:10px solid var(--green);
	border-right-color:var(--navy);
	display:block
}
.logo small {
	display:block;
	color:var(--green);
	font-size:19px
}
.menu {
	display:flex;
	gap:25px;
	align-items:center
}
.menu a {
	font-size:12px;
	font-weight:600;
	text-decoration:none;
	color:#10254b;
	font-family: 'Montserrat', sans-serif;
	border-bottom:2px solid transparent;
	padding-bottom:5px;
	padding-top:5px;
}
.phone {
	background:var(--green);
	color:#fff;
	border-radius:6px;
	padding:11px 18px;
	font-weight:700;
	font-size:13px;
	white-space:nowrap
}
.phone a {
	color:#fff
}
.phone:hover {
	background:var(--navy);
}
.mobile-toggle {
	display:none;
	background:var(--navy);
	color:white;
	border:0;
	border-radius:6px;
	padding:10px 12px; font-size:20px; padding:4px 12px 5px 12px;
}
.hero {
	background: url(../images/hero.jpg) no-repeat right top;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	padding:80px 0 50px;
}
.hero-grid {
	display:grid;
	grid-template-columns:1fr 1fr;
	align-items:center;
	gap:40px
}
.hero h1 {
	font-size:44px;
	line-height:1.15;
	color:var(--navy);
	font-weight:700;
	margin-bottom:18px;
}
.trust-row {
	display:grid;
	grid-template-columns:repeat(4, 1fr);
	gap:20px;
	margin-top:42px;
	max-width:520px
}
.trust-item {
	text-align:center;
	font-size:13px;
	font-weight:700
}
.trust-icon {
	font-size:34px;
	margin-bottom:8px;
	color:var(--navy);
}
.trust-item span {
	color:#191919
}
.about-grid {
	display:grid;
	grid-template-columns:1fr 1.05fr;
	align-items:center;
	gap:70px
}
.about .underline {
	margin-left:0
}
.about-copy p+p {
	margin-top:18px
}
.services {
	background:var(--light)
}
.service-grid {
	display:grid;
	grid-template-columns:repeat(6, 1fr);
	gap:16px
}
.service-card {
	background:#fff;
	border:1px solid var(--border);
	border-radius:10px;
	overflow:hidden;
	box-shadow:0 8px 24px rgba(6, 40, 95, .06)
}
.service-card img {
	height:165px;
	width:100%;
	object-fit:cover
}
.service-body {
	padding:18px 10px
}
.service-body h3 {
	text-align:center;
	color:var(--navy);
	font-size:16px;
	line-height:1.25;
	margin-bottom:14px;
	padding:15px 0 0 0
}
.service-body ul { margin:0; padding:0;}
.service-body li {
	font-size:12px;
	line-height:1.2;
	margin-bottom:10px;
	color:#243655; list-style:none!important; position:relative; padding-left:20px;
}

.service-body li i { position:absolute; left:0;}

.why-grid {
	display:grid;
	grid-template-columns:repeat(5, 1fr);
	border:1px solid var(--border);
	border-radius:12px;
	overflow:hidden;
	background:#fff;
}
.why-card {
	padding:34px 20px;
	text-align:center;
	border-right:1px solid var(--border);
	background:#f5f8fd
}
.why-card:last-child {
	border-right:0
}
.why-icon {
	font-size:42px;
	margin-bottom:18px
}
.why-card h3 {
	font-size:16px;
	line-height:1.4;
	color:var(--navy);
	margin-bottom:12px;
	padding:0 6%
}
.why-card p {
	font-size:12px;
	line-height:1.6
}
.industry-grid {
	display:grid;
	grid-template-columns:repeat(7, 1fr);
	gap:22px
}
.industry-item {
	text-align:center;
	color:var(--navy);
	font-size:13px;
	font-weight:700;
	line-height:1.35
}
.industry-icon {
	width:100px;
	height:100px;
	border-radius:50%;
	display:flex;
	align-items:center;
	justify-content:center;
	background:#fff;
	box-shadow:var(--shadow);
	font-size:34px;
	margin:0 auto 14px;
	padding:15px;
}
.industry-icon img {
	max-width:100%
}
.global {
	background:#edf0f5
}
.global-grid {
	display:grid;
grid-template-columns:.8fr 1.2fr;
	align-items:center;
	gap:45px
}
.market-list {
	list-style:none;
	margin:24px 0
}
.market-list li {
	font-weight:600;
	color:var(--navy);
	margin:10px 0;
	width:30%
}

.market-list li i {color:var(--green); margin-right:5px}

.market-list li img {
	width:20px;
	float:right
}
.contact {
	background: linear-gradient(90deg, #fff 0%, #fff 50%, rgba(255, 255, 255, .4) 64%, rgba(255, 255, 255, 0) 100%), url('../images/contact.jpg') right center/58% auto no-repeat;
	padding:0!important;
}
.p-0 {
	margin:0!important;
	padding:0!important;
}
.contact-se {
	padding:50px 0 50px 0
}
.contact-grid {
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:60px;
	align-items:center
}
.contact-boxes {
	display:grid;
	grid-template-columns:repeat(2, 1fr);
	gap:14px;
	margin-top:30px
}
.contact-box {
	background:#fff;
	border-radius:8px;
	padding:17px 18px;
	box-shadow:0 8px 25px rgba(6, 40, 95, .08);
	font-weight:700;
	font-size:14px;
	color:var(--navy)
}

.contact-box a {color:var(--navy)}
.contact-box a:hover {color: var(--green);}

.contact-box i {
	font-size:20px;
	vertical-align:middle;
	margin-right:14px
}
/* -- FOOTER -- */
  footer {
	background-color: #0a1f44;
	width: 100%;
	padding: 0 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 58px;
	flex-wrap: wrap;
	gap: 0;
}
/* -- LOGO AREA -- */
  .footer-logo {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	flex-shrink: 0;
	padding: 10px 0;
}
.logo-icon {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
}
.logo-text {
	display: flex;
	flex-direction: column;
	line-height: 1.15;
}
.logo-text .genz {
	font-size: 17px;
	font-weight: 800;
	color: #ffffff;
}
.logo-text .pharma {
	font-size: 12px;
	font-weight: 700;
	color: #4caf7d;
}
/* -- TAGLINE -- */
  .tagline {
	border-left: 1px solid rgba(255, 255, 255, 0.22);
	padding-left: 13px;
	margin-left: 8px;
	flex-shrink: 0;
}
.tagline p {
	font-size:11px;
	color: #b0c4d8;
	line-height: 1.5;
	font-weight: 600;
	max-width: 200px;
}
/* -- VERTICAL DIVIDER -- */
  .v-divider {
	width: 1px;
	height: 34px;
	background: rgba(255, 255, 255, 0.2);
	margin: 0 1.4rem;
	flex-shrink: 0;
}
/* -- FOOTER LINKS -- */
  .footer-links {
	display: flex;
	align-items: center;
	list-style: none;
	flex: 1;
	justify-content: center;
	flex-wrap: wrap;
}
.footer-links li a {
	padding: 0 13px;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: #ccd9e8;
	text-decoration: none;
	border-right: 1px solid rgba(255, 255, 255, 0.18);
	white-space: nowrap;
	transition: color 0.2s;
	line-height: 58px;
}
.footer-links li:first-child a {
	border-left: 1px solid rgba(255, 255, 255, 0.18);
}
.footer-links li:last-child a {
	border:0;
}
.footer-links li a:hover {
	color: #ffffff;
}
/* -- RIGHT SECTION -- */
  .footer-right {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
	padding: 10px 0;
}
.follow-text {
	font-size: 11px;
	font-weight: 600;
	color: #b0c4d8;
	white-space: nowrap;
}
.linkedin-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: #0a66c2;
	border-radius: 5px;
	text-decoration: none;
	transition: background 0.2s;
	flex-shrink: 0;
}
.linkedin-btn:hover {
	background: #0958a8;
}
.linkedin-btn svg {
	width: 15px;
	height: 15px;
	fill: #ffffff;
}
.copyright {
	font-size: 11px;
	color: #7a92a8;
	white-space: nowrap;
	border-left: 1px solid rgba(255, 255, 255, 0.15);
	padding-left: 12px;
	margin-left: 4px;
}

  /* -- RESPONSIVE -- */

  /* Tablet */
  @media (max-width: 1050px) {
 .footer-links li a {
padding: 0 9px;
font-size: 10px;
}
 .v-divider {
margin: 0 0.8rem;
}
 .copyright {
display: none;
}
}

  /* Small tablet / large mobile */
  @media (max-width: 780px) {
 footer {
 flex-direction: column;
 align-items: flex-start;
 padding: 1rem 1.5rem;
 gap: 12px;
 min-height: unset;
}
 .v-divider {
display: none;
}
 .tagline {
border-left: none;
padding-left: 0;
margin-left: 0;
}
 .footer-links {
 justify-content: flex-start;
 gap: 0;
}
 .footer-links li a {
 line-height: 36px;
 font-size: 10px;
 padding: 0 10px;
}
 .footer-links li:first-child a {
border-left: 1px solid rgba(255, 255, 255, 0.18);
}
 .footer-right {
width: 100%;
justify-content: flex-start;
}
 .copyright {
 display: block;
 border-left: none;
 padding-left: 0;
 margin-left: 0;
 font-size: 10px;
 color: #5a7a8a;
 width: 100%;
}
}

  /* Mobile */
  @media (max-width: 480px) {
footer {
padding: 1rem;
gap: 10px;
}
.footer-links {
flex-wrap: wrap;
}
.footer-links li a {
line-height: 32px;
font-size: 9.5px;
padding: 0 8px;
}
.logo-text .genz {
font-size: 15px;
}
.footer-links li a {
line-height:14px;
font-size:9.5px;
}
}
.mobile-menu {
	display:none
}
@media(max-width:1100px) {
.menu {
display:none
}
.mobile-toggle {
display:block
}
.mobile-menu.is-open {
display:flex;
position:absolute;
top:82px;
left:4%;
right:4%;
background:#fff;
box-shadow:var(--shadow);
border-radius:12px;
padding:18px;
flex-direction:column;
gap:12px
}
.mobile-menu a {
text-decoration:none;
color:var(--navy);
font-weight:700
}
.hero {
background-size:70%;
background-position:right bottom
}
.hero-grid, .about-grid, .global-grid, .contact-grid {
grid-template-columns:1fr
}
.service-grid {
grid-template-columns:repeat(3, 1fr)
}
.why-grid {
grid-template-columns:repeat(2, 1fr);
border:0;
gap:18px;
box-shadow:none
}
.why-card {
border:1px solid var(--border);
border-radius:12px
}
.industry-grid {
grid-template-columns:repeat(4, 1fr)
}
.footer-grid {
grid-template-columns:1fr 1fr
}
}
@media(max-width:760px) {
.section {
padding:60px 0
}
.hero {
padding-top:20px;
min-height:auto;
background:#f8f9fe
}
.hero h1 {
font-size:34px
}
.section-title {
font-size:30px
}
.trust-row {
grid-template-columns:repeat(2, 1fr)
}
.why-grid, .industry-grid, .contact-boxes, .footer-grid {
grid-template-columns:1fr
}
 .service-grid {
grid-template-columns:1fr 1fr
}
 .contact {
background:#f8fbff
}
.phone {
display:none
}
.logo {
font-size:22px
}
 .footer-menu {
flex-direction:column
}
.about-grid {
gap:30px
}
}
/*service*/
.card-icon {
	position: absolute;
	bottom: -14px;
	left: 50%;
	transform: translateX(-50%);
	width:40px;
	height:40px;
	background: var(--navy);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
	border:solid 1px var(--white)
}
.card-icon i {color:#fff}

/*service*/
@media(max-width:820px) {    
.hero h1 {font-size:22px;}
.site-header {padding:8px 0}
.section {padding:20px 0;}
.section-title { font-size:20px}
.btn {font-size:13px; padding:10px 13px;}
.trust-item br { display:none}
.hero-grid {gap:0;}
.underline {margin:14px auto 20px auto}
p {font-size:14px;line-height: 1.5;}
.section-head {margin-bottom:20px;}
.why-card {padding:20px}
.industry-icon {width:70px; height:70px;}
.industry-grid {grid-template-columns:1fr 1fr;}
.mobile-menu.is-open {display: flex;
position: absolute;
top: 59px;
left: 0;
right: 0;
background: #f7f8fa;
box-shadow: var(--shadow);
border-radius: 0;
padding: 18px;
flex-direction: column;
gap: 12px;
}
.mobile-menu a { font-size:14px;}
.contact-se {padding: 50px 0 0 0;}
.hero {padding:20px 0 20px}
.active {border-bottom:0!important; color:#16843a!important}
}

@media(max-width:480px) {.service-grid {grid-template-columns:1fr}}
