/*
 * Clenivax — Navy Blue Palette
 * Deep navy     : #0a1f44
 * Mid navy      : #142d6e
 * Accent blue   : #1e5fa8
 * Highlight     : #2563eb
 * Light bg      : #f4f7fc
 */

/* ════════════════════════════════════════════════
   HERO VIDEO BACKGROUND
   ════════════════════════════════════════════════ */
.home-banner {
    background: none !important;
    overflow: hidden;
    position: relative;
}
.home-banner::before {
    background: linear-gradient(135deg, rgba(10,31,68,0.90) 0%, rgba(20,45,110,0.80) 60%, rgba(30,95,168,0.65) 100%) !important;
    opacity: 1 !important;
    z-index: 1;
}
.hero-video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    object-fit: cover;
    z-index: 0;
}
.home-banner .container {
    position: relative;
    z-index: 2;
}
/* Text in hero → always white */
.banner-left span,
.banner-left h3,
.banner-left p { color: #fff !important; }
.banner-left span {
    background-color: rgba(37,99,235,0.75);
    border-radius: 3px;
    padding: 3px 10px;
}
/* Hero CTA button */
.banner-left a {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #fff !important;
}
.banner-left a:hover {
    background-color: #0a1f44 !important;
    border-color: #0a1f44 !important;
}

/* ════════════════════════════════════════════════
   LOGO IMAGE
   ════════════════════════════════════════════════ */
.clnvx-logo-img {
    height: 54px;
    width: auto;
    display: block;
    background: transparent;
    padding: 0;
}
.clnvx-logo-ftr-img {
    height: 56px;
    margin: 0 auto 16px;
}
@media (max-width: 767px) {
    .clnvx-logo-img { height: 36px; }
}

/* ════════════════════════════════════════════════
   LOGO
   ════════════════════════════════════════════════ */
.clnvx-logo {
    font-family: 'Raleway', sans-serif;
    font-size: 28px;
    font-weight: 900;
    color: #0a1f44;
    letter-spacing: 1px;
    text-decoration: none;
}
.clnvx-logo-ftr {
    font-size: 22px;
    color: #fff !important;
    display: block;
    margin-bottom: 20px;
}
.clnvx-plus {
    color: #2563eb;
    font-size: 1.2em;
    margin-right: 3px;
}
.middle-header .logo-block a { text-decoration: none; }

/* Hero banner text - white on dark background */
.home-banner .clnvx-logo {
    color: #fff !important;
}

/* Footer text - white */
.footer-main .clnvx-logo,
.footer-main .clnvx-logo-ftr {
    color: #fff !important;
}

/* ════════════════════════════════════════════════
   TOP HEADER (dark navy bg)
   ════════════════════════════════════════════════ */
.top-header { background-color: #0a1f44 !important; }
.top-header p, .top-header ul li a { color: #c8d8f0 !important; }
.top-header .col-md-6:last-child > a {
    background-color: #2563eb !important;
    color: #fff !important;
}
.top-header .col-md-6:last-child > a:hover {
    background-color: #142d6e !important;
}

/* ════════════════════════════════════════════════
   MIDDLE HEADER (white bg → dark text)
   ════════════════════════════════════════════════ */
.middle-header { background-color: #fff; }
.middle-header .location h3,
.middle-header .phone h3   { color: #0a1f44 !important; }
.middle-header .location p,
.middle-header .phone p    { color: #444 !important; }

/* ════════════════════════════════════════════════
   NAVIGATION (white bg → blue text)
   ════════════════════════════════════════════════ */
.ow-navigation {
    background-color: #ffffff !important;
    border-color: #e8edf5 !important;
    position: sticky;
    position: -webkit-sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}
.ow-navigation.scrolled {
    background: rgba(255, 255, 255, 0.75) !important;
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.4) !important;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}
.ow-navigation .navbar-toggle {
    border-color: #d0d8e8;
    margin-top: 14px;
}
.ow-navigation .navbar-toggle .icon-bar {
    background-color: #0a1f44;
}
/* Flexbox centering */
.ow-navigation .container-fluid {
    display: flex;
    align-items: center;
    padding-left: 32px;
    padding-right: 32px;
}
.ow-navigation .navbar-header {
    float: none;
    flex-shrink: 0;
}
.ow-navigation .navbar-collapse {
    float: none !important;
    flex: 1;
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 0;
    box-shadow: none !important;
    border: none !important;
    background: transparent !important;
}
.ow-navigation .navbar-collapse * {
    background: transparent;
}
.ow-navigation .navbar-nav {
    float: none !important;
    display: flex !important;
    align-items: center;
    margin: 0;
    background: transparent !important;
}
.ow-navigation .navbar-nav > li {
    float: none;
    background: transparent !important;
}
/* CTA list pushes to far right */
.ow-navigation .nav-cta {
    position: absolute;
    right: 32px;
}
.ow-navigation .navbar-brand {
    padding: 10px 0;
    height: auto;
    display: inline-block;
}
.ow-navigation .navbar-brand .clnvx-logo {
    color: #fff !important;
    font-size: 24px;
}
.ow-navigation .navbar-brand .clnvx-plus {
    color: #2563eb !important;
}
.ow-navigation .navbar-brand:hover .clnvx-logo {
    color: #e0eaff !important;
}
.ow-navigation .navbar-nav > li > a {
    color: #0a1f44 !important;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 8px 16px;
    position: relative;
    transition: color 0.2s ease;
}
.ow-navigation .navbar-nav > li > a::after {
    content: '';
    position: absolute;
    bottom: 4px;
    left: 16px;
    right: 16px;
    height: 2px;
    background: #2563eb;
    border-radius: 2px;
    transform: scaleX(0);
    transition: transform 0.25s ease;
}
.ow-navigation .navbar-nav > .active > a,
.ow-navigation .navbar-nav > .active > a:hover,
.ow-navigation .navbar-nav > .active > a:focus,
.ow-navigation .navbar-nav > li > a:hover,
.ow-navigation .navbar-nav > li > a:focus {
    background-color: transparent !important;
    color: #2563eb !important;
}
.ow-navigation .navbar-nav > li > a:hover::after,
.ow-navigation .navbar-nav > .active > a::after {
    transform: scaleX(1);
}
/* CTA pill button */
.ow-navigation .navbar-nav > li > a.nav-cta-btn {
    color: #fff !important;
}
.nav-cta-btn {
    background-color: #0a1f44 !important;
    color: #fff !important;
    border-radius: 50px !important;
    padding: 8px 24px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.8px !important;
    text-transform: uppercase !important;
    border: 2px solid #0a1f44 !important;
    transition: background 0.2s ease, color 0.2s ease !important;
}
.nav-cta-btn::after { display: none !important; }
.nav-cta-btn:hover {
    background-color: transparent !important;
    color: #0a1f44 !important;
    border-color: #0a1f44 !important;
}

/* ════════════════════════════════════════════════
   FEATURE HIGHLIGHT BOXES (dark navy bg → white text)
   ════════════════════════════════════════════════ */
.message-borad { background-color: #f4f7fc; }
.emargency-case { background-color: #0a1f44 !important; }
.opening-hours  { background-color: #142d6e !important; }
.message-block h3 { color: #fff !important; }
.message-block p  { color: #c8d8f0 !important; }
.message-block a  { color: #7eb8ff !important; }
.message-block a:hover { color: #fff !important; }

/* ════════════════════════════════════════════════
   ABOUT / SERVICE SECTION (white bg → dark text)
   ════════════════════════════════════════════════ */
.service-section { background-color: #fff; }
.service-section .section-header h3 { color: #0a1f44 !important; }
.service-section .section-header p  { color: #333 !important; }
.service-block-content h3 { 
    color: #0a1f44 !important; 
}
.service-block-content h3::before,
.service-block-content h3::after {
    display: none !important;
}
.service-block-content p  { color: #444 !important; }
.service-block-icon { 
    display: inline-block;
    margin-right: 15px;
    vertical-align: top;
}
.service-block-icon i {
    font-size: 48px;
    color: #0a1f44;
}
.service-block {
    display: flex;
    align-items: flex-start;
    gap: 15px;
}
.service-block-content {
    flex: 1;
}

/* Section header underlines */
.section-header h3:before,
.section-header h3:after { background-color: #2563eb !important; }

/* Appointment form (white bg → dark text) */
.appoinment-form { background-color: #f4f7fc !important; }
.appoinment-form h3 { color: #0a1f44 !important; }
.appoinment-form .btn-submit {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #fff !important;
}
.appoinment-form .btn-submit:hover {
    background-color: #0a1f44 !important;
    border-color: #0a1f44 !important;
}

/* ════════════════════════════════════════════════
   CTA CALL-OUT (deep navy bg → white text)
   ════════════════════════════════════════════════ */
.call-out { background-color: #0a1f44 !important; }
.call-out-content h3 { color: #fff !important; }
.call-out-content p  { color: #c8d8f0 !important; }
.call-out-content span { color: #fff !important; }
.call-out-content a {
    background-color: #2563eb !important;
    color: #fff !important;
    border-color: #2563eb !important;
}
.call-out-content a:hover {
    background-color: #fff !important;
    color: #0a1f44 !important;
}

/* ════════════════════════════════════════════════
   PRODUCT BLOCK — LUCIDE SVG ICONS
   ════════════════════════════════════════════════ */
.what-we-do-block-content i {
    display: block;
    margin: 0 auto 10px;
    width: 52px;
    height: 52px;
    line-height: 1;
}
.what-we-do-block-content i svg {
    width: 52px;
    height: 52px;
    color: #2563eb;
    display: block;
}
.what-we-do-block:hover .what-we-do-block-content i svg {
    color: #fff;
}

/* ════════════════════════════════════════════════
   PRODUCTS — WHAT WE DO BEST
   ════════════════════════════════════════════════ */
.what-we-do-block-content h5 { color: #111 !important; }
.what-we-do-block-content p  { color: #333 !important; }
.what-we-do-block:hover .what-we-do-block-content {
    background-color: rgba(10,31,68,0.88) !important;
}
.what-we-do-block:hover .what-we-do-block-content h5,
.what-we-do-block:hover .what-we-do-block-content p { color: #fff !important; }
/* Title block — dark text on light bg */
.what-we-do-title .what-we-do-block-content h3 { color: #0a1f44 !important; }
.what-we-do-title .what-we-do-block-content p  { color: #444 !important; }

/* ════════════════════════════════════════════════
   WHY CLENIVAX — WE ARE BEST (light bg → dark text)
   ════════════════════════════════════════════════ */
.we-are-best { background-color: #f4f7fc !important; }
.we-are-best .section-header h3 { color: #0a1f44 !important; }
.we-are-best .section-header p  { color: #333 !important; }
.we-are-best-block { 
    border-left: 3px solid #2563eb !important; 
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 20px 0;
}
.we-are-best-icon  { 
    display: inline-block;
    min-width: 60px;
}
.we-are-best-icon i {
    font-size: 48px;
    color: #2563eb;
}
.we-are-best-content {
    flex: 1;
}
.we-are-best-content h3 { 
    color: #0a1f44 !important; 
    margin-top: 0;
}
.we-are-best-content h3::before,
.we-are-best-content h3::after {
    display: none !important;
}
.we-are-best-content p  { color: #444 !important; }

/* Accordion / departments */
.departments { background-color: transparent; }
.departments .section-header h3 { color: #111 !important; }
.departments .section-header h3:before,
.departments .section-header h3:after { background-color: #2563eb !important; }
.departments .panel-default { background-color: rgba(255,255,255,0.75); border-color: rgba(0,0,0,0.12); }
.departments .panel-heading { background-color: transparent !important; }
.departments .panel-heading a { color: #111 !important; padding-left: 18px !important; }
.departments .panel-heading a:hover { color: #2563eb !important; }
.departments .panel-body { background-color: rgba(255,255,255,0.6); }
.departments .panel-body p { color: #333 !important; }
.departments .panel-body a { color: #2563eb !important; }

/* ════════════════════════════════════════════════
   STATS COUNTER (dark overlay → white text)
   ════════════════════════════════════════════════ */
.happy-customer h3,
.happy-customer h3.block-title { color: #fff !important; }
.happy-customer p { color: #c8d8f0 !important; }
.happy-customer p span { color: #7eb8ff !important; }
.happy-customer a {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #fff !important;
}
.happy-customer a:hover {
    background-color: #0a1f44 !important;
    border-color: #0a1f44 !important;
}
.statistics-content span { color: #fff !important; }
.statistics-content p    { color: #c8d8f0 !important; }

/* ════════════════════════════════════════════════
   FOOTER (deep navy bg → white text)
   ════════════════════════════════════════════════ */
.footer-main { background-color: #0d2255 !important; }

/* Contact detail boxes */
.contact-details .detail-box             { background-color: #1e5fa8 !important; }
.contact-details .detail-box i           { background-color: #142d6e !important; }
.contact-details .detail-box h4,
.contact-details .detail-box p,
.contact-details .detail-box a          { color: #fff !important; }
.contact-details .detail-box.phone-box  { background-color: #142d6e !important; }
.contact-details .detail-box.phone-box i{ background-color: #0a1f44 !important; }
.contact-details .detail-box.mail-box   { background-color: #0a1f44 !important; }
.contact-details .detail-box.mail-box i { background-color: #071630 !important; }

/* Widget titles and text */
.footer-main .widget-title { color: #fff !important; }
.footer-main .widget-title:before { background-color: #2563eb !important; }
.footer-main .widget-about { text-align: center; }
.footer-main .widget-about p { color: #a8c0e8 !important; }
.footer-main .widget-about .time-schedule { text-align: left; }
.footer-main .widget-about .time-schedule p { color: #a8c0e8 !important; }
.footer-main .widget-about .time-schedule span { color: #fff !important; }
.footer-main .widget-links ul li a { color: #a8c0e8 !important; }
.footer-main .widget-links ul li a:hover { color: #fff !important; }
.footer-main .widget-newsletter p { color: #a8c0e8 !important; }
.footer-main .widget-newsletter .social h6 { color: #a8c0e8 !important; }
.footer-main .widget-newsletter .social ul li a { color: #fff !important; }
.footer-main .widget-newsletter .input-group span button {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #fff !important;
}

/* Bottom footer */
.bottom-footer { background-color: #071630 !important; }
.bottom-footer p, .bottom-footer a { color: #6b8ab8 !important; }
.bottom-footer a:hover { color: #fff !important; }

/* ════════════════════════════════════════════════
   FLOATING WHATSAPP BUTTON
   ════════════════════════════════════════════════ */
.whatsapp-float {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
    z-index: 9998;
    transition: all 0.3s ease;
    text-decoration: none;
}
.whatsapp-float:hover {
    background: linear-gradient(135deg, #128C7E 0%, #075E54 100%);
    transform: scale(1.1);
    box-shadow: 0 6px 30px rgba(37, 211, 102, 0.6);
    color: #fff;
}
.whatsapp-float i {
    line-height: 1;
}

/* Pulse animation */
@keyframes whatsapp-pulse {
    0% {
        box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
    }
    50% {
        box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4), 0 0 0 10px rgba(37, 211, 102, 0.1);
    }
    100% {
        box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
    }
}
.whatsapp-float {
    animation: whatsapp-pulse 2s infinite;
}

/* Mobile responsive */
@media (max-width: 767px) {
    .whatsapp-float {
        width: 50px;
        height: 50px;
        font-size: 26px;
        bottom: 20px;
        right: 20px;
    }
}

/* ════════════════════════════════════════════════
   CATALOG DOWNLOAD SECTION
   ════════════════════════════════════════════════ */
.catalog-download-section {
    background: linear-gradient(135deg, #f4f7fc 0%, #e8f0fc 100%);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
}
.catalog-download-section::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(37,99,235,0.08) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}
.catalog-download-inner {
    position: relative;
    z-index: 1;
}

/* Left column - text content */
.catalog-text-col {
    padding-right: 40px;
}
.catalog-badge {
    display: inline-block;
    background: linear-gradient(135deg, #2563eb 0%, #1e5fa8 100%);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 20px;
    margin-bottom: 20px;
}
.catalog-text-col h2 {
    font-size: 36px;
    color: #0a1f44;
    font-weight: 800;
    margin: 0 0 20px;
    line-height: 1.2;
}
.catalog-text-col h2 span {
    color: #2563eb;
    position: relative;
}
.catalog-text-col > p {
    font-size: 16px;
    color: #444;
    line-height: 1.7;
    margin-bottom: 25px;
}

/* Meta list with icons */
.catalog-meta-list {
    list-style: none;
    padding: 0;
    margin: 0 0 30px;
}
.catalog-meta-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    font-size: 15px;
    color: #333;
    border-bottom: 1px solid rgba(10,31,68,0.08);
}
.catalog-meta-list li:last-child {
    border-bottom: none;
}
.catalog-meta-list li i {
    color: #2563eb;
    font-size: 18px;
    width: 24px;
    text-align: center;
}

/* Action buttons */
.btn-catalog-download,
.btn-catalog-view {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 700;
    border-radius: 6px;
    text-decoration: none;
    transition: all 0.3s ease;
    margin-right: 12px;
    margin-bottom: 10px;
}
.btn-catalog-download {
    background: linear-gradient(135deg, #2563eb 0%, #1e5fa8 100%);
    color: #fff;
    box-shadow: 0 4px 14px rgba(37,99,235,0.3);
}
.btn-catalog-download:hover {
    background: linear-gradient(135deg, #0a1f44 0%, #142d6e 100%);
    box-shadow: 0 6px 20px rgba(10,31,68,0.4);
    transform: translateY(-2px);
    color: #fff;
}
.btn-catalog-view {
    background: #fff;
    color: #2563eb;
    border: 2px solid #2563eb;
}
.btn-catalog-view:hover {
    background: #2563eb;
    color: #fff;
    transform: translateY(-2px);
}

/* Right column - PDF card visual */
.catalog-visual-col {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-left: 40px;
}
.catalog-pdf-card {
    background: #fff;
    border-radius: 12px;
    padding: 40px 30px;
    text-align: center;
    box-shadow: 0 10px 40px rgba(10,31,68,0.12);
    position: relative;
    transition: all 0.3s ease;
    max-width: 280px;
    width: 100%;
}
.catalog-pdf-card::before {
    content: '';
    position: absolute;
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    background: linear-gradient(135deg, #2563eb, #1e5fa8);
    border-radius: 12px;
    z-index: -1;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.catalog-pdf-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(10,31,68,0.2);
}
.catalog-pdf-card:hover::before {
    opacity: 1;
}

.catalog-pdf-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 20px;
    background: linear-gradient(135deg, #2563eb 0%, #1e5fa8 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}
.catalog-pdf-card:hover .catalog-pdf-icon {
    transform: scale(1.1) rotate(5deg);
}
.catalog-pdf-icon i {
    font-size: 36px;
    color: #fff;
}
.catalog-pdf-name {
    font-size: 18px;
    font-weight: 700;
    color: #0a1f44;
    margin: 0 0 8px;
    line-height: 1.3;
}
.catalog-pdf-size {
    display: block;
    font-size: 13px;
    color: #888;
    margin-bottom: 20px;
}
.catalog-pdf-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: #f4f7fc;
    color: #2563eb;
    border-radius: 50%;
    font-size: 20px;
    text-decoration: none;
    transition: all 0.3s ease;
}
.catalog-pdf-btn:hover {
    background: #2563eb;
    color: #fff;
    transform: scale(1.15);
}

/* Responsive */
@media (max-width: 991px) {
    .catalog-text-col,
    .catalog-visual-col {
        width: 100% !important;
        padding-left: 15px;
        padding-right: 15px;
    }
    .catalog-visual-col {
        margin-top: 40px;
    }
}
@media (max-width: 767px) {
    .catalog-download-section {
        padding: 50px 0;
    }
    .catalog-text-col h2 {
        font-size: 28px;
    }
    .btn-catalog-download,
    .btn-catalog-view {
        width: 100%;
        justify-content: center;
        margin-right: 0;
    }
}

/* ════════════════════════════════════════════════
   DETAIL MODAL SYSTEM
   ════════════════════════════════════════════════ */
.clnvx-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
}
.clnvx-modal.is-open { display: flex; }

.clnvx-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(5, 15, 35, 0.72);
    backdrop-filter: blur(4px);
    cursor: pointer;
}
.clnvx-modal-box {
    position: relative;
    background: #fff;
    border-radius: 12px;
    width: 90%;
    max-width: 680px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 24px 80px rgba(0,0,0,0.35);
    animation: modalSlideIn 0.32s cubic-bezier(.4,0,.2,1);
    z-index: 1;
}
@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(28px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.clnvx-modal-close {
    position: absolute;
    top: 16px;
    right: 20px;
    background: none;
    border: none;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    color: #888;
    transition: color 0.2s;
    z-index: 2;
}
.clnvx-modal-close:hover { color: #0a1f44; }

.clnvx-modal-header {
    padding: 28px 36px 18px;
    border-bottom: 2px solid #f0f4fb;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.clnvx-modal-header h2 {
    margin: 0;
    font-size: 22px;
    color: #0a1f44;
    font-weight: 700;
    flex: 1;
}
.clnvx-modal-tag {
    background: #2563eb;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 20px;
    white-space: nowrap;
}
.clnvx-modal-body {
    padding: 24px 36px 32px;
}
.clnvx-modal-body > p { color: #333; font-size: 15px; line-height: 1.7; margin-bottom: 18px; }
.clnvx-modal-body h4 {
    color: #0a1f44;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    margin: 22px 0 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid #e8eef8;
}
.clnvx-modal-body ul { padding-left: 0; list-style: none; margin: 0 0 8px; }
.clnvx-modal-body ul li {
    position: relative;
    padding: 6px 0 6px 20px;
    font-size: 14px;
    color: #444;
    line-height: 1.6;
    border-bottom: 1px solid #f5f7fb;
}
.clnvx-modal-body ul li::before {
    content: '';
    position: absolute;
    left: 0; top: 14px;
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #2563eb;
}
.clnvx-modal-note {
    margin-top: 22px !important;
    font-size: 13px !important;
    color: #888 !important;
    font-style: italic;
    background: #f4f7fc;
    padding: 12px 16px;
    border-radius: 6px;
    border-left: 3px solid #2563eb;
}
.clnvx-modal-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 18px;
    font-weight: 600;
    font-size: 14px;
    color: #2563eb;
    text-decoration: none;
    letter-spacing: 0.02em;
}
.clnvx-modal-link::after {
    content: "\2197";
    font-size: 16px;
}
.clnvx-modal-link:hover {
    color: #0a1f44;
}

/* Details trigger button */
.clnvx-modal-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1.5px solid #2563eb;
    color: #2563eb;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 7px 16px;
    border-radius: 4px;
    cursor: pointer;
    margin-top: 10px;
    transition: background 0.2s, color 0.2s;
}
.clnvx-modal-btn:hover { background: #2563eb; color: #fff; }

/* Mobile adjustments */
@media (max-width: 600px) {
    .clnvx-modal-box { width: 95%; max-height: 90vh; }
    .clnvx-modal-header, .clnvx-modal-body { padding-left: 20px; padding-right: 20px; }
    .clnvx-modal-header h2 { font-size: 18px; }
}

/* ════════════════════════════════════════════════
   SCROLL ANIMATIONS
   ════════════════════════════════════════════════ */

/* Base hidden state — applied by JS before observe */
.clnvx-anim {
    opacity: 0 !important;
    will-change: opacity, transform;
    transition: opacity 0.7s cubic-bezier(.4,0,.2,1),
                transform 0.7s cubic-bezier(.4,0,.2,1);
}
.clnvx-anim.is-visible { opacity: 1 !important; transform: none !important; }

/* Variants */
.clnvx-fade-up    { transform: translateY(45px) !important; }
.clnvx-fade-down  { transform: translateY(-30px) !important; }
.clnvx-fade-left  { transform: translateX(-45px) !important; }
.clnvx-fade-right { transform: translateX(45px) !important; }
.clnvx-zoom-in    { transform: scale(0.86) !important; }

/* Stagger delays */
.clnvx-d1  { transition-delay: 0.05s; }
.clnvx-d2  { transition-delay: 0.12s; }
.clnvx-d3  { transition-delay: 0.20s; }
.clnvx-d4  { transition-delay: 0.28s; }
.clnvx-d5  { transition-delay: 0.36s; }
.clnvx-d6  { transition-delay: 0.44s; }
.clnvx-d7  { transition-delay: 0.52s; }
.clnvx-d8  { transition-delay: 0.60s; }
.clnvx-d9  { transition-delay: 0.68s; }

/* Respect user preference */
@media (prefers-reduced-motion: reduce) {
    .clnvx-anim { transition: none !important; opacity: 1 !important; transform: none !important; }
}

/* ════════════════════════════════════════════════
   RESPONSIVE — TABLET  (768px – 991px)
   ════════════════════════════════════════════════ */
@media (max-width: 991px) {

    /* --- Middle header: stack logo + contacts */
    .middle-header .logo-block,
    .middle-header .col-md-9 { float: none !important; text-align: center !important; width: 100%; }
    .middle-header .location,
    .middle-header .phone { display: inline-block; margin: 10px 15px 0; }

    /* --- Feature boxes: wrap to 2×2 grid */
    .message-borad .row { flex-wrap: wrap; }
    .emargency-case,
    .opening-hours { width: 100% !important; display: flex !important; }

    /* --- Products: hide left photo, grid full-width */
    .what-we-do-left { display: none !important; }
    .what-we-do-right { width: 100% !important; }

    /* --- Why section: stack panels */
    .we-are-best,
    .departments { width: 100% !important; float: none !important; }
    .departments-bg { display: none !important; }

    /* --- Footer contact boxes: 3-col to 1-col */
    .contact-details .detail-box { width: 100% !important; float: none !important; display: block !important; }
}

/* ════════════════════════════════════════════════
   RESPONSIVE — MOBILE  (≤ 767px)
   ════════════════════════════════════════════════ */
@media (max-width: 767px) {

    /* --- Global: prevent horizontal overflow */
    body, .main-container { overflow-x: hidden; }
    img { max-width: 100%; height: auto; }
    * { word-break: break-word; }

    /* --- Top header */
    .top-header .col-md-6 { width: 100%; text-align: center !important; }
    .top-header ul { justify-content: center; display: flex; flex-wrap: wrap; padding: 0; margin: 0 0 8px; }
    .top-header ul li { display: inline-block; }

    /* --- Navbar brand */
    .ow-navigation .navbar-brand { padding: 10px 15px; }
    .ow-navigation .navbar-brand .clnvx-logo { font-size: 20px; }

    /* --- Middle header */
    .middle-header { padding: 15px 0; }
    .middle-header .logo-block,
    .middle-header .col-md-9 { float: none !important; text-align: center !important; width: 100%; padding: 0 15px; }
    .clnvx-logo { font-size: 22px; }
    .middle-header .location,
    .middle-header .phone { display: block; margin: 8px 0 0; }
    .middle-header .location h3,
    .middle-header .phone h3 { font-size: 16px !important; }
    .middle-header .location p,
    .middle-header .phone p { font-size: 12px !important; }

    /* --- Hero */
    .home-banner { min-height: auto !important; }
    .home-banner > .container { padding-top: 50px !important; padding-bottom: 30px !important; }
    .banner-fullwidth,
    .banner-left { max-width: 100% !important; padding: 0 20px !important; }
    .banner-left h3 { font-size: 24px !important; letter-spacing: 0 !important; }
    .banner-left span { font-size: 13px !important; }
    .banner-left p { font-size: 14px !important; line-height: 1.6; }

    /* --- Feature boxes: RESET our flexbox, stack vertically */
    .message-borad .row { display: block !important; }
    .emargency-case,
    .opening-hours {
        display: block !important;
        width: 100% !important;
        padding: 0 !important;
    }
    .message-block {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        float: none !important;
        padding: 30px 25px !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }
    .message-block:nth-child(2) { padding-left: 25px !important; padding-right: 25px !important; }
    .message-borad::before { width: 100%; height: 50%; }

    /* --- About / service section */
    .service-section .service,
    .service-section .col-md-4 { width: 100% !important; float: none !important; padding: 0 15px; }
    .service-block { max-width: 100% !important; margin: 20px 0 !important; }
    .service-block-icon { display: inline-block; vertical-align: middle; margin-right: 12px; }
    .service-block-content { display: inline-block; vertical-align: middle; max-width: calc(100% - 70px); }
    .appoinment-form { margin: 30px 0 0 !important; }

    /* --- CTA call-out */
    .call-out-content .col-md-10,
    .call-out-content .col-md-2 { width: 100% !important; float: none !important; text-align: center; }
    .call-out-content h3 { font-size: 20px !important; }
    .call-out-content .col-md-2 { margin-top: 15px; }

    /* --- Products */
    .what-we-do-best { display: block !important; }
    .what-we-do-left { display: none !important; }
    .what-we-do-right { width: 100% !important; float: none !important; }
    .what-we-do-right .col-xs-6 { width: 50% !important; }
    .what-we-do-block-content h5 { font-size: 12px !important; }
    .what-we-do-block-content p { font-size: 11px !important; line-height: 1.4; }

    /* --- Why Clenivax */
    .we-are-best,
    .departments { width: 100% !important; float: none !important; padding: 20px 15px !important; }
    .departments-bg { display: none !important; }
    .we-are-best-block { margin-bottom: 20px !important; padding: 15px !important; }
    .we-are-best-icon { width: 50px !important; height: 50px !important; min-width: 50px; }
    .we-are-best-content h3 { font-size: 16px !important; }
    .departments .section-header h3 { font-size: 18px !important; }
    .departments .panel-heading a { font-size: 13px !important; }
    .departments .panel-body { padding-left: 15px !important; padding-right: 15px !important; }

    /* --- Counter / Stats */
    .counter-section .col-md-6 { width: 100% !important; float: none !important; }
    .happy-customer { padding: 30px 20px !important; margin-bottom: 0 !important; }
    .happy-customer h3 { font-size: 22px !important; }
    .counter-app .col-md-6 { width: 50% !important; }
    .statistics-box { padding: 20px 10px !important; }
    .statistics-content span { font-size: 26px !important; }
    .statistics-content p { font-size: 11px !important; }

    /* --- Footer */
    .contact-details { display: block !important; }
    .contact-details .detail-box { width: 100% !important; float: none !important; display: block !important; }
    .footer-main .row .col-md-4,
    .footer-main .row .col-sm-6 { width: 100% !important; float: none !important; margin-bottom: 30px; }
    .bottom-footer { text-align: center; padding: 15px !important; }
    .bottom-footer p { font-size: 12px; }

    /* --- Section headers */
    .section-header h3 { font-size: 20px !important; }
    .section-header p { font-size: 14px !important; }
}

/* ════════════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE  (≤ 479px)
   ════════════════════════════════════════════════ */
@media (max-width: 479px) {

    /* Feature boxes: 1 column */
    .emargency-case .col-md-6,
    .opening-hours .col-md-6 { width: 100% !important; float: none !important; }

    /* Products: 1 column */
    .what-we-do-right .col-xs-6 { width: 100% !important; }

    /* Hero text */
    .banner-left h3 { font-size: 20px !important; }
    .home-banner > .container { padding-top: 40px !important; padding-bottom: 25px !important; }

    /* Stats: 1 column */
    .counter-app .col-md-6 { width: 100% !important; float: none !important; }

    /* Top header: hide social icons on very small */
    .top-header ul { display: none; }
    .top-header .col-md-6:last-child > a { font-size: 11px; padding: 5px 10px; }

    /* CTA form selects and inputs */
    .appoinment-form .form-control { font-size: 14px; }
}

/* ════════════════════════════════════════════════
   SCROLL EXPAND HERO
   ════════════════════════════════════════════════ */
.seh-section {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}
.seh-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(135deg, #0a1f44 0%, #142d6e 55%, #1e5fa8 100%);
}
.seh-bg canvas {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
}
.seh-stage {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.seh-media-box {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 300px;
    height: 400px;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 8px 60px rgba(0,0,0,0.45);
    z-index: 1;
}
.seh-inner-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.seh-media-dim {
    position: absolute;
    inset: 0;
    background: rgba(10,31,68,0.45);
    pointer-events: none;
}
.seh-title-row {
    position: relative;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    width: 100%;
    pointer-events: none;
}
.seh-word-left,
.seh-word-right {
    font-family: 'Raleway', sans-serif;
    font-size: clamp(1.8rem, 4vw, 3.2rem);
    font-weight: 900;
    color: #fff;
    letter-spacing: 3px;
    text-transform: uppercase;
    display: inline-block;
    white-space: nowrap;
    text-shadow: 0 2px 24px rgba(0,0,0,0.6);
}
.seh-hint {
    position: absolute;
    bottom: 36px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    z-index: 10;
    pointer-events: none;
    color: rgba(255,255,255,0.75);
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}
.seh-hint p {
    margin: 0;
    font-size: 12px;
    color: rgba(255,255,255,0.45);
    letter-spacing: 2px;
}
.seh-hint .fa {
    font-size: 16px;
    animation: sehBounce 1.4s ease-in-out infinite;
}
@keyframes sehBounce {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(7px); }
}
.seh-full-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    background: linear-gradient(135deg, rgba(10,31,68,0.88) 0%, rgba(20,45,110,0.78) 55%, rgba(30,95,168,0.60) 100%);
    opacity: 0;
    pointer-events: none;
}
.seh-cta {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    z-index: 10;
    width: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.7s ease;
    padding-top: 70px;
}
.seh-cta.visible {
    opacity: 1;
    pointer-events: auto;
}
/* banner-left inside CTA */
.seh-cta .banner-left,
.seh-cta .banner-fullwidth {
    display: block !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    position: static !important;
    width: 100%;
    max-width: 680px;
    text-align: left;
}
.seh-cta .banner-left::before { display: none !important; }

/* ── SEH Mobile ─────────────────────────────── */
@media (max-width: 767px) {
    .seh-section {
        height: 70vh !important;
    }
    .seh-stage {
        height: 70vh !important;
    }
    .seh-media-box {
        width: 220px !important;
        height: 300px !important;
    }
    .seh-title-row {
        flex-direction: column;
        gap: 4px;
    }
    .seh-word-left,
    .seh-word-right {
        font-size: clamp(1.3rem, 7vw, 1.8rem);
        letter-spacing: 2px;
    }
    .seh-hint {
        bottom: 24px;
        font-size: 10px;
    }
    .seh-cta {
        padding-top: 55px;
    }
    .seh-cta .container {
        padding-left: 24px;
        padding-right: 24px;
    }
    .seh-cta .banner-left h3 {
        font-size: 22px !important;
    }
    .seh-cta .banner-left p {
        font-size: 14px !important;
        line-height: 1.6 !important;
    }
    .seh-cta .banner-left a {
        display: block;
        text-align: center;
        margin: 0 auto;
        max-width: 220px;
    }
}

/* ════════════════════════════════════════════════
   FEATURE BOXES — equal height via flexbox
   ════════════════════════════════════════════════ */
.message-borad .row {
    display: flex;
    align-items: stretch;
}
.emargency-case,
.opening-hours {
    display: flex !important;
    align-items: stretch;
    padding-top: 0;
    padding-bottom: 0;
}
.message-block {
    display: flex !important;
    flex-direction: column;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 50px !important;
    padding-bottom: 50px !important;
    box-sizing: border-box;
}
.message-block p {
    flex: 1;
    margin-bottom: 30px !important;
}

/* ════════════════════════════════════════════════
   MEDICOSWAB STYLE PRODUCTS PAGE WITH SIDEBAR
   ════════════════════════════════════════════════ */
.products-catalog-page {
    padding: 40px 0 80px;
    background: #fff;
    position: relative;
    z-index: 10;
}
/* Remove any banner shapes from products page */
.products-catalog-page .banner-shape,
.products-catalog-page .left-shape,
.products-catalog-page .left-shape-blue,
.products-catalog-page .right-shape,
.products-catalog-page .right-shape-blue,
.products-catalog-page [class*="shape"] {
    display: none !important;
}

/* Page Header */
.page-header-section {
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #e8e8e8;
}
.page-header-section h1 {
    font-size: 32px;
    color: #0a1f44;
    margin: 0 0 10px;
    font-weight: 700;
}
.breadcrumb-nav {
    color: #888;
    font-size: 14px;
    margin: 0;
}
.breadcrumb-nav a {
    color: #2563eb;
    text-decoration: none;
}

/* ---- Layout row: flexbox so position:sticky works on sidebar ---- */
.products-layout-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
}
.products-layout-row > [class*="col-"] {
    float: none;
}

/* ---- Sticky sidebar column ---- */
.sidebar-column {
    padding-right: 20px;
    position: -webkit-sticky;
    position: sticky;
    top: 90px;
    -ms-flex-item-align: start;
        align-self: flex-start;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    overflow-x: hidden;
}
/* Hide scrollbar chrome but keep scrollability */
.sidebar-column::-webkit-scrollbar { width: 4px; }
.sidebar-column::-webkit-scrollbar-thumb { background: #d1dae3; border-radius: 2px; }

.category-sidebar {
    background: #fafafa;
    border: 1px solid #e5e5e5;
    border-radius: 4px;
    padding: 0;
    overflow: hidden;
}
.sidebar-section-title {
    background: #0a1f44;
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    margin: 0;
    padding: 15px 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.sidebar-category-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.cat-parent {
    border-bottom: 1px solid #e5e5e5;
}
.cat-parent:last-child {
    border-bottom: none;
}
.cat-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    color: #444;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.2s ease;
    background: #fff;
}
.cat-link:hover {
    background: #f0f4f8;
    color: #0a1f44;
}
.cat-link.has-sub i {
    font-size: 11px;
    color: #999;
    transition: transform 0.25s ease;
}
.cat-link.has-sub[aria-expanded="true"] i {
    transform: rotate(90deg);
}
.cat-parent.active > .cat-link.has-sub i {
    color: #2563eb;
}
.cat-parent.active > .cat-link {
    background: #e8f4fc;
    color: #0a1f44;
    font-weight: 600;
    border-left: 3px solid #2563eb;
}
.sub-cat {
    list-style: none;
    padding: 0;
    margin: 0;
    background: #f5f5f5;
}
.sub-cat li a {
    display: block;
    padding: 10px 20px 10px 35px;
    color: #666;
    font-size: 13px;
    text-decoration: none;
    transition: all 0.2s ease;
    border-left: 3px solid transparent;
}
.sub-cat li a:hover {
    background: #e8f4fc;
    color: #2563eb;
}
.sub-cat li.active-sub a {
    background: #e8f4fc;
    color: #2563eb;
    border-left-color: #2563eb;
    font-weight: 600;
}

/* Product Category Sections — hidden by default, shown via .active */
.product-category-section {
    display: none;
    padding-top: 10px;
}
.product-category-section.active {
    display: block;
    -webkit-animation: sectionFadeIn 0.3s ease;
            animation: sectionFadeIn 0.3s ease;
}
@-webkit-keyframes sectionFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0);   }
}
@keyframes sectionFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0);   }
}
.products-content-area {
    min-height: 600px;
}
.category-header {
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
}
.category-header h2 {
    font-size: 26px;
    color: #0a1f44;
    margin: 0 0 12px;
    font-weight: 700;
}
.category-header .category-desc {
    color: #666;
    font-size: 15px;
    line-height: 1.7;
    margin: 0;
}
.medicoswab-products {
    padding: 40px 0 80px;
    background: #fff;
}
.medicoswab-products .page-title {
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
}
.medicoswab-products .page-title h1 {
    font-size: 32px;
    color: #0a1f44;
    margin: 0 0 10px;
    font-weight: 700;
}
.medicoswab-products .breadcrumb {
    color: #888;
    font-size: 14px;
    margin: 0;
}
.medicoswab-products .breadcrumb a {
    color: #2563eb;
    text-decoration: none;
}

/* Sidebar Styles */
.product-sidebar {
    padding-right: 20px;
}
.sidebar-widget {
    background: #f9f9f9;
    border: 1px solid #e8e8e8;
    border-radius: 4px;
    padding: 20px;
    margin-bottom: 20px;
}
.sidebar-title {
    font-size: 16px;
    font-weight: 700;
    color: #0a1f44;
    margin: 0 0 15px;
    padding-bottom: 12px;
    border-bottom: 2px solid #2563eb;
    text-transform: uppercase;
}
.category-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}
.category-menu li {
    border-bottom: 1px solid #eee;
}
.category-menu li:last-child {
    border-bottom: none;
}
.category-menu .cat-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    color: #555;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.3s ease;
}
.category-menu .cat-link:hover,
.category-menu .cat-link.active {
    color: #2563eb;
}
.category-menu .cat-link i {
    font-size: 10px;
    color: #aaa;
}
.category-menu .has-submenu .submenu {
    list-style: none;
    padding: 0 0 10px 15px;
    margin: 0;
    display: none;
}
.category-menu .has-submenu .submenu.show {
    display: block;
}
.category-menu .has-submenu .submenu li {
    border-bottom: none;
}
.category-menu .has-submenu .submenu a {
    display: block;
    padding: 8px 0;
    color: #777;
    font-size: 13px;
    text-decoration: none;
    transition: all 0.3s ease;
}
.category-menu .has-submenu .submenu a:hover,
.category-menu .has-submenu .submenu li.active a {
    color: #2563eb;
}

/* Product Main Content */
.product-main-content {
    padding-left: 20px;
}
.products-list-header {
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
}
.products-list-header h2 {
    font-size: 24px;
    color: #0a1f44;
    margin: 0 0 10px;
    font-weight: 700;
}
.products-list-header .category-desc {
    color: #666;
    font-size: 14px;
    line-height: 1.7;
    margin: 0;
}

/* Product Grid */
.products-grid-container {
    margin-bottom: 40px;
}
.product-item {
    margin-bottom: 30px;
}
.product-thumb {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 4px;
    overflow: hidden;
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.product-thumb:hover {
    box-shadow: 0 5px 20px rgba(0,0,0,0.1);
    border-color: #2563eb;
}
.product-image-wrapper {
    position: relative;
    background: #f9f9f9;
    padding: 20px;
    text-align: center;
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.product-image-wrapper img {
    max-width: 100%;
    max-height: 160px;
    object-fit: contain;
}
.product-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 4px 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 3px;
    color: #fff;
}
.product-badge.featured {
    background: #2563eb;
}
.product-badge.new {
    background: #22c55e;
}
.product-info {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.product-name {
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
    margin: 0 0 10px;
}
.product-name a {
    color: #0a1f44;
    text-decoration: none;
}
.product-name a:hover {
    color: #2563eb;
}
.product-meta {
    margin-bottom: 12px;
}
.product-meta span {
    display: inline-block;
    font-size: 12px;
    color: #888;
    margin-right: 10px;
}
.product-meta .model {
    color: #2563eb;
    font-weight: 600;
}
.product-desc {
    font-size: 13px;
    color: #666;
    line-height: 1.6;
    margin-bottom: 15px;
    flex: 1;
}
.product-specs-list {
    margin-bottom: 15px;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.spec-item {
    display: inline-block;
    background: #f0f4fc;
    color: #1e5fa8;
    padding: 3px 8px;
    font-size: 11px;
    border-radius: 3px;
}
.btn-enquiry {
    display: inline-block;
    background: #0a1f44;
    color: #fff;
    padding: 8px 20px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 3px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
}
.btn-enquiry:hover {
    background: #2563eb;
    color: #fff;
    text-decoration: none;
}

/* Pagination */
.pagination-wrapper {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid #eee;
}
.pagination {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    gap: 5px;
}
.pagination li a,
.pagination li span {
    display: block;
    padding: 8px 14px;
    border: 1px solid #ddd;
    color: #555;
    font-size: 13px;
    text-decoration: none;
    border-radius: 3px;
    transition: all 0.3s ease;
}
.pagination li a:hover {
    background: #f5f5f5;
    border-color: #2563eb;
    color: #2563eb;
}
.pagination li a.active {
    background: #2563eb;
    border-color: #2563eb;
    color: #fff;
}

/* Responsive */
@media (max-width: 991px) {
    .product-sidebar {
        padding-right: 15px;
        margin-bottom: 30px;
    }
    .product-main-content {
        padding-left: 15px;
    }
    .medicoswab-products .page-title h1 {
        font-size: 26px;
    }
}
@media (max-width: 767px) {
    .product-item {
        margin-bottom: 20px;
    }
    .product-image-wrapper {
        min-height: 160px;
    }
    .sidebar-widget {
        padding: 15px;
    }
}

/* ════════════════════════════════════════════════
   MEDICOSWAB STYLE PRODUCTS SECTION
   ════════════════════════════════════════════════ */
.chg-products-section {
    padding: 80px 0 100px;
    background: #fff;
}
.chg-products-section .section-header h2 {
    color: #0a1f44;
    font-size: 42px;
    font-weight: 700;
    margin-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.chg-products-section .section-subtitle {
    color: #2563eb;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 10px;
}
.chg-products-section .section-description {
    color: #666;
    font-size: 15px;
    line-height: 1.7;
    max-width: 800px;
    margin: 0 auto 40px;
}

/* Category Navigation */
.product-categories-nav {
    margin-bottom: 40px;
    text-align: center;
}
.category-list {
    display: inline-flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
}
.category-item {
    display: inline-block;
    padding: 10px 25px;
    background: #f4f7fc;
    color: #666;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 25px;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.category-item:hover,
.category-item.active {
    background: #2563eb;
    color: #fff;
}

/* Product Cards */
.products-grid {
    margin-bottom: 60px;
}
.product-card {
    margin-bottom: 30px;
}
.product-inner {
    background: #fff;
    border: 1px solid #e8eef8;
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.product-inner:hover {
    box-shadow: 0 15px 40px rgba(10,31,68,0.12);
    transform: translateY(-5px);
    border-color: #2563eb;
}
.product-image {
    position: relative;
    padding: 20px;
    background: #f9fafc;
    text-align: center;
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.product-image img {
    max-width: 100%;
    max-height: 180px;
    object-fit: contain;
}
.product-tag {
    position: absolute;
    top: 15px;
    left: 15px;
    background: #2563eb;
    color: #fff;
    padding: 5px 15px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    border-radius: 3px;
}
.product-tag.new {
    background: #22c55e;
}
.product-content {
    padding: 25px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.product-content h3 {
    font-size: 18px;
    font-weight: 700;
    color: #0a1f44;
    margin-bottom: 12px;
    line-height: 1.4;
}
.product-specs {
    margin-bottom: 12px;
}
.spec-badge {
    display: inline-block;
    background: #e8f4fd;
    color: #1e5fa8;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 3px;
    margin-right: 5px;
    margin-bottom: 5px;
}
.product-short-desc {
    color: #666;
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 15px;
}
.product-features-preview ul {
    padding: 0;
    margin: 0 0 20px 0;
    list-style: none;
}
.product-features-preview li {
    position: relative;
    padding-left: 15px;
    margin-bottom: 6px;
    font-size: 13px;
    color: #555;
    line-height: 1.5;
}
.product-features-preview li:before {
    content: "•";
    color: #2563eb;
    position: absolute;
    left: 0;
    font-weight: bold;
}
.product-enquiry-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #0a1f44;
    color: #fff;
    padding: 12px 20px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 4px;
    margin-top: auto;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.product-enquiry-btn:hover {
    background: #2563eb;
    color: #fff;
    text-decoration: none;
}

/* Application Section */
.application-section {
    margin-bottom: 50px;
}
.application-box {
    background: #f4f7fc;
    padding: 35px 40px;
    border-radius: 8px;
    border-left: 4px solid #2563eb;
}
.application-box h3 {
    color: #0a1f44;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 25px;
    text-transform: uppercase;
}
.application-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.application-list li {
    padding: 8px 0;
    font-size: 14px;
    color: #444;
    display: flex;
    align-items: center;
    gap: 10px;
}
.application-list li i {
    color: #2563eb;
    font-size: 16px;
}

/* Features Section */
.features-section {
    margin-bottom: 50px;
}
.features-section h3 {
    color: #0a1f44;
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 30px;
    text-align: center;
    text-transform: uppercase;
}
.feature-item {
    padding: 25px;
    background: #fff;
    border: 1px solid #e8eef8;
    border-radius: 8px;
    margin-bottom: 20px;
    transition: all 0.3s ease;
}
.feature-item:hover {
    border-color: #2563eb;
    box-shadow: 0 10px 30px rgba(37,99,235,0.1);
}
.feature-item h4 {
    color: #0a1f44;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.feature-item h4 i {
    color: #2563eb;
    font-size: 18px;
    width: 24px;
}
.feature-item p {
    color: #666;
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

/* Precautions Section */
.precautions-section {
    margin-bottom: 40px;
}
.precautions-box {
    background: #fff8e6;
    border: 1px solid #ffd699;
    border-radius: 8px;
    padding: 30px 40px;
}
.precautions-box h3 {
    color: #b8860b;
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.precautions-box h3 i {
    font-size: 22px;
}
.precautions-box ol {
    margin: 0;
    padding-left: 25px;
}
.precautions-box ol li {
    padding: 6px 0;
    font-size: 14px;
    color: #555;
    line-height: 1.5;
}

/* Packaging Section */
.packaging-section {
    margin-bottom: 30px;
}
.packaging-box {
    background: #f4f7fc;
    padding: 25px 35px;
    border-radius: 8px;
}
.packaging-box h3 {
    color: #0a1f44;
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 15px;
}
.pack-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.pack-tag {
    background: #e8f4fd;
    color: #1e5fa8;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 500;
    border-radius: 20px;
}

/* =============================================
   PRODUCT CATALOG CARD STYLES (products.html)
   ============================================= */

/* ---- Grid row: flexbox override (Bootstrap 3 uses floats) ---- */
.products-grid-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 10px;
}
/* Disable float on Bootstrap columns so flexbox takes over */
.products-grid-row > [class*="col-"] {
    float: none;
}

/* ---- Column wrapper: flex column so inner card can stretch ---- */
.product-card-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 24px;
}

/* ---- Card container ---- */
.product-card-wrap {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    overflow: hidden;
    transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    box-shadow: 0 2px 8px rgba(10,31,68,0.07);
}
.product-card-wrap:hover {
    box-shadow: 0 12px 34px rgba(10,31,68,0.15);
    transform: translateY(-5px);
    border-color: #2563eb;
}

/* ---- Image box: fixed 180px height, perfectly contained ---- */
.product-img-box {
    position: relative;
    background: #f8fafc;
    height: 180px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    overflow: hidden;
    border-bottom: 1px solid #edf2f7;
}
.product-img-box a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 100%;
    padding: 14px;
}
.product-img-box img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: transform 0.3s ease;
}
.product-card-wrap:hover .product-img-box img {
    transform: scale(1.06);
}

/* ---- Badges ---- */
.badge-featured,
.badge-new {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 3px 9px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    border-radius: 3px;
    letter-spacing: 0.5px;
    z-index: 2;
    line-height: 1.6;
}
.badge-featured { background: #2563eb; color: #fff; }
.badge-new      { background: #16a34a; color: #fff; }

/* ---- Info box: flex column, fills remaining card space ---- */
.product-info-box {
    padding: 16px 18px 18px;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

/* ---- Product title: 2-line clamp ---- */
.product-title {
    font-size: 14px;
    font-weight: 700;
    color: #0a1f44;
    margin: 0 0 8px 0;
    line-height: 1.45;
    min-height: calc(1.45em * 2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
            line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.product-title a {
    color: #0a1f44;
    text-decoration: none;
}
.product-title a:hover { color: #2563eb; }

/* ---- Attributes ---- */
.product-attributes {
    font-size: 12px;
    color: #556;
    margin-bottom: 3px;
    line-height: 1.5;
}
.attr-label {
    font-weight: 700;
    color: #1e3a5f;
    margin-right: 3px;
}

/* ---- Description: 3-line clamp, fills flex space above button ---- */
.product-desc-short {
    font-size: 12px;
    color: #666;
    line-height: 1.6;
    margin: 8px 0 10px;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
            line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(1.6em * 3);
}

/* ---- Tags ---- */
.product-tags {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 12px;
}
.tag {
    background: #e8f2ff;
    color: #1e5fa8;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    white-space: nowrap;
}

/* ---- Enquiry button: full-width, always pinned to card bottom ---- */
.btn-enquiry {
    display: block;
    width: 100%;
    background: #0a1f44;
    color: #fff;
    text-align: center;
    padding: 12px 20px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 4px;
    text-decoration: none;
    transition: all 0.3s ease;
    margin-top: auto;
    border: none;
    cursor: pointer;
    font-family: inherit;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.btn-enquiry:hover {
    background: #2563eb;
    color: #fff;
    text-decoration: none;
}

/* ---- Category section header: accent border-left + tinted bg ---- */
.category-header {
    margin-bottom: 24px;
    padding: 16px 20px;
    border-left: 4px solid #2563eb;
    background: linear-gradient(135deg, #f0f5ff 0%, #f8fafc 100%);
    border-radius: 0 8px 8px 0;
}
.category-header h2 {
    font-size: 21px;
    font-weight: 800;
    color: #0a1f44;
    margin: 0 0 4px 0;
    line-height: 1.3;
}
.category-desc {
    font-size: 13px;
    color: #5a6a85;
    line-height: 1.6;
    margin: 0;
}

/* ---- "Image Coming Soon" placeholder ---- */
.product-img-box.img-coming-soon {
    background: #f0f4f8;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
}
.product-img-box.img-coming-soon::before {
    content: "\f030";
    font-family: FontAwesome;
    font-size: 34px;
    color: #c5d2e0;
}
.product-img-box.img-coming-soon::after {
    content: "Image Coming Soon";
    font-size: 10px;
    color: #9ab0c3;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.product-img-box.img-coming-soon a,
.product-img-box.img-coming-soon img {
    display: none;
}

/* ---- Responsive ---- */
@media (max-width: 991px) {
    .product-title { font-size: 13px; }
    .product-img-box { height: 160px; }
}
@media (max-width: 767px) {
    .product-card-item { margin-bottom: 16px; }
    .product-img-box   { height: 150px; }
    .category-header   { padding: 14px 16px; }
    .category-header h2 { font-size: 17px; }
    .products-content-area { min-height: 400px; }
}

/* Mobile Responsive */
@media (max-width: 991px) {
    .chg-products-section {
        padding: 60px 0 80px;
    }
    .chg-products-section .section-header h2 {
        font-size: 32px;
    }
    .application-box {
        padding: 25px;
    }
    .precautions-box {
        padding: 25px;
    }
}
@media (max-width: 767px) {
    .product-card {
        margin-bottom: 20px;
    }
    .category-item {
        padding: 8px 18px;
        font-size: 12px;
    }
    .features-section h3 {
        font-size: 22px;
    }
    .feature-item {
        padding: 20px;
    }
}
