/* ========================================
   CSS CUSTOM PROPERTIES - Color Palette
   ======================================== */
:root {
	--color-primary: #0c324a;
	--color-secondary: #FFFFFF;
	--color-info: #348AA7;
	--color-accent: #F6AE2D;
	--color-danger: #721817;
	--color-light-grey: #D1D5DB;
	--color-medium-grey: #6b7280;
	--color-bg: #F5F5F5;
	--color-white: #ffffff;
	--color-parchment: #F2EFEA;
	--shadow-sm: 0 2px 8px rgba(12, 50, 74, 0.06);
	--shadow-md: 0 8px 24px rgba(12, 50, 74, 0.08);
	--shadow-lg: 0 20px 60px rgba(12, 50, 74, 0.08);
	--transition-fast: 0.15s ease;
	--transition-normal: 0.2s ease;
	--transition-slow: 0.25s ease;
}
@font-face {
	font-family: 'OSP-DIN';
	src: url('../i/OSP-DIN.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}
.font-osp-din {
    font-family: 'OSP-DIN', helvetica neue, sans-serif;
}

/* ========================================
   BASE STYLES
   ======================================== */
* { 
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	background: var(--color-bg);
	font-family: var(--tblr-body-font-family);
	color: var(--color-primary);
	overflow-x: hidden;
}

html {
	scroll-behavior: smooth;
}

/* ========================================
   HEADER & NAVIGATION
   ======================================== */
.header-minimal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 158px;
	z-index: 99;
}

.header-white-base {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 165px;
	background: var(--color-white);
	z-index: 1;
}

.header-dark-top {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 125px;
	background: var(--color-primary);
	z-index: 5;
}

#header-menu {
	position: relative;
	top: -40px;
	left: 0;
	right: 0;
	padding: 0;
	z-index: 1000;
}

.nav-link:focus, 
.nav-link:hover {
	background: var(--color-primary) !important;
	color: var(--color-white) !important;
}
#header-menu .nav-link {
	position: relative !important;
	transition: background-color 0.2s ease, color 0.2s ease;
}

#header-menu .nav-link:hover {
	background-color: var(--color-primary) !important;
	color: var(--color-parchment) !important;
}

#header-menu .nav-link:hover .products-chevron {
	color: var(--color-parchment) !important;
}

#header-menu .nav-link.active {
	background-color: var(--color-primary) !important;
	color: var(--color-parchment) !important;
	font-weight: 600 !important;
}

#header-menu .nav-link.active .products-chevron {
	color: var(--color-parchment) !important;
}

#productsMenuToggle[aria-expanded="true"] {
	background-color: var(--color-primary) !important;
	color: var(--color-parchment) !important;
}

#productsMenuToggle[aria-expanded="true"] .products-chevron {
	color: var(--color-parchment) !important;
}

/* ========================================
   HEADER TOP RIGHT - Date, Contact & Language
   ======================================== */
#header-top-right {
	position: absolute;
	top: 8px;
	right: 0px;
	z-index: 1000;
}

.header-date {
	font-size: 0.75rem;
	opacity: 0.9;
}

.header-contact-link:hover {
	color: var(--color-accent) !important;
}

.header-lang-switcher {
	border-left: 1px solid rgba(255, 255, 255, 0.3);
	padding-left: 0.75rem;
}

.lang-link {
	color: var(--color-white);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	padding: 0.25rem 0.5rem;
	border-radius: 3px;
	transition: background-color var(--transition-fast);
}

.lang-link:hover {
	background: rgba(255, 255, 255, 0.1);
	color: var(--color-accent);
}

.lang-link.active {
	background: var(--color-accent);
	color: var(--color-primary);
	font-weight: 600;
}

.lang-separator {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.75rem;
}

/* ========================================
   LOGO STYLING
   ======================================== */
#logo-container {
	position: relative;
	height: 165px;
	z-index: 999;
}

#logoSelf {
	position: absolute;
	background: url("../i/logo.png") no-repeat top left;
	top: 1px;
	left: -8px;
	width: 535px;
	height: 160px;
	z-index: 10;
}
#logoSelf span {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.logo-name {
	font-family: 'OSP-DIN', helvetica neue, sans-serif;
	font-size: 1.5rem;
	letter-spacing: 1px;
	font-weight: 100;
}

.logo-reg {
	position: relative;
	top: 65px;
	right: -430px;
	font-size: 1rem;
	font-weight: 400;
	color: var(--color-white);
	vertical-align: super;
}

.logo-reg-bottomline {
	font-size: 1rem;
	font-weight: 200;
}

#logo-subtitle {
	font-family: 'OSP-DIN', helvetica neue, sans-serif;
	position: absolute;
	top: 128px;
	left: 112px;
	margin: 0;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	z-index: 1001;
}

/* ========================================
   TYPOGRAPHY
   ======================================== */
.title-minimal {
	font-size: clamp(2rem, 6vw, 2rem);
	font-weight: 300;
	line-height: 1.1;
	letter-spacing: -0.02em;
}

.title-minimal strong {
	font-weight: 900;
}

.line-accent {
	width: 60px;
	height: 2px;
	background: var(--color-info);
	margin-bottom: 1.5rem;
}

/* ========================================
   EMAIL PROTECTION
   ======================================== */
a.email-protected {
	cursor: pointer;
}
.no-js a.email-protected {
	pointer-events: none;
	opacity: 0.6;
}

/* ========================================
   UTILITY CLASSES
   ======================================== */
.text-info-color { color: var(--color-info); }
.text-body-color { color: var(--color-primary); }
.text-muted-color { color: var(--color-medium-grey); }
.text-primary-color { color: var(--color-primary); }
.bg-accent { background-color: var(--color-accent) !important; }
.bg-parchment { background-color: var(--color-parchment) !important; }
.bg-light-grey { background-color: var(--color-light-grey) !important; }
.bg-medium-grey { background-color: var(--color-medium-grey) !important; }
.text-accent { color: var(--color-accent) !important; }
.text-parchment { color: var(--color-parchment) !important; }
.text-light-grey { color: var(--color-light-grey) !important; }
.text-medium-grey { color: var(--color-medium-grey) !important; }
.border-accent-color { border-color: var(--color-accent) !important; }
.border-light-grey-color { border-color: var(--color-light-grey) !important; }
.visually-hidden {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border-width: 0 !important;
}
.text-opacity-10 { opacity: 0.1 !important; }
.text-opacity-25 { opacity: 0.25 !important; }
.text-opacity-50 { opacity: 0.5 !important; }
.text-opacity-75 { opacity: 0.75 !important; }
.text-opacity-100 { opacity: 1 !important; }

.bg-opacity-10 { opacity: 0.1 !important; }
.bg-opacity-25 { opacity: 0.25 !important; }
.bg-opacity-50 { opacity: 0.5 !important; }
.bg-opacity-75 { opacity: 0.75 !important; }
.bg-opacity-100 { opacity: 1 !important; }
.fs-09 { font-size: 0.9rem; }
.fs-095 { font-size: 0.95rem; }
.fs-105 { font-size: 1.05rem; }
.fs-11 { font-size: 1.1rem; }
.fs-12 { font-size: 1.2rem; }
.fs-13 { font-size: 1.3rem; }
.fs-15 { font-size: 1.5rem; }
.fs-18 { font-size: 1.8rem; }
.fs-2rem { font-size: 2rem; }
.fs-3rem { font-size: 3rem; }
.fs-35rem { font-size: 3.5rem; }

.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
.fw-300 { font-weight: 300; }

.lh-16 { line-height: 1.6; }
.lh-17 { line-height: 1.7; }
.lh-18 { line-height: 1.8; }
.mt-0 { margin-top: 0; }
.mt-3 { margin-top: 1rem; }
.mt-80 { margin-top: 80px; }
.mt-50 { margin-top: 50px; }
.mt-60 { margin-top: 60px; }
.mt-100 { margin-top: 100px; }
.mt-150 { margin-top: 150px; }
.my-60-100 { margin: 60px 0 100px; }
.my-100-100 { margin: 100px 0 100px; }
.mb-5 { margin-bottom: 2.5rem; }
.mb-100 { margin-bottom: 100px; }

.p-form { padding: 1rem; }
.p-3rem { padding: 3rem; }
.border-accent { border-top: 3px solid var(--color-accent); }
.border-muted-1 { border: 1px solid var(--color-light-grey); }
.border-muted-2 { border: 2px solid var(--color-light-grey); }
.border-accent-left { border-left: 5px solid var(--color-accent); }
.max-w-550 { max-width: 550px; }
.max-w-700 { max-width: 700px; }
.w-full { width: 100%; }
.w-70{width: 70% !important;}
.w-65{width: 65% !important;}
.w-60{width: 60% !important;}
.w-45{width: 45% !important;}
.w-40{width: 40% !important;}
.w-35{width: 35% !important;}
.w-30{width: 30% !important;}

/* ========================================
   MODULAR GRID SYSTEM
   ======================================== */
.modular-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 1.5rem;
	isolation: auto;
}
.module-1 { grid-column: span 12; }
.module-2 { grid-column: span 6; }
.module-3 { grid-column: span 4; }
.module-4 { grid-column: span 3; }
.module-6 { grid-column: span 8; }
.module-7 { grid-column: span 5; }
.module-8 { grid-column: span 7; }

/* ========================================
   MODULE BASE STYLES
   ======================================== */
.module {
	background: var(--color-white);
	padding: 1.5rem;
	border: 1px solid var(--color-light-grey);
	position: relative;
	overflow: hidden;
}

.module::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 3px;
	height: 100%;
	background: var(--color-white);
	transform: scaleY(0);
	transform-origin: top;
}

.module:hover {
	transform: translateY(-5px);
	transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.module:hover::before {
	transform: scaleY(1);
	transition: transform var(--transition-normal);
}
.module-1:hover {
	transform: none;
	box-shadow: none;
}

.module-1:hover::before {
	height: 0;
}
.module-tall { min-height: 450px; }
.module-medium { min-height: 300px; }
.module-short { min-height: 200px; }
.module-170 { min-height: 170px; }
.module-dark {
	background: var(--color-primary);
	color: var(--color-parchment);
	border-color: var(--color-primary);
}

.module-white {
	background: var(--color-white);
	border-color: var(--color-light-grey);
}

/* ========================================
   SPECIALIZED MODULES
   ======================================== */

/* Note: .hero-fullwidth moved to page-home.css (homepage specific)
   Other pages using .hero-fullwidth should define it in their own page-specific CSS files */
.image-module {
	padding: 0;
	overflow: hidden;
	border: none;
	background: transparent;
}

.image-module img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.cta-module {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
}

/* ========================================
   TEXT & CARD COMPONENTS
   ======================================== */
.card-title-minimal,
.service-title-minimal {
	font-weight: 600;
	font-size: 1.2rem;
	margin-bottom: 0.6rem;
	color: var(--color-primary);
}

.service-title-minimal {
	font-size: 1.3rem;
	margin-bottom: 0.8rem;
}
.card-text-minimal {
	color: var(--color-info);
	line-height: 1.5;
	font-size: 0.95rem;
}

.service-text-minimal {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--color-primary);
}

/* ========================================
   TIMELINE COMPONENT
   ======================================== */
.timeline-container {
	border-bottom: 1px solid var(--color-light-grey);
}

.timeline-year {
	color: var(--color-primary);
}

.timeline-year strong {
	font-size: 1.8rem;
	font-weight: 700;
	display: block;
	line-height: 1;
	margin-bottom: 0.3rem;
}

.timeline-year span {
	color: var(--color-medium-grey);
	font-size: 0.85rem;
}

.timeline-divider {
	height: 2px;
	background: linear-gradient(90deg, var(--color-light-grey), var(--color-accent), var(--color-light-grey));
}

/* ========================================
   QUALITY CERTIFICATION LOGOS
   ======================================== */
.quality-box {
	border: 2px solid var(--color-light-grey);
	border-left: 5px solid var(--color-accent);
	padding: 2rem 3rem;
	background: var(--color-white);
}

.quality-logo {
	max-height: 70px;
	max-width: 75px;
	height: auto;
	width: auto;
	display: block;
}

.quality-divider {
	padding: 0;
	height: 50px;
	width: 1px;
	background: var(--color-light-grey);
}

/* ========================================
   FORMS
   ======================================== */
.form-container {
	max-width: 700px;
	margin: 0 auto;
}

.form-description {
	font-size: 1.1rem;
	color: var(--color-info);
	margin-bottom: 3rem;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

.form-input-minimal {
	width: 100%;
	padding: 1rem;
	border: 1px solid var(--color-light-grey);
	font-size: 1rem;
	color: var(--color-primary);
	background: var(--color-white);
}

.form-input-minimal:focus {
	outline: none;
	border-color: var(--color-primary);
}

.form-footer-text {
	font-size: 0.85rem;
	color: var(--color-medium-grey);
	text-align: center;
	margin-top: 1.5rem;
}

.form-footer-text strong {
	color: var(--color-primary);
}
form input,
form select,
form textarea,
form button,
form .btn-minimal,
form .btn-minimal::before,
form .btn-minimal-primary,
form .btn-minimal-primary::before,
form .btn-ghost-minimal-primary,
form .btn-ghost-minimal-primary::before,
form p,
form a,
form strong {
	transition: none !important;
}

/* ========================================
   BUTTONS
   ======================================== */
.btn-minimal {
	display: inline-block;
	padding: 1rem 2rem;
	background: transparent !important;
	color: var(--color-primary);
	border: 2px solid var(--color-primary);
	text-decoration: none;
	font-weight: 600;
	position: relative;
	overflow: hidden;
}

.btn-minimal::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-primary);
	transform: scaleX(0);
	transform-origin: left;
	z-index: -1;
	pointer-events: none;
}
.btn-minimal > *,
.btn-minimal-inner {
	position: relative;
	z-index: 1;
}

.btn-minimal:hover {
	background: transparent !important;
	color: var(--color-white) !important;
	transition: color var(--transition-slow);
}

.btn-minimal:hover::before {
	transform: scaleX(1) !important;
	transition: transform var(--transition-slow);
}
.hero-content-overlay .btn-minimal:hover {
	color: var(--color-white) !important;
}

.btn-minimal-primary {
	background: var(--color-primary);
	color: var(--color-parchment);
	border-color: var(--color-primary);
}

.btn-minimal-primary::before {
	background: var(--color-info);
}

.btn-minimal-primary:hover {
	border-color: var(--color-info);
}
.btn-ghost-minimal-primary {
	background: transparent;
	color: var(--color-primary);
	border: 2px solid transparent;
}

.btn-ghost-minimal-primary::before {
	background: var(--color-primary);
}

.btn-ghost-minimal-primary:hover {
	background: var(--color-primary) !important;
	color: var(--color-parchment) !important;
	border-color: var(--color-primary) !important;
}

.btn-full-width {
	width: 100%;
	justify-content: center;
}

/* ========================================
   FOOTER
   ======================================== */
.footer-minimal {
	background: var(--color-white);
	border-top: 1px solid var(--color-light-grey);
	padding: 4rem 0 2rem 0;
}

.footer-dark {
	background: var(--color-primary) !important;
	/*border-top: 1px solid rgba(255, 255, 255, 0.1) !important; */
}

.footer-dark .footer-heading {
	color: var(--color-parchment) !important;
	border-bottom: 2px solid var(--color-info);
	padding-bottom: 0.5rem;
	margin-bottom: 1rem;
}

.footer-dark .footer-list a,
.footer-dark .footer-contact,
.footer-dark .footer-contact a {
	color: rgba(242, 239, 234, 0.8) !important;
}

.footer-dark .footer-list a:hover,
.footer-dark .footer-contact a:hover {
	color: #17a2b8 !important;
}

.footer-dark .border-top {
	border-color: rgba(255, 255, 255, 0.1) !important;
}

.footer-heading {
	font-weight: 600;
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 1.5rem;
	color: var(--color-primary);
}

.footer-list {
	list-style: none;
	padding: 0;
	line-height: 2.2;
	font-size: 0.9rem;
}

.footer-list a {
	color: var(--color-primary);
	text-decoration: none;
}

.footer-list a:hover,
.footer-minimal a:hover {
	color: var(--color-accent) !important;
}

.footer-contact {
	line-height: 2.2;
	color: var(--color-primary);
	font-size: 0.9rem;
}

.footer-text-small {
	font-size: 0.85rem;
	color: var(--color-medium-grey);
	text-align: center;
	margin-top: 1.5rem;
}

.footer-text-small strong {
	color: var(--color-primary);
}

/* ========================================
   SPACING
   ======================================== */
.spacer {
	padding: 3rem 0;
}

.container-xl.spacer {
	margin-top: 0;
	padding-top: 0;
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */
@media (max-width: 992px) {
	.module-2,
	.module-7,
	.module-8 {
		grid-column: span 6;
	}
	
	.module-3,
	.module-4 {
		grid-column: span 7;
	}
	
	.module-6 {
		grid-column: span 12;
	}
}

@media screen and (max-width: 768px) {
	html, body {
		width: 100% !important;
		max-width: 100% !important;
		overflow-x: hidden;
		margin: 0;
		padding: 0;
	}
	.module-2,
	.module-3,
	.module-4,
	.module-6,
	.module-7,
	.module-8 {
		grid-column: span 12;
	}
	
	.modular-grid {
		gap: 1rem;
		width: 100%;
		justify-items: center;
	}
	
	.module {
		padding: 1.5rem;
		width: 100%;
		max-width: 100%;
	}
	.container-xl {
		width: 100% !important;
		max-width: 100% !important;
		padding-left: 1rem !important;
		padding-right: 1rem !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	.header-minimal,
	#header-menu {
		width: 100vw !important;
		max-width: 100vw !important;
		left: 0 !important;
		right: 0 !important;
	}
	.header-minimal {
		height: 130px !important;
		border-bottom: none !important;
		outline: none !important;
	}
	
	.header-white-base {
		height: 130px !important;
	}
	
	.header-dark-top {
		height: 93px !important;
	}
	
	#header-menu {
		top: 122px !important;
		position: fixed !important;
		background: var(--color-white) !important;
		box-shadow: none !important;
		border: none !important;
		outline: none !important;
		margin: 0 auto !important;
		padding: 0 !important;
		width: 100vw !important;
		z-index: 100 !important;
		left: 0 !important;
		right: 0 !important;
	}
	#header-menu .navbar {
		justify-content: center !important;
	}
	
	#header-menu .navbar-nav {
		width: 100% !important;
		justify-content: center !important;
		text-align: center !important;
	}
	#header-menu .nav-link::before {
		content: none !important;
		display: none !important;
	}
	
	#header-menu,
	#header-menu .container-xl,
	#header-menu .navbar,
	#header-menu .navbar-nav,
	#header-menu .nav-item {
		pointer-events: auto !important;
		overflow: visible !important;
		touch-action: manipulation !important;
		z-index: 1000 !important;
	}
	
	#header-menu .nav-link {
		pointer-events: auto !important;
		overflow: visible !important;
		position: relative !important;
		cursor: pointer !important;
		-webkit-tap-highlight-color: rgba(12, 50, 74, 0.3);
		touch-action: manipulation !important;
		-webkit-user-select: none;
		user-select: none;
		z-index: 1001 !important;
	}
	
	#header-menu .nav-link .nav-link-title {
		pointer-events: none !important;
		z-index: 1002 !important;
	}
	
	#header-menu .nav-link:active {
		background: var(--color-primary) !important;
		color: var(--color-parchment) !important;
	}
	
	.module-tall,
	.module-medium {
		min-height: auto;
	}
	.hero-fullwidth {
		padding: 200px 0 0 0;
	}
	
	.hero-fullwidth .container-xl {
		min-height: 400px;
		background-position: 70% center;
		padding-bottom: 75px !important;
	}
	.quality-box {
		padding: 1.5rem !important;
		display: grid !important;
		grid-template-columns: 1fr 1fr;
		gap: 2.5rem 2rem !important;
		align-items: center;
		justify-items: center;
	}
	
	.quality-logo {
		max-height: 55px !important;
		max-width: 60px !important;
		height: auto;
		width: auto;
		display: block;
	}
	
	.quality-divider {
		display: none !important;
	}
	.quality-box .row {
		display: contents !important;
		margin: 0 !important;
		gap: 0 !important;
	}
	
	.quality-box .col-auto {
		display: flex !important;
		justify-content: center;
		align-items: center;
		margin: 0 !important;
		padding: 0 !important;
	}
	#logo-container {
		height: 90px !important;
		position: relative;
		backdrop-filter: none !important;
		background: transparent !important;
	}
	#header-top-right {
		position: absolute;
		top: 5px;
		right: 10px;
		font-size: 0.75rem;
	}
	#header-top-right > div:nth-child(2) {
		display: none !important;
	}
	#header-top-right .header-lang-switcher {
		display: none !important;
	}
	#header-top-right .fs-09 {
		font-size: 0.7rem !important;
		margin-right: 0 !important;
	}
	
	#logoSelf {
		position: absolute !important;
		width: 321px !important;
		height: 119px !important;
		background-size: 321px 119px !important;
		left: 50% !important;
		margin-left: -160.5px !important;
		top: 0 !important;
	}
	#logoSelf span {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}
	
	#logo-subtitle {
		position: absolute !important;
		top: 95px !important;
		left: 58% !important;
		transform: translateX(-50%) !important;
		font-size: 1.3rem !important;
		white-space: nowrap;
		text-align: center;
		z-index: 10 !important;
		padding-bottom: 5px;
		border-bottom: none;
	}
	
	.logo-subtitle {
		font-size: 0.5rem;
	}
	
	.logo-reg {
		font-size: 0.7rem;
	}
	.container-xl.spacer {
		margin-top: 70px !important;
	}
	.row.g-3.align-items-center.justify-content-center img {
		height: 60px !important;
	}
	.module-short,
	.module-medium,
	.module-tall {
		margin-left: auto;
		margin-right: auto;
	}
	.modular-grid > * {
		justify-self: center;
	}
}

/* ========================================
   PRODUCT CARDS - Image Height Consistency & Hover Effects
   ======================================== */
.card-img-top {
	height: 240px;
	object-fit: cover;
	object-position: bottom;
}
.product-detail-page .card-img-top {
	object-position: center;
}
.card.card-link:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15) !important;
	transition: transform 0.9s ease, box-shadow 0.2s ease;
}
@media (max-width: 767px) {
	.card-img-top {
		height: 200px;
	}
}

/* ========================================
   TABLER OVERRIDES - Color Classes
   ======================================== */
.bg-primary {
	background-color: var(--color-primary) !important;
	color: var(--color-white) !important;
}

.bg-secondary {
	background-color: var(--color-secondary) !important;
	color: var(--color-primary) !important;
}

.bg-info {
	background-color: var(--color-info) !important;
	color: var(--color-white) !important;
}

.bg-muted {
	background-color: var(--color-light-grey) !important;
	color: var(--color-primary) !important;
}

.bg-warning {
	background-color: var(--color-accent) !important;
	color: var(--color-primary) !important;
}

.bg-danger {
	background-color: var(--color-danger) !important;
	color: var(--color-white) !important;
}

.text-primary {
	color: var(--color-primary) !important;
}

.text-secondary {
	color: var(--color-medium-grey) !important;
}

.text-warning {
	color: var(--color-accent) !important;
}

.text-danger {
	color: var(--color-danger) !important;
}

.text-muted {
	color: var(--color-light-grey) !important;
}

/* ========================================
   SUB-MENU NAVIGATION
   ======================================== */
/* Note: All submenu styles moved to product-page-common.css 
   since submenus are only used on product/service pages */

/* ========================================
   MOBILE MENU
   ======================================== */
.mobile-menu-btn {
	display: none !important;
	position: fixed;
	top: 25px;
	right: 0;
	z-index: 9999;
	align-items: center;
	justify-content: center;
}

.mobile-menu-btn:hover {
	background: var(--color-info);
	transform: scale(1.05);
}

.mobile-menu-btn:active {
	transform: scale(0.95);
}
.mobile-menu-overlay {
	display: none !important;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0);
	z-index: 10000;
	transition: background 0.2s ease;
	pointer-events: none;
}

.mobile-menu-overlay.active {
	background: rgba(0, 0, 0, 0.5);
	pointer-events: auto;
}
.mobile-menu-panel {
	position: fixed;
	top: 0;
	right: -100%;
	width: 300px;
	max-width: 85vw;
	height: 100%;
	background: white;
	box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1);
	transition: right 0.2s ease;
	overflow-y: auto;
	z-index: 10001;
}

.mobile-menu-panel.active {
	right: 0;
}
.mobile-menu-close {
	position: absolute;
	top: 15px;
	right: 15px;
	background: transparent;
	border: none;
	font-size: 2rem;
	color: var(--color-primary);
	cursor: pointer;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 4px;
	transition: background-color 0.2s ease;
}

.mobile-menu-close:hover {
	background: rgba(12, 50, 74, 0.1);
}
.mobile-menu-content {
	padding: 70px 30px 30px;
}
.mobile-menu-logo {
	text-align: center;
	padding-bottom: 30px;
	border-bottom: 2px solid var(--color-light-grey);
	margin-bottom: 30px;
}

.mobile-menu-logo a {
	text-decoration: none;
	color: var(--color-primary);
	font-size: 1.5rem;
	font-weight: 700;
}
.mobile-menu-nav {
	display: flex;
	flex-direction: column;
	gap: 5px;
	margin-bottom: 30px;
}

.mobile-menu-link {
	display: block;
	padding: 15px 20px;
	color: var(--color-primary);
	text-decoration: none;
	font-size: 1.1rem;
	font-weight: 500;
	border-radius: 8px;
	transition: background-color 0.2s ease;
}

.mobile-menu-link:hover {
	background: rgba(12, 50, 74, 0.05);
	padding-left: 25px;
}

.mobile-menu-link.active {
	background: var(--color-primary);
	color: white;
	font-weight: 600;
}
.mobile-menu-submenu {
	margin-top: 0.5rem;
	padding-top: 0.5rem;
	border-top: 1px solid rgba(12, 50, 74, 0.15);
}
.mobile-menu-submenu-title {
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 0.5rem;
	padding-left: 15px;
}
.mobile-menu-submenu-link {
	padding-left: 28px !important;
	font-size: 0.95rem;
}
.mobile-menu-submenu-link.active {
	background: var(--color-primary);
	color: white;
}
.mobile-menu-lang {
	text-align: center;
	padding: 20px 0;
	border-top: 2px solid var(--color-light-grey);
	border-bottom: 2px solid var(--color-light-grey);
	margin-bottom: 20px;
}

.mobile-lang-link {
	text-decoration: none;
	color: var(--color-medium-grey);
	font-size: 0.95rem;
	font-weight: 600;
	padding: 5px 10px;
	transition: color 0.2s ease;
}

.mobile-lang-link.active {
	color: var(--color-primary);
}

.mobile-lang-separator {
	color: var(--color-light-grey);
	padding: 0 5px;
}
.mobile-menu-contact {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.mobile-contact-link {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 15px;
	background: rgba(12, 50, 74, 0.05);
	color: var(--color-primary);
	text-decoration: none;
	border-radius: 8px;
	font-size: 0.9rem;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.mobile-contact-link:hover {
	background: var(--color-primary);
	color: white;
}

.mobile-contact-link i {
	font-size: 1.2rem;
}
@media screen and (max-width: 991px) {
	.mobile-menu-btn {
		display: block !important;
		top: 125px !important;
	}
	
	.mobile-menu-overlay {
		display: block !important;
	}
	#header-menu {
		display: none !important;
	}
	.submenu-container {
		display: none !important;
	}
}

/*
========================================
  PRODUCTS SUBMENU TOGGLE (Global)
========================================
*/
.submenu-container {
	position: fixed !important;
	top: 165px !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	z-index: 999 !important;
}

#submenu-alt-container{
	margin-bottom: 1px;
	border-bottom: 1px solid #f5f5f5;
	border-top: 1px solid #fff;
	background: #fff !important; 
	box-shadow: inset 0 -3px 13px #aaa;
}
.submenu-container .nav-segmented .nav-link.submenu-link{
	border: 1px solid transparent !important;
	font-size: 1rem;
}

.submenu-container .nav-segmented .nav-link.submenu-link:hover {
	background: #f9f9f9 !important; 
	box-shadow: inset 0px 0px 14px #ced6da !important;
	border: 1px solid #8598a4 !important;
	color: var(--color-primary) !important;
}
.submenu-container .nav-link.active,
.submenu-container .nav-link.simple-inner-shadow {
	background: #ced6da !important;
	box-shadow: inset 0px 1px 5px #6d8492 !important;
	border: 1px solid #fff !important;
	color: #3c5a6e !important;
	
}
.submenu-container[style*="display: none"] {
	pointer-events: none;
}
#productsMenuToggle {
	background: none !important;
	border: none !important;
	padding: 0.5rem 1rem !important;
	cursor: pointer !important;
	font: inherit;
	color: inherit;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	position: relative;
	z-index: 1000;
	pointer-events: auto !important;
}

#productsMenuToggle:hover {
	background: rgba(0, 0, 0, 0.02) !important;
}

#productsMenuToggle:focus {
	outline: 2px solid var(--tblr-primary);
	outline-offset: 2px;
}

#productsMenuToggle:active {
	background: rgba(0, 0, 0, 0.05) !important;
}
.products-chevron {
	transition: transform 0.3s ease;
	display: inline-block;
	position: relative;
	z-index: 2;
}

#productsMenuToggle[aria-expanded="true"] .products-chevron {
	transform: rotate(180deg);
}
