/* Public website redesign layer. Loaded after the original template CSS. */
:root {
	--pharma-ink: #10233f;
	--pharma-body: #53657a;
	--pharma-muted: #7b8a9d;
	--pharma-line: #dbe7ee;
	--pharma-surface: #ffffff;
	--pharma-soft: #f3f8fb;
	--pharma-soft-2: #eaf5f7;
	--pharma-primary: #0f8fa3;
	--pharma-primary-dark: #0a5d70;
	--pharma-accent: #f06f4f;
	--pharma-green: #2f9f6b;
	--pharma-shadow: 0 20px 55px rgba(16, 35, 63, 0.12);
	--pharma-shadow-soft: 0 10px 28px rgba(16, 35, 63, 0.08);
}

html {
	scroll-behavior: smooth;
}

body {
	color: var(--pharma-body);
	background: var(--pharma-soft);
	font-size: 16px;
	line-height: 1.7;
}

h1, h2, h3, h4, h5, h6,
.module-header {
	color: var(--pharma-ink);
	letter-spacing: 0;
}

a {
	transition: color 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.container {
	width: min(1180px, 100%);
}

.ls {
	background: var(--pharma-surface);
}

.pharma-site-header.page_header {
	position: sticky;
	top: 0;
	z-index: 1000;
	padding: 14px 0;
	background: rgba(255, 255, 255, 0.94);
	border-bottom: 1px solid rgba(219, 231, 238, 0.82);
	box-shadow: 0 14px 34px rgba(16, 35, 63, 0.08);
	backdrop-filter: blur(14px);
}

.pharma-site-header .display_table {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
}

.pharma-site-header .display_table_cell {
	display: block;
}

.top_logo img,
.page_footer .vertical_logo img {
	width: 92px !important;
	max-height: 76px;
	object-fit: contain;
}

.header_mainmenu {
	display: flex !important;
	align-items: center;
	justify-content: flex-end;
	gap: 18px;
}

.mainmenu_wrapper .mainmenu {
	display: flex;
	align-items: center;
	gap: 4px;
}

.mainmenu_wrapper .mainmenu > li > a {
	position: relative;
	padding: 12px 15px;
	color: var(--pharma-ink);
	font-size: 14px;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.mainmenu_wrapper .mainmenu > li > a:after {
	content: "";
	position: absolute;
	right: 15px;
	bottom: 6px;
	left: 15px;
	height: 2px;
	border-radius: 99px;
	background: var(--pharma-primary);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.18s ease;
}

.mainmenu_wrapper .mainmenu > li > a:hover,
.mainmenu_wrapper .mainmenu > li.active > a {
	color: var(--pharma-primary);
}

.mainmenu_wrapper .mainmenu > li > a:hover:after,
.mainmenu_wrapper .mainmenu > li.active > a:after {
	transform: scaleX(1);
}

.header_cta_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 0 18px;
	border-radius: 6px;
	color: #fff;
	background: var(--pharma-primary);
	font-size: 13px;
	font-weight: 850;
	text-transform: uppercase;
	box-shadow: 0 12px 28px rgba(15, 143, 163, 0.22);
}

.header_cta_button:hover,
.header_cta_button:focus {
	color: #fff;
	background: var(--pharma-primary-dark);
	transform: translateY(-1px);
}

.intro_section.page_mainslider {
	position: relative;
	background: #071923;
	overflow: hidden;
}

.intro_section.page_mainslider:after {
	content: "";
	position: absolute;
	right: -18vw;
	bottom: -28vw;
	width: 52vw;
	height: 52vw;
	border-radius: 50%;
	background: rgba(15, 143, 163, 0.16);
	pointer-events: none;
}

.intro_section .slides > li {
	position: relative;
	min-height: 700px;
}

.intro_section .slides > li:before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		linear-gradient(90deg, rgba(6, 26, 38, 0.9) 0%, rgba(6, 26, 38, 0.7) 42%, rgba(6, 26, 38, 0.28) 100%),
		linear-gradient(180deg, rgba(6, 26, 38, 0.28), rgba(6, 26, 38, 0.62));
}

.intro_section .slides > li > img {
	width: 100%;
	min-height: 700px;
	object-fit: cover;
	filter: saturate(1.04) contrast(1.03);
}

.slide_description_wrapper {
	position: relative;
	z-index: 2;
	text-align: left;
}

.slide_description .with_corner_border.with_padding {
	max-width: 700px;
	padding: 46px 48px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.28);
	backdrop-filter: blur(14px);
}

.slide_description .bottom_corners,
.slide_description .with_corner_border:before,
.slide_description .with_corner_border:after {
	display: none;
}

.slide_description h5 {
	display: inline-flex;
	margin-bottom: 14px;
	padding: 7px 12px;
	border-radius: 999px;
	color: var(--pharma-primary-dark);
	background: rgba(15, 143, 163, 0.12);
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.slide_description h2 {
	margin-bottom: 18px;
	color: var(--pharma-ink);
	font-size: clamp(38px, 5vw, 70px);
	line-height: 1.02;
	font-weight: 900;
}

.slide_description p {
	max-width: 600px;
	color: #405166;
	font-size: 18px;
	line-height: 1.75;
}

.theme_button,
.theme_button.color2,
.theme_button.color2.inverse,
button.theme_button {
	min-height: 46px;
	border: 0;
	border-radius: 6px;
	background: var(--pharma-accent);
	color: #fff;
	box-shadow: 0 14px 28px rgba(240, 111, 79, 0.24);
	font-weight: 900;
	letter-spacing: 0;
}

.theme_button:hover,
.theme_button.color2:hover,
.theme_button.color2.inverse:hover {
	background: var(--pharma-primary);
	color: #fff;
	box-shadow: 0 14px 28px rgba(15, 143, 163, 0.24);
	transform: translateY(-1px);
}

.pharma-section-heading {
	max-width: 720px;
	margin: 0 auto 42px;
}

.pharma-section-heading span {
	display: inline-block;
	margin-bottom: 10px;
	color: var(--pharma-primary);
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.pharma-section-heading h3 {
	margin: 0 0 10px;
	font-size: clamp(28px, 3vw, 42px);
	line-height: 1.16;
	font-weight: 900;
}

.pharma-section-heading p {
	margin: 0;
	color: var(--pharma-muted);
	font-size: 17px;
}

.pharma-products-section {
	position: relative;
	padding-top: 110px !important;
	padding-bottom: 115px !important;
	background:
		linear-gradient(180deg, #fff 0%, #f6fbfd 100%);
}

#products.products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 26px;
}

#products.products:before,
#products.products:after {
	display: none;
}

#products.products > li.product {
	float: none;
	width: auto;
	margin: 0;
}

#products .vertical-item.with_border {
	position: relative;
	height: 100%;
	border: 1px solid var(--pharma-line);
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
	box-shadow: var(--pharma-shadow-soft);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

#products .vertical-item.with_border:before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--pharma-primary), var(--pharma-green));
}

#products .vertical-item.with_border:hover {
	transform: translateY(-6px);
	border-color: rgba(15, 143, 163, 0.38);
	box-shadow: var(--pharma-shadow);
}

#products .item-media {
	height: 238px;
	margin-bottom: 0;
	background:
		radial-gradient(circle at 50% 42%, rgba(15, 143, 163, 0.14), transparent 56%),
		linear-gradient(145deg, #eef8fa, #ffffff);
	display: flex;
	align-items: center;
	justify-content: center;
}

#products .item-media img {
	width: auto;
	max-width: 86%;
	max-height: 190px;
	object-fit: contain;
	filter: drop-shadow(0 16px 16px rgba(16, 35, 63, 0.14));
	transition: transform 0.2s ease;
}

#products .vertical-item.with_border:hover .item-media img {
	transform: scale(1.04);
}

#products .item-content {
	padding: 24px 22px 28px;
	text-align: left;
}

#products h4 {
	min-height: 52px;
	margin-bottom: 10px;
	font-size: 19px;
	line-height: 1.32;
	font-weight: 900;
}

#products h4 a {
	color: var(--pharma-ink);
}

#products h4 a:hover {
	color: var(--pharma-primary);
}

#products .price {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	margin: 4px 0 14px;
	padding: 7px 11px;
	border-radius: 999px;
	color: var(--pharma-primary-dark);
	background: rgba(15, 143, 163, 0.1);
	font-size: 14px;
	font-weight: 900;
}

#products .price ins {
	text-decoration: none;
}

#products .product-summary {
	min-height: 78px;
	color: var(--pharma-muted);
	font-size: 15px;
	line-height: 1.65;
}

#products .min_width_button {
	width: 100%;
	text-align: center;
}

.pharma-reviews-section {
	padding-top: 96px !important;
	padding-bottom: 106px !important;
	background:
		linear-gradient(135deg, rgba(16, 35, 63, 0.96), rgba(10, 93, 112, 0.94));
}

.pharma-reviews-section .pharma-section-heading h3,
.pharma-reviews-section .pharma-section-heading p {
	color: #fff;
}

.pharma-reviews-section .pharma-section-heading span {
	color: rgba(255, 255, 255, 0.68);
}

.testimonials-carousel {
	max-width: 920px;
	margin: 0 auto;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.96);
	padding: 42px 48px 60px;
	box-shadow: 0 24px 68px rgba(0, 0, 0, 0.22);
}

.testimonials-carousel .media {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 20px;
}

.testimonials-carousel .pull-left {
	float: none !important;
}

.testimonials-carousel .media-object {
	width: 82px;
	height: 82px;
	border: 4px solid #fff;
	border-radius: 50%;
	object-fit: cover;
	box-shadow: 0 10px 22px rgba(16, 35, 63, 0.18);
}

.testimonials-carousel .media-body h4 {
	margin-bottom: 4px;
	font-size: 20px;
	font-weight: 900;
}

.testimonials-carousel .media-body p {
	margin: 0;
	color: var(--pharma-primary);
	font-weight: 750;
}

.testimonials-carousel .item > p {
	color: #405166;
	font-size: 18px;
	line-height: 1.85;
}

.testimonials-carousel .carousel-control.left,
.testimonials-carousel .carousel-control.right {
	border-color: rgba(15, 143, 163, 0.22);
	background: var(--pharma-primary);
}

.pharma-contact-section {
	padding-top: 106px !important;
	padding-bottom: 110px !important;
	background:
		linear-gradient(180deg, #f6fbfd 0%, #ffffff 100%);
}

.pharma-contact-section form {
	padding: 34px;
	border: 1px solid var(--pharma-line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--pharma-shadow);
}

.pharma-contact-section label {
	color: var(--pharma-ink);
	font-size: 14px;
	font-weight: 850;
}

.pharma-contact-section .form-control {
	height: 52px;
	border: 1px solid var(--pharma-line);
	border-radius: 6px;
	background: #fff;
	color: var(--pharma-ink);
	box-shadow: none;
}

.pharma-contact-section textarea.form-control {
	min-height: 132px;
	resize: vertical;
}

.pharma-contact-section .form-control:focus {
	border-color: var(--pharma-primary);
	box-shadow: 0 0 0 3px rgba(15, 143, 163, 0.12);
}

.pharma-contact-section .list1.no-bullets li {
	margin-bottom: 16px;
	padding: 22px;
	border: 1px solid var(--pharma-line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--pharma-shadow-soft);
}

.pharma-contact-section .list1 .media {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.pharma-contact-section .list1 .media-left {
	width: 42px;
	height: 42px;
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(15, 143, 163, 0.11);
}

.pharma-contact-section .list1 .media-left i {
	color: var(--pharma-primary);
}

.pharma-contact-section .media-heading {
	margin-bottom: 4px;
	color: var(--pharma-ink);
	font-weight: 900;
}

.page_footer.ds.color {
	padding-top: 82px !important;
	background:
		linear-gradient(135deg, #10233f, #081722);
}

.page_footer .widget-title,
.page_footer h4 {
	color: #fff;
}

.page_footer p,
.page_footer .media-body {
	color: rgba(255, 255, 255, 0.78);
}

.page_footer a {
	color: rgba(255, 255, 255, 0.9);
}

.page_footer a:hover {
	color: #fff;
}

.page_footer a.social-icon {
	margin-right: 8px;
	border-radius: 6px;
	color: #fff;
	background: rgba(255, 255, 255, 0.1);
}

.page_copyright.ds.color.darker {
	background: #07131e;
}

@media (max-width: 1199px) {
	#products.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 991px) {
	.header_cta_button {
		display: none;
	}

	#products.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.slide_description .with_corner_border.with_padding {
		padding: 34px;
	}

	.intro_section .slides > li,
	.intro_section .slides > li > img {
		min-height: 620px;
	}
}

@media (max-width: 767px) {
	.pharma-site-header.page_header {
		position: relative;
		background: #fff;
	}

	.pharma-site-header .display_table {
		display: table;
	}

	.pharma-site-header .display_table_cell {
		display: table-cell;
	}

	.mainmenu_wrapper .mainmenu {
		display: block;
	}

	.intro_section .slides > li,
	.intro_section .slides > li > img {
		min-height: 560px;
	}

	.slide_description_wrapper {
		text-align: center;
	}

	.slide_description .with_corner_border.with_padding {
		padding: 26px 20px;
	}

	.slide_description h2 {
		font-size: 34px;
	}

	.slide_description p {
		font-size: 16px;
	}

	.pharma-products-section,
	.pharma-reviews-section,
	.pharma-contact-section {
		padding-top: 72px !important;
		padding-bottom: 76px !important;
	}

	#products.products {
		grid-template-columns: 1fr;
	}

	#products .item-media {
		height: 218px;
	}

	.testimonials-carousel {
		padding: 28px 24px 56px;
	}

	.testimonials-carousel .media {
		display: block;
		text-align: center;
	}

	.testimonials-carousel .media-object {
		margin: 0 auto 14px;
	}

	.pharma-contact-section form {
		padding: 22px;
	}
}
