/* @import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=Playfair+Display:wght@700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Google+Sans+Flex:opsz,wght@6..144,1..1000&family=Google+Sans:ital,opsz,wght@0,17..18,400..700;1,17..18,400..700&family=Manrope:wght@200..800&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap'); */

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-ExtraLight.woff2') format('woff2'), url('../fonts/PlusJakartaSans-ExtraLight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-ExtraLightItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-ExtraLightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-Italic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-Light.woff2') format('woff2'), url('../fonts/PlusJakartaSans-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-LightItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-Medium.woff2') format('woff2'), url('../fonts/PlusJakartaSans-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-MediumItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-Regular.woff2') format('woff2'), url('../fonts/PlusJakartaSans-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-SemiBold.woff2') format('woff2'), url('../fonts/PlusJakartaSans-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-SemiBoldItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-SemiBoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-Bold.woff2') format('woff2'), url('../fonts/PlusJakartaSans-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-BoldItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-ExtraBold.woff2') format('woff2'), url('../fonts/PlusJakartaSans-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Plus Jakarta Sans';
    src: url('../fonts/PlusJakartaSans-ExtraBoldItalic.woff2') format('woff2'), url('../fonts/PlusJakartaSans-ExtraBoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}


/* ─── Variables ──────────────────────────────────────────── */

:root {
    --red: #ed1c24;
    --red-dark: #c0101a;
    --red-mid: #d41920;
    --red-glow: rgba(237, 28, 36, 0.18);
    --dark: #1e1917;
    --dark2: #2d2420;
    --charcoal: #3a3330;
    --text: #4a4a4a;
    --muted: #212121;
    --silver: #d7d9db;
    /* --light: #f7f7f8; */
    --light: #f6f6f6;
    --lighter: #fafafa;
    --white: #ffffff;
    --border: #ebebeb;
    --border-dark: #dedede;
    --shadow-xs: 0 1px 4px rgba(0, 0, 0, .06);
    --shadow-sm: 0 4px 16px rgba(0, 0, 0, .08);
    --shadow-md: 0 8px 32px rgba(0, 0, 0, .11);
    --shadow-lg: 0 20px 60px rgba(0, 0, 0, .14);
    --shadow-red: 0 8px 28px rgba(237, 28, 36, .28);
    --radius-sm: 6px;
    --radius: 10px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --ease: cubic-bezier(.4, 0, .2, 1);
    --dur: .3s;
}


/* ─── Reset ──────────────────────────────────────────────── */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
    overflow-x: hidden;
    /* outer guard — also keeps position:sticky working on iOS */
}

body {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 15px;
    color: var(--text);
    background: var(--white);
    line-height: 1.75;
    -webkit-font-smoothing: antialiased;
    overflow-x: clip;
    /* clips horizontal bleed without creating a scroll container (sticky stays intact) */
}

a {
    text-decoration: none;
    color: inherit;
    transition: color var(--dur) var(--ease);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

button {
    cursor: pointer;
    font-family: inherit;
}


/* ─── Typography ─────────────────────────────────────────── */

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--dark);
    font-weight: 700;
    line-height: 1.2;
}

h1 {
    font-size: clamp(2.2rem, 5vw, 3.6rem);
}

h2 {
    font-size: clamp(1.7rem, 3.5vw, 2.6rem);
}

h3 {
    font-size: clamp(1.2rem, 2.2vw, 1.6rem);
}

.display-serif {
    font-family: 'Playfair Display', serif;
    font-weight: 800;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 14px;
}

.eyebrow::before {
    content: '';
    display: block;
    width: 28px;
    height: 2px;
    background: var(--red);
    border-radius: 2px;
}

.section-title {
    font-size: clamp(1.7rem, 3vw, 2.5rem);
    font-weight: 700;
    color: var(--dark);
    line-height: 1.2;
    margin-bottom: 1rem;
}

.section-title em {
    font-style: normal;
    color: var(--red);
}

.section-sub {
    font-size: 1rem;
    color: var(--muted);
    line-height: 1.8;
    max-width: 640px;
}


/* ─── Utility ────────────────────────────────────────────── */

.section-pad {
    padding: 100px 0;
}

.section-pad-sm {
    padding: 68px 0;
}

.section-pad-lg {
    padding: 130px 0;
}

.bg-light {
    background: var(--light);
}

.bg-dark {
    background: var(--dark);
}

.bg-red {
    background: var(--red);
}


/* Pill tag */

.tag {
    display: inline-block;
    font-size: .72rem;
    font-weight: 500;
    padding: 4px 13px;
    border-radius: 50px;
    border: 1.5px solid var(--border);
    color: #000000e3;
    background: var(--white);
    transition: all var(--dur) var(--ease);
}

.tag:hover {
    border-color: var(--red);
    color: var(--red);
    background: #fff5f5;
}


/* ─── Scroll Reveal ──────────────────────────────────────── */

.reveal {
    opacity: 0;
    transform: translateY(36px);
    transition: opacity .65s var(--ease), transform .65s var(--ease);
}

.reveal.in {
    opacity: 1;
    transform: translateY(0);
}

.reveal-left {
    opacity: 0;
    transform: translateX(-40px);
    transition: opacity .65s var(--ease), transform .65s var(--ease);
}

.reveal-left.in {
    opacity: 1;
    transform: translateX(0);
}

.reveal-right {
    opacity: 0;
    transform: translateX(40px);
    transition: opacity .65s var(--ease), transform .65s var(--ease);
}

.reveal-right.in {
    opacity: 1;
    transform: translateX(0);
}

.reveal-scale {
    opacity: 0;
    transform: scale(.92);
    transition: opacity .65s var(--ease), transform .65s var(--ease);
}

.reveal-scale.in {
    opacity: 1;
    transform: scale(1);
}


/* ─── BUTTONS ────────────────────────────────────────────── */

.btn-red {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--red);
    color: var(--white);
    font-size: .875rem;
    font-weight: 600;
    padding: 13px 30px;
    border-radius: var(--radius);
    border: 2px solid var(--red);
    letter-spacing: .2px;
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-red:hover {
    background: #ed1c24;
    border-color: #ed1c24;
    color: var(--white);
    transform: translateY(-2px);
}

.btn-red-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--red);
    font-size: .875rem;
    font-weight: 600;
    padding: 12px 28px;
    border-radius: var(--radius);
    border: 2px solid var(--red);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-red-outline:hover {
    background: var(--red);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: var(--shadow-red);
}

.btn-white {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--white);
    color: var(--red);
    font-size: .875rem;
    font-weight: 700;
    padding: 13px 30px;
    border-radius: var(--radius);
    border: 2px solid var(--white);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-white:hover {
    background: transparent;
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(255, 255, 255, .18);
}

.btn-white-ghost {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, .08);
    color: var(--white);
    font-size: .875rem;
    font-weight: 600;
    padding: 12px 28px;
    border-radius: var(--radius);
    border: 2px solid rgba(255, 255, 255, .35);
    backdrop-filter: blur(8px);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-white-ghost:hover {
    background: var(--white);
    color: var(--red);
    border-color: var(--white);
}

.btn-dark {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--dark);
    color: var(--white);
    font-size: .875rem;
    font-weight: 600;
    padding: 13px 30px;
    border-radius: var(--radius);
    border: 2px solid var(--dark);
    transition: all var(--dur) var(--ease);
}

.btn-dark:hover {
    background: var(--charcoal);
    border-color: var(--charcoal);
    color: var(--white);
    transform: translateY(-2px);
}

.btn-lg {
    padding: 15px 36px !important;
    font-size: .95rem !important;
}

.btn-sm {
    padding: 9px 20px !important;
    font-size: .8rem !important;
}


/* ─── TOP BAR ────────────────────────────────────────────── */

.top-bar {
    background: linear-gradient(to right, #0d0908 0%, #180d0d 60%, #1a0e0f 100%);
    padding: 0;
    font-size: .74rem;
    border-bottom: 1px solid rgba(255, 255, 255, .05);
    position: relative;
}


/* 2px red accent line at very top */

.top-bar::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(to right, var(--red) 0%, var(--red-mid) 40%, rgba(237, 28, 36, 0) 100%);
}

.top-bar .container-fluid {
    padding-top: 7px;
    padding-bottom: 7px;
}

.top-bar-link {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: rgba(255, 255, 255);
    margin-right: 0;
    padding: 0 14px 0 0;
    border-right: 1px solid rgba(255, 255, 255, .08);
    margin-right: 14px;
    transition: color var(--dur);
    text-decoration: none;
    font-weight: 500;
    letter-spacing: .1px;
}

.top-bar-link:last-child {
    border-right: none;
    margin-right: 0;
}

.top-bar-link:hover {
    color: var(--white);
}

.top-bar-link i {
    color: var(--red);
    font-size: .72rem;
}


/* Certified strip on the right */

.top-bar-cert {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
    color: rgba(255, 255, 255);
    margin-right: 16px;
}

.top-bar-cert i {
    color: rgba(237, 28, 36);
}

.top-social-ico {
    width: 26px;
    height: 26px;
    line-height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255);
    color: rgba(255, 255, 255);
    font-size: .65rem;
    transition: all var(--dur);
    text-decoration: none;
}

.top-social-ico:hover {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
    transform: translateY(-1px);
}


/* ─── HEADER ─────────────────────────────────────────────── */

.site-header {
    background: var(--white);
    position: sticky;
    top: 0;
    z-index: 1040;
    border-bottom: 1px solid rgba(0, 0, 0, .06);
    transition: box-shadow .3s var(--ease), background .3s, border-color .3s;
}


/* Scrolled: frosted glass + stronger shadow + red bottom line */

.site-header.scrolled {
    background: rgba(255, 255, 255, .96);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 6px 32px rgba(0, 0, 0, .10), 0 1px 0 rgba(237, 28, 36, .18);
    border-bottom-color: transparent;
}


/* Navbar height: 78px on desktop */

.navbar {
    padding: 0;
    min-height: 78px;
}

.navbar-collapse {
    align-items: center;
}


/* Brand */

.navbar-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px 0 10px 0;
    min-height: 78px;
    text-decoration: none;
    line-height: 1;
    position: relative;
    padding-left: 14px;
}


/* Red left accent line on brand */


/* .navbar-brand::before {
    content: '';
    position: absolute;
    left: 0;
    top: 18px;
    bottom: 18px;
    width: 3px;
    background: linear-gradient(to bottom, var(--red), var(--red-mid));
    border-radius: 3px;
} */

.navbar-brand img {
    height: 46px;
    width: auto;
    display: block;
}


/* Hide fallback by default; onerror JS shows it */

.brand-fallback {
    display: none;
    align-items: center;
    gap: 2px;
    font-size: 1.3rem;
    font-weight: 900;
    letter-spacing: -.5px;
}

.brand-fallback .bf-red {
    color: var(--red);
}

.brand-fallback .bf-dark {
    color: var(--dark);
}

.brand-tagline {
    display: block;
    font-size: .54rem;
    color: #000000;
    letter-spacing: .4px;
    margin-top: 4px;
    font-style: italic;
    white-space: nowrap;
    opacity: 1;
}


/* ─── DESKTOP NAV LINKS ──────────────────────────────────── */

.navbar-nav {
    align-items: center;
}

.navbar-nav>.nav-item>.nav-link,
.navbar-nav>.nav-item>.mega-trigger {
    font-size: .85rem;
    font-weight: 600;
    color: #2a2020 !important;
    padding: 0 26px !important;
    height: 78px;
    display: flex !important;
    align-items: center;
    position: relative;
    letter-spacing: .1px;
    transition: color .2s;
    cursor: pointer;
    white-space: nowrap;
    background: none;
    border: none;
    outline: none;
}


/* Red bottom indicator on hover / active */

.navbar-nav>.nav-item>.nav-link::after,
.navbar-nav>.nav-item>.mega-trigger::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 10px;
    right: 10px;
    height: 3px;
    background: linear-gradient(to right, var(--red), var(--red-mid));
    border-radius: 3px 3px 0 0;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .24s var(--ease);
}

.navbar-nav>.nav-item>.nav-link:hover,
.navbar-nav>.nav-item>.mega-trigger:hover,
.navbar-nav>.nav-item>.nav-link.active,
.navbar-nav>.nav-item>.mega-trigger.active {
    color: var(--red) !important;
}

.navbar-nav>.nav-item>.nav-link:hover::after,
.navbar-nav>.nav-item>.mega-trigger:hover::after,
.navbar-nav>.nav-item>.nav-link.active::after,
.navbar-nav>.nav-item>.mega-trigger.active::after {
    transform: scaleX(1);
}

.mega-arrow,
.nav-arrow {
    font-size: .55rem;
    opacity: .45;
    margin-left: 5px;
    transition: transform .22s, opacity .22s;
}

/* Products mega menu — arrow states */
.mega-trigger:hover .mega-arrow,
.mega-trigger.open .mega-arrow {
    opacity: .8;
}

.mega-trigger.open .mega-arrow {
    transform: rotate(180deg);
}

/* Bootstrap dropdown items — arrow on hover / open */
.navbar-nav .nav-item.dropdown:hover .nav-arrow,
.navbar-nav .nav-item.dropdown.show  .nav-arrow {
    opacity: .8;
    transform: rotate(180deg);
}


/* ─── CONTACT US NAV BUTTON ──────────────────────────────── */


/* Lives in its own li; not a nav-link — no height:72px */

.nav-cta-wrap {
    display: flex;
    align-items: center;
    padding-left: 10px;
}

.btn-nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #ed1c24;
    color: var(--white) !important;
    font-size: .82rem;
    font-weight: 700;
    padding: 11px 22px;
    border-radius: 9px;
    text-decoration: none;
    white-space: nowrap;
    transition: all .24s var(--ease);
    letter-spacing: .1px;
    position: relative;
    overflow: hidden;
}

.btn-nav-cta::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0);
    transition: background .2s;
}

.btn-nav-cta:hover {
    color: var(--white) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 26px rgba(237, 28, 36, .48);
}

.btn-nav-cta:hover::after {
    background: rgba(255, 255, 255, .07);
}

.btn-nav-cta i {
    font-size: .78rem;
}


/* Keep old .nav-cta for backwards compat */

.nav-cta {
    background: var(--red) !important;
    color: var(--white) !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    font-size: .815rem !important;
    font-weight: 700 !important;
    height: auto !important;
    min-height: unset !important;
    box-shadow: 0 3px 14px rgba(237, 28, 36, .3);
    transition: all .22s var(--ease) !important;
    align-self: center !important;
}

.nav-item.nav-cta-item {
    display: flex;
    align-items: center;
}

.nav-cta::after {
    display: none !important;
}

.nav-cta:hover {
    background: var(--red-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 22px rgba(237, 28, 36, .42) !important;
    color: var(--white) !important;
}


/* ─── DROPDOWN MENUS ─────────────────────────────────────── */

.dd-menu {
    border: none;
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .14), 0 0 0 1px rgba(0, 0, 0, .05);
    padding: 8px 6px;
    min-width: 230px;
    margin-top: 0 !important;
    border-top: 3px solid var(--red);
    animation: ddSlide .18s var(--ease);
    overflow: hidden;
}

@keyframes ddSlide {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes menuDrop {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.dropdown-menu {
    animation: ddSlide .18s var(--ease);
}

.dropdown-item {
    font-size: .825rem;
    font-weight: 600;
    color: #2a2020;
    padding: 9px 14px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 11px;
    transition: all .2s;
    position: relative;
}

.dropdown-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 3px;
    background: var(--red);
    border-radius: 0 3px 3px 0;
    transform: scaleY(0);
    transition: transform .2s;
}

.dropdown-item i {
    width: 30px;
    height: 30px;
    background: rgba(237, 28, 36, .07);
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .78rem;
    flex-shrink: 0;
    transition: background .2s;
}

.dropdown-item:hover {
    background: #fff3f3;
    color: var(--red);
    padding-left: 18px;
}

.dropdown-item:hover::before {
    transform: scaleY(1);
}

.dropdown-item:hover i {
    background: rgba(237, 28, 36, .14);
}

.dropdown-divider {
    border-color: var(--border);
    margin: 4px 8px;
}


/* ─── MEGA MENU ──────────────────────────────────────────── */

.mega-dropdown {
    position: static !important;
}

.mega-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--white);
    box-shadow: 0 24px 64px rgba(0, 0, 0, .15), 0 0 0 1px rgba(0, 0, 0, .05);
    border-top: 3px solid var(--red);
    border-radius: 0 0 18px 18px;
    display: none;
    z-index: 1050;
    overflow: hidden;
    animation: ddSlide .22s var(--ease);
}

.mega-menu.show,
.mega-menu.open {
    display: flex;
}


/* ── Dark left panel ── */

.mega-panel {
    width: 240px;
    flex-shrink: 0;
    background: linear-gradient(135deg, #fff5f5, #ffe8e8);
    padding: 30px 22px;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

.mega-panel::before {
    content: '';
    position: absolute;
    bottom: -60px;
    right: -60px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(237, 28, 36, .14) 0%, transparent 70%);
    pointer-events: none;
}

.mega-panel-ico {
    width: 52px;
    height: 52px;
    background: rgba(237, 28, 36, .16);
    border-radius: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.4rem;
    margin-bottom: 16px;
    position: relative;
    z-index: 1;
}

.mega-panel-title {
    font-size: .95rem;
    font-weight: 800;
    color: #ec1b23;
    margin-bottom: 5px;
    position: relative;
    z-index: 1;
}

.mega-panel-sub {
    font-size: .73rem;
    color: rgb(0 0 0);
    line-height: 1.55;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.mega-panel-divider {
    border: none;
    border-top: 1px solid rgba(0, 0, 0);
    margin: 16px 0;
    position: relative;
    z-index: 1;
}

.mega-panel-link {
    display: flex;
    align-items: center;
    gap: 10px;
    color: rgb(0 0 0);
    font-size: .8rem;
    font-weight: 500;
    padding: 8px 0;
    text-decoration: none;
    border-bottom: 1px solid rgba(0, 0, 0, .07);
    transition: color .2s, padding-left .2s;
    position: relative;
    z-index: 1;
}

.mega-panel-link:last-of-type {
    border-bottom: none;
}

.mega-panel-link i {
    width: 28px;
    height: 28px;
    background: rgba(237, 28, 36, .12);
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .72rem;
    flex-shrink: 0;
}

.mega-panel-link:hover {
    color: #000000;
    padding-left: 4px;
}

.mega-panel-cta {
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #ed1c24;
    color: var(--white) !important;
    font-size: .78rem;
    font-weight: 700;
    padding: 11px 16px;
    border-radius: 9px;
    text-decoration: none;
    transition: opacity .2s, transform .2s;
    position: relative;
    z-index: 1;
}

.mega-panel-cta:hover {
    opacity: .9;
    transform: translateY(-1px);
}


/* ── Columns area ── */

.mega-cols-wrap {
    flex: 1;
    display: flex;
    padding: 24px 16px 24px 0;
    gap: 0;
}

.mega-col {
    flex: 1;
    padding: 0 20px;
    border-right: 1px solid var(--border);
}

.mega-col:last-child {
    border-right: none;
}

.mega-col-head {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--dark);
    padding-bottom: 10px;
    border-bottom: 2px solid var(--border);
    margin-bottom: 8px;
}

.mega-col-ico {
    width: 24px;
    height: 24px;
    background: rgba(237, 28, 36, .1);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .68rem;
    flex-shrink: 0;
}

.mega-col-ico.nutra {
    background: rgba(39, 174, 96, .1);
    color: #1a7a30;
}

.mega-col-ico.cosm {
    background: rgba(142, 68, 173, .1);
    color: #6a20c8;
}


/* Links */

.mega-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mega-links li a {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .815rem;
    font-weight: 500;
    color: #3a2828;
    padding: 6px 8px;
    border-radius: 7px;
    text-decoration: none;
    transition: all .18s;
}

.mega-links li a::before {
    content: '';
    width: 5px;
    height: 5px;
    background: var(--border-dark);
    border-radius: 50%;
    flex-shrink: 0;
    transition: background .18s, transform .18s;
}

.mega-links li a:hover {
    color: var(--red);
    background: rgba(237, 28, 36, .05);
}

.mega-links li a:hover::before {
    background: var(--red);
    transform: scale(1.4);
}

.mega-view-all {
    font-weight: 700 !important;
    color: var(--red) !important;
    font-size: .78rem !important;
    margin-top: 2px;
}

.mega-view-all::before {
    display: none !important;
}

.mega-view-all i {
    font-size: .62rem;
    margin-left: 3px;
}


/* Export promo */

.mega-promo {
    background: linear-gradient(135deg, #fff5f5, #ffe8e8);
    border: 1px solid rgba(237, 28, 36, .18);
    border-radius: 11px;
    padding: 14px;
    margin-top: 12px;
}

.mega-promo-badge {
    display: inline-block;
    font-size: .64rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--red);
    background: rgba(237, 28, 36, .1);
    padding: 3px 10px;
    border-radius: 50px;
    margin-bottom: 7px;
}

.mega-promo p {
    font-size: .74rem;
    color: var(--muted);
    margin-bottom: 8px;
}

.mega-promo a {
    font-size: .78rem;
    font-weight: 700;
    color: var(--red);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: gap .2s;
}

.mega-promo a:hover {
    gap: 9px;
}


/* ─── HAMBURGER BUTTON ───────────────────────────────────── */

.ham-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 42px;
    height: 42px;
    background: var(--white);
    border: 1.5px solid rgba(0, 0, 0, .1);
    border-radius: 10px;
    padding: 10px 9px;
    cursor: pointer;
    transition: all .22s;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .06);
}

.ham-btn span {
    display: block;
    height: 2px;
    border-radius: 2px;
    background: #2a2020;
    transition: all .22s;
}

.ham-btn span:nth-child(2) {
    width: 70%;
}

.ham-btn:hover {
    border-color: var(--red);
    background: #fff4f4;
    box-shadow: 0 3px 12px rgba(237, 28, 36, .15);
}

.ham-btn:hover span {
    background: var(--red);
}

.ham-btn:hover span:nth-child(2) {
    width: 100%;
}


/* Mobile icon buttons */

.mob-icon-btn {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: 1.5px solid rgba(0, 0, 0, .1);
    color: var(--charcoal);
    font-size: .88rem;
    text-decoration: none;
    transition: all .22s;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .06);
}

.mob-icon-btn:hover {
    border-color: var(--red);
    color: var(--red);
    background: #fff4f4;
}

.mob-wa {
    border-color: rgba(37, 211, 102, .4);
    color: #25d366 !important;
}

.mob-wa:hover {
    background: #25d366 !important;
    color: #fff !important;
    border-color: #25d366 !important;
}


/* ─── OFFCANVAS MOBILE SIDEBAR ───────────────────────────── */

.nav-offcanvas {
    width: 320px !important;
    border-right: none !important;
    box-shadow: 6px 0 40px rgba(0, 0, 0, .18) !important;
}


/* Offcanvas header — rich gradient */

.nav-oc-header {
    background: #f6f6f6;
    padding: 18px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    /* never compress header */
}

.nav-oc-header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(to right, var(--red) 0%, rgba(237, 28, 36, 0) 100%);
}

.nav-oc-close {
    width: 34px;
    height: 34px;
    background: rgba(255, 255, 255, .07);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 8px;
    color: rgba(255, 255, 255, .65);
    font-size: .9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all .2s;
}

.nav-oc-close:hover {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
}

.nav-oc-body {
    padding: 0;
    display: flex;
    flex-direction: column;
    flex: 1;
    /* fill remaining height after header */
    overflow-y: auto;
    /* body itself is the scroll container */
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    /* smooth iOS momentum scroll */
    min-height: 0;
}


/* Mobile nav list */

.mob-nav {
    padding: 8px 0;
}

.mob-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 20px;
    font-size: .875rem;
    font-weight: 700;
    color: #2a1f1f;
    text-decoration: none;
    border-bottom: 1px solid var(--border);
    transition: all .18s;
    background: none;
    border-left: 3px solid transparent;
    border-right: none;
    border-top: none;
    width: 100%;
    text-align: left;
    cursor: pointer;
}

.mob-nav-link>span {
    display: flex;
    align-items: center;
    gap: 11px;
}

.mob-nav-link i:first-child {
    width: 30px;
    height: 30px;
    background: rgba(237, 28, 36, .08);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .82rem;
    flex-shrink: 0;
}

.mob-nav-link:hover,
.mob-nav-link.active {
    color: var(--red);
    background: #fff4f4;
    border-left-color: var(--red);
}

.mob-arrow {
    font-size: .62rem;
    color: var(--muted);
    transition: transform .25s;
    flex-shrink: 0;
}

.mob-nav-toggle[aria-expanded="true"] .mob-arrow {
    transform: rotate(180deg);
}

.mob-sub {
    background: #faf8f8;
    border-bottom: 1px solid var(--border);
}

.mob-sub-head {
    font-size: .65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    color: var(--red);
    padding: 12px 20px 4px 26px;
}

.mob-sub a {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 9px 20px 9px 26px;
    font-size: .825rem;
    font-weight: 500;
    color: #3a2828;
    text-decoration: none;
    border-bottom: 1px solid rgba(0, 0, 0, .04);
    transition: all .18s;
}

.mob-sub a::before {
    content: '';
    width: 4px;
    height: 4px;
    background: var(--border-dark);
    border-radius: 50%;
    flex-shrink: 0;
    transition: background .18s;
}

.mob-sub a:hover {
    color: var(--red);
    padding-left: 30px;
}

.mob-sub a:hover::before {
    background: var(--red);
}

.mob-sub a:last-child {
    border-bottom: none;
}


/* Mobile contact */

.mob-contact {
    padding: 16px 20px;
    background: #f6f6f6;
    border-top: 2px solid rgb(228 34 38);
}

.mob-contact a {
    display: flex;
    align-items: center;
    gap: 11px;
    color: rgb(0 0 0 / 86%);
    font-size: .82rem;
    font-weight: 500;
    text-decoration: none;
    padding: 7px 0;
    transition: color .18s;
}

.mob-contact a i {
    width: 28px;
    height: 28px;
    background: rgba(237, 28, 36, .14);
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .78rem;
    flex-shrink: 0;
}

.mob-contact a:hover {
    color: var(--white);
}


/* ─── HERO ───────────────────────────────────────────────── */

.hero-wrap {
    position: relative;
    overflow: hidden;
}

.hero-slide {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    /* background: linear-gradient(100deg, rgba(18, 10, 8, .88) 0%, rgba(18, 10, 8, .68) 55%, rgba(18, 10, 8, .22) 100%); */
    background: linear-gradient(100deg, rgb(18 10 8 / 40%) 0%, rgb(18 10 8 / 30%) 55%, rgba(18, 10, 8, .22) 100%);
}

.hero-content {
    position: relative;
    z-index: 2;
    color: var(--white);
    max-width: 640px;
}

.hero-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgb(255 255 255);
    border: 1px solid rgba(237, 28, 36, .45);
    color: #000000;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: 7px 18px;
    border-radius: 50px;
    margin-bottom: 20px;
    backdrop-filter: blur(6px);
}

.hero-pill i {
    font-size: .8rem;
    color: var(--red);
}

.hero-h1 {
    font-size: clamp(2.4rem, 5.5vw, 4rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--white);
    margin-bottom: 18px;
    letter-spacing: -.5px;
}

.hero-h1 em {
    font-style: normal;
    color: var(--red);
}

.hero-p {
    font-size: 1.05rem;
    color: rgba(255, 255, 255);
    line-height: 1.85;
    margin-bottom: 34px;
    font-weight: 400;
}

.hero-btns {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 44px;
}

.hero-divider {
    width: 100%;
    border: none;
    border-top: 1px solid rgba(255, 255, 255, .12);
    margin-bottom: 28px;
}

.hero-kpis {
    display: flex;
    gap: 36px;
    flex-wrap: wrap;
}

.hero-kpi {}

.hero-kpi strong {
    display: block;
    font-size: 2rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1;
}

.hero-kpi strong span {
    color: var(--red);
}

.hero-kpi small {
    font-size: .72rem;
    color: rgba(255, 255, 255, .55);
    letter-spacing: .6px;
    text-transform: uppercase;
}


/* Hero side card */

.hero-card {
    position: relative;
    z-index: 2;
    background: rgba(255, 255, 255, .07);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: var(--radius-xl);
    padding: 28px 24px;
    color: var(--white);
}

.hero-card-title {
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255);
    margin-bottom: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
}

.hero-item {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
    font-size: .875rem;
    color: rgba(255, 255, 255);
}

.hero-item:last-child {
    border-bottom: none;
}

.hero-icon {
    width: 38px;
    height: 38px;
    background: rgb(255 255 255);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ed1c24;
    font-size: .9rem;
    flex-shrink: 0;
}


/* Carousel indicators */

.carousel-indicators [data-bs-target] {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .4);
    border: none;
    transition: all .3s;
    margin: 0 4px;
}

.carousel-indicators .active {
    width: 26px;
    border-radius: 4px;
    background: var(--red);
}

.carousel-control-prev,
.carousel-control-next {
    width: 44px;
    height: 44px;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 50%;
    background: rgba(255, 255, 255, .12);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255, 255, 255, .2);
    opacity: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-control-prev {
    left: 24px;
}

.carousel-control-next {
    right: 24px;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    background: var(--red);
}


/* ─── STATS BAR ──────────────────────────────────────────── */

.stats-bar {
    background: #f6f6f6;
    position: relative;
    overflow: hidden;
}

.stats-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--red), transparent);
}

.stat-box {
    padding: 36px 20px;
    text-align: center;
    position: relative;
    transition: background var(--dur);
}

.stat-box+.stat-box::before {
    content: '';
    position: absolute;
    left: 0;
    top: 24%;
    bottom: 24%;
    width: 1px;
    background: rgba(255, 255, 255, .08);
}

.stat-box:hover {
    background: rgba(237, 28, 36, .07);
}

.stat-num {
    font-size: 2.8rem;
    font-weight: 700;
    color: #ed1c24;
    line-height: 1;
    margin-bottom: 6px;
    letter-spacing: -1px;
}

.stat-num span {
    color: var(--red);
}

.stat-label {
    font-size: .74rem;
    color: rgba(255, 255, 255, .5);
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-weight: 600;
}

.stat-icon-wrap {
    width: 48px;
    height: 48px;
    background: rgba(237, 28, 36, .14);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
    font-size: 1.3rem;
    color: var(--red);
}


/* ─── ABOUT HOME ─────────────────────────────────────────── */

.about-img-frame {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.about-img-frame img {
    width: 100%;
    /* height: 520px; */
    object-fit: cover;
    object-position: center;
    display: block;
}

.about-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18, 10, 8, .72) 0%, transparent 55%);
}

.about-badge {
    position: absolute;
    bottom: 24px;
    left: 24px;
    background: var(--red);
    color: var(--white);
    border-radius: var(--radius-lg);
    padding: 16px 22px;
    box-shadow: var(--shadow-red);
}

.about-badge strong {
    display: block;
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1;
}

.about-badge span {
    font-size: .72rem;
    opacity: 1;
    letter-spacing: .5px;
}

.about-badge2 {
    position: absolute;
    top: 24px;
    right: 24px;
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(10px);
    border-radius: var(--radius-lg);
    padding: 14px 18px;
    box-shadow: var(--shadow-md);
    display: flex;
    align-items: center;
    gap: 10px;
}

.about-badge2 i {
    font-size: 1.4rem;
    color: var(--red);
}

.about-badge2 strong {
    font-size: 1rem;
    font-weight: 700;
    color: var(--dark);
    display: block;
    line-height: 1.2;
}

.about-badge2 small {
    font-size: .72rem;
    color: var(--muted);
}

.strength-row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--border);
}

.strength-row:last-child {
    border-bottom: none;
}

.str-icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    background: #fff0f0;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.1rem;
    transition: all var(--dur);
}

.strength-row:hover .str-icon {
    background: var(--red);
    color: var(--white);
}

.strength-row h6 {
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 2px;
    color: var(--dark);
}

.strength-row p {
    font-size: .81rem;
    color: #000000e3;
    margin: 0;
    line-height: 1.6;
}


/* ─── PRODUCT CATEGORY CARDS ─────────────────────────────── */

.cat-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    background: var(--white);
    transition: all var(--dur) var(--ease);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.cat-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: transparent;
}

.cat-card-img {
    /* height: 210px; */
    position: relative;
    overflow: hidden;
}

.cat-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s var(--ease);
}

.cat-card:hover .cat-card-img img {
    transform: scale(1.05);
}

.cat-card-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18, 10, 8, .7) 0%, rgba(18, 10, 8, .1) 60%);
}

.cat-card-label {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--red);
    color: var(--white);
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 4px 12px;
    border-radius: 50px;
}

.cat-card-title-overlay {
    position: absolute;
    bottom: 16px;
    left: 16px;
    right: 16px;
    color: var(--white);
}

.cat-card-title-overlay h4 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 2px;
}

.cat-card-title-overlay p {
    font-size: .75rem;
    color: rgba(255, 255, 255);
    margin: 0;
}

.cat-card-body {
    padding: 20px 22px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.cat-card-tags {
    flex: 1;
    margin-bottom: 16px;
}

.cat-card-tags .tag {
    margin: 3px 2px;
}

.cat-card-footer {
    padding-top: 14px;
    border-top: 1px solid var(--border);
}


/* ─── FEATURE CARDS ──────────────────────────────────────── */

.feat-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 34px 28px;
    box-shadow: var(--shadow-xs);
    transition: all var(--dur) var(--ease);
    height: 100%;
    position: relative;
    overflow: hidden;
}

.feat-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--red);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s var(--ease);
}

.feat-card:hover::after {
    transform: scaleX(1);
}

.feat-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: transparent;
}

.feat-icon {
    width: 60px;
    height: 60px;
    background: #fff0f0;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.7rem;
    color: var(--red);
    margin-bottom: 20px;
    transition: all var(--dur);
}

.feat-card:hover .feat-icon {
    background: var(--red);
    color: var(--white);
}

.feat-card h5 {
    font-size: .97rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.feat-card p {
    font-size: .83rem;
    color: #000000e3;
    margin: 0;
    line-height: 1.7;
}


/* ─── IMAGE SECTION ──────────────────────────────────────── */

.img-section {
    position: relative;
    overflow: hidden;
}

.img-section-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.img-section-overlay {
    position: absolute;
    inset: 0;
    background: rgba(18, 10, 8, .78);
}

.img-section>.container {
    position: relative;
    z-index: 2;
}


/* ─── GLOBAL PRESENCE ────────────────────────────────────── */

.globe-section {
    background: #f5e4e5;
    position: relative;
    overflow: hidden;
}

.globe-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url('../images/silok/map.svg');
    background-size: 70%;
    background-position: right center;
    background-repeat: no-repeat;
    opacity: .05;
}

.country-chip {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    background: rgb(255 255 255);
    border: 1px solid rgba(237, 28, 36, .25);
    color: rgb(30 25 23);
    font-size: 1rem;
    font-weight: 500;
    padding: 10px 15px;
    border-radius: 50px;
    margin: 7px;
    transition: all var(--dur);
}

.country-chip:hover {
    background: rgba(237, 28, 36, .22);
    border-color: rgba(237, 28, 36, .4);
    color: #000000;
}

.country-chip .flag {
    font-size: 1.15rem;
}


/* Global office card */

.globe-office {
    background: rgba(237, 28, 36, .1);
    border: 1px solid rgba(237, 28, 36, .25);
    border-radius: var(--radius-lg);
    padding: 22px 26px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.globe-office .icon {
    width: 46px;
    height: 46px;
    background: rgba(237, 28, 36, .18);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.2rem;
    flex-shrink: 0;
}


/* ─── CERTIFICATIONS — PREMIUM ───────────────────────────── */


/* ── Stat Bar ── */

.cert-stat-bar {
    background: #f6f6f6;
    padding: 22px 0;
    border-top: 3px solid var(--red);
    border-bottom: 3px solid rgba(237, 28, 36, .18);
}

.cert-stat-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
}

.cert-stat-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 32px;
    color: var(--white);
}

.cert-stat-num {
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--red);
    line-height: 1;
}

.cert-stat-lbl {
    font-size: .78rem;
    font-weight: 500;
    color: #000000e3;
    text-transform: uppercase;
    letter-spacing: .6px;
}

.cert-stat-sep {
    width: 1px;
    height: 36px;
    background: rgba(255, 255, 255, .12);
    flex-shrink: 0;
}

@media (max-width: 767px) {
    .cert-stat-item {
        padding: 8px 18px;
    }
    .cert-stat-sep {
        display: none;
    }
}


/* ── Cert Cards ── */

.cert-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.cert-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
}

.cert-card-topbar {
    height: 4px;
    width: 100%;
    flex-shrink: 0;
}

.cert-card-body {
    padding: 24px 20px 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.cert-card-ico {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 14px;
    flex-shrink: 0;
}

.cert-card-title {
    font-size: .92rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 8px;
    line-height: 1.35;
}

.cert-card-desc {
    font-size: .78rem;
    color: var(--muted);
    line-height: 1.6;
    flex: 1;
    margin: 0;
}

.cert-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px 16px;
    border-top: 1px solid var(--border);
    margin-top: 12px;
}

.cert-cat-badge {
    font-size: .68rem;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 50px;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: #1e1917 !important;
}

.cert-card-check {
    font-size: .95rem;
    flex-shrink: 0;
}


/* ─── MANUFACTURING IMAGE SECTION ───────────────────────── */

.mfg-img-wrap {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.mfg-img-wrap img {
    width: 100%;
    height: 460px;
    object-fit: cover;
}

.mfg-float {
    position: absolute;
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: 16px 18px;
}

.mfg-float-tl {
    top: 24px;
    left: 24px;
}

.mfg-float-br {
    bottom: 24px;
    right: 24px;
}


/* ─── CTA SECTION ────────────────────────────────────────── */

.cta-red {
    background: linear-gradient(135deg, var(--red-mid) 0%, var(--red-dark) 100%);
    position: relative;
    overflow: hidden;
}

.cta-red::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .06);
}

.cta-red::after {
    content: '';
    position: absolute;
    bottom: -40px;
    left: -40px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(0, 0, 0, .06);
}

.cta-red>* {
    position: relative;
    z-index: 1;
}

.cta-red h2 {
    color: var(--white);
}

.cta-red p {
    color: rgba(255, 255, 255, .82);
}


/* CTA with bg image */

.cta-img-section {
    position: relative;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.cta-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgb(0 0 0 / 50%) 0%, rgb(0 0 0 / 50%) 100%);
}

.cta-img-section>.container {
    position: relative;
    z-index: 2;
}


/* ─── BLOG CARDS ─────────────────────────────────────────── */

.blog-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-xs);
    border: 1px solid var(--border);
    transition: all var(--dur) var(--ease);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.blog-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: transparent;
}

.blog-img-wrap {
    /* height: 196px; */
    overflow: hidden;
    position: relative;
}

.blog-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s var(--ease);
}

.blog-card:hover .blog-img-wrap img {
    transform: scale(1.06);
}

.blog-img-placeholder {
    height: 196px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3.2rem;
    color: var(--red);
    position: relative;
}

.blog-cat-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--red);
    color: var(--white);
    font-size: .68rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 50px;
    letter-spacing: .8px;
    text-transform: uppercase;
}

.blog-body {
    padding: 22px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.blog-meta {
    font-size: .75rem;
    color: var(--muted);
    margin-bottom: 8px;
}

.blog-body h5 {
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: 8px;
    line-height: 1.4;
}

.blog-body h5 a {
    color: var(--dark);
}

.blog-body h5 a:hover {
    color: var(--red);
}

.blog-body p {
    font-size: .82rem;
    color: var(--muted);
    flex: 1;
}

.blog-read {
    font-size: .8rem;
    font-weight: 700;
    color: var(--red);
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.blog-read:hover {
    gap: 10px;
    color: var(--red-dark);
}


/* ─── PAGE HERO ──────────────────────────────────────────── */

.page-hero {
    position: relative;
    min-height: 280px;
    padding: 100px 0 80px;
    background-size: cover;
    background-position: center center;
    background-color: #1a0d0e;
    /* fallback when image loads slowly */
    overflow: hidden;
    display: flex;
    align-items: center;
}

.page-hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(110deg, rgb(14 7 5 / 50%) 0%, rgb(14 7 5 / 37%) 55%, rgb(37 33 33 / 37%) 100%);
}

.page-hero>.container {
    position: relative;
    z-index: 2;
}

.page-hero h1 {
    color: var(--white);
    font-size: clamp(1.7rem, 3.5vw, 2.5rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 10px;
}

.page-hero h1 span {
    color: var(--red) !important;
}

.page-hero p {
    color: rgba(255, 255, 255);
    font-size: 1rem;
    max-width: 600px;
    margin-bottom: 0;
}

.page-hero .breadcrumb {
    margin-bottom: 18px;
}


/* ── Hero certification chips ───────────────────────────── */

.hero-cert-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.hero-cert-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .30);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .3px;
    padding: 6px 15px;
    border-radius: 30px;
    white-space: nowrap;
}

.hero-cert-chip i {
    font-size: .8rem;
}

.breadcrumb-item,
.breadcrumb-item a {
    color: rgba(255, 255, 255);
    font-size: .8rem;
    text-decoration: none;
}

.breadcrumb-item a:hover {
    color: rgba(255, 255, 255);
}

.breadcrumb-item.active {
    color: #ffffff;
    font-weight: 600;
}

.breadcrumb-item+.breadcrumb-item::before {
    color: rgba(255, 255, 255, .9);
}


/* ─── FORMS ──────────────────────────────────────────────── */

.form-wrap {
    background: var(--white);
    border-radius: var(--radius-xl);
    padding: 42px 40px;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border);
}

.form-control,
.form-select {
    border: 1.5px solid var(--border-dark);
    border-radius: var(--radius);
    padding: 12px 16px;
    font-size: .875rem;
    color: var(--dark);
    font-family: inherit;
    transition: border-color var(--dur), box-shadow var(--dur);
    background: var(--lighter);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--red);
    box-shadow: 0 0 0 3px rgba(237, 28, 36, .09);
    outline: none;
    background: var(--white);
}

.form-label {
    font-size: .83rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: 6px;
}

.required-star {
    color: var(--red);
}


/* Alerts */

.msg-ok {
    background: #e8f5e9;
    color: #2e7d32;
    border: 1px solid #c8e6c9;
    border-radius: var(--radius);
    padding: 13px 16px;
    font-size: .875rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 9px;
}

.msg-err {
    background: #ffebee;
    color: #c62828;
    border: 1px solid #ffcdd2;
    border-radius: var(--radius);
    padding: 13px 16px;
    font-size: .875rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 9px;
}


/* ─── CONTACT INFO CARDS ─────────────────────────────────── */

.contact-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    padding: 28px 24px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    text-align: center;
    transition: all var(--dur);
    height: 100%;
}

.contact-card:hover {
    border-color: var(--red);
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}

.contact-card-icon {
    width: 60px;
    height: 60px;
    background: #fff0f0;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--red);
    margin: 0 auto 14px;
}

.contact-card h6 {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--muted);
    margin-bottom: 6px;
}

.contact-card p,
.contact-card a {
    font-size: .9rem;
    color: var(--dark);
    font-weight: 500;
    margin: 0;
}

.contact-card a:hover {
    color: var(--red);
}


/* Download buttons */

.dl-btn {
    display: flex;
    align-items: center;
    gap: 11px;
    background: var(--light);
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 12px 16px;
    color: var(--dark);
    font-size: .83rem;
    font-weight: 500;
    transition: all var(--dur);
    margin-bottom: 8px;
}

.dl-btn:hover {
    border-color: var(--red);
    background: #fff0f0;
    color: var(--red);
}

.dl-btn i {
    color: var(--red);
    font-size: 1.1rem;
}


/* ─── CAPABILITY CARDS — see premium block near footer ───── */


/* (Old stubs kept for any legacy references; new styles override below) */

.cap-head {
    display: flex;
    align-items: center;
    gap: 13px;
    margin-bottom: 14px;
}

.cap-ico {
    width: 46px;
    height: 46px;
    background: #fff0f0;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--red);
}


/* ─── DISTRIBUTOR BENEFITS ───────────────────────────────── */

.benefit-row {
    display: flex;
    gap: 18px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 22px;
    box-shadow: var(--shadow-xs);
    transition: all var(--dur);
    margin-bottom: 14px;
}

.benefit-row:hover {
    border-color: var(--red);
    box-shadow: var(--shadow-sm);
}

.benefit-ico {
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    background: #fff0f0;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    color: var(--red);
    transition: all var(--dur);
}

.benefit-row:hover .benefit-ico {
    background: var(--red);
    color: var(--white);
}

.benefit-row h6 {
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 3px;
}

.benefit-row p {
    font-size: .81rem;
    color: var(--muted);
    margin: 0;
}


/* ─── CERT GRID CARDS ────────────────────────────────────── */

.cert-grid {
    background: var(--white);
    border-radius: var(--radius-xl);
    padding: 28px 22px;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-xs);
    text-align: center;
    height: 100%;
    transition: all var(--dur);
}

.cert-grid:hover {
    border-color: var(--red);
    box-shadow: var(--shadow-sm);
    transform: translateY(-4px);
}

.cert-grid .ci {
    width: 64px;
    height: 64px;
    background: #fff0f0;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: var(--red);
    margin: 0 auto 14px;
}

.cert-grid h6 {
    font-size: .88rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 5px;
}

.cert-grid p {
    font-size: .78rem;
    color: var(--muted);
    margin: 0;
}


/* ─── JOB CARDS ──────────────────────────────────────────── */

.job-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 26px 28px;
    box-shadow: var(--shadow-xs);
    transition: all var(--dur);
    margin-bottom: 14px;
}

.job-card:hover {
    border-color: var(--red);
    box-shadow: var(--shadow-sm);
}

.job-badge {
    font-size: .7rem;
    font-weight: 700;
    padding: 3px 12px;
    border-radius: 50px;
    text-transform: uppercase;
    letter-spacing: .8px;
    display: inline-block;
    margin-bottom: 10px;
}

.job-badge.ft {
    background: #e8f5e9;
    color: #2e7d32;
}

.job-card h5 {
    font-size: 1.05rem;
    font-weight: 700;
    margin-bottom: 6px;
}

.job-card p {
    font-size: .845rem;
    color: var(--muted);
    margin-bottom: 14px;
}

.job-tags span {
    font-size: .78rem;
    color: var(--muted);
    margin-right: 16px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}


/* ─── PROCESS STEPS ──────────────────────────────────────── */

.step-wrap {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 28px;
}

.step-num {
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    background: var(--red);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: .95rem;
    box-shadow: 0 4px 14px rgba(237, 28, 36, .3);
}

.step-wrap h6 {
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 3px;
}

.step-wrap p {
    font-size: .83rem;
    color: var(--muted);
    margin: 0;
}


/* ─── WHATSAPP FLOAT ─────────────────────────────────────── */

.wa-float {
    position: fixed;
    bottom: 28px;
    right: 28px;
    width: 58px;
    height: 58px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.65rem;
    color: var(--white);
    box-shadow: 0 6px 24px rgba(37, 211, 102, .5);
    z-index: 9999;
    transition: all var(--dur);
    animation: waPulse 2.5s infinite;
}

.wa-float:hover {
    color: var(--white);
    transform: scale(1.1);
}

@keyframes waPulse {
    0%,
    100% {
        box-shadow: 0 6px 24px rgba(37, 211, 102, .5);
    }
    50% {
        box-shadow: 0 6px 36px rgba(37, 211, 102, .75);
    }
}


/* ─── BACK TO TOP ────────────────────────────────────────── */

#backTop {
    position: fixed;
    bottom: 98px;
    right: 28px;
    width: 44px;
    height: 44px;
    background: var(--dark);
    color: var(--white);
    border: none;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    box-shadow: var(--shadow-md);
    z-index: 9998;
    opacity: 0;
    transform: translateY(10px);
    transition: all var(--dur);
}

#backTop.show {
    opacity: 1;
    transform: translateY(0);
}

#backTop:hover {
    background: var(--red);
    transform: translateY(-3px);
}


/* ─── PRODUCT CARDS ──────────────────────────────────────── */

.prod-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-xs);
    transition: all var(--dur) var(--ease);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.prod-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: var(--red);
}

.prod-card-img {
    height: 170px;
    background: linear-gradient(135deg, #fff0f0 0%, #fde8e8 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.8rem;
    color: var(--red);
    position: relative;
}

.prod-card-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--red);
    color: var(--white);
    font-size: .66rem;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 50px;
}

.prod-card-body {
    padding: 18px 20px;
    flex: 1;
}

.prod-card-body .seg {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--muted);
    margin-bottom: 5px;
}

.prod-card-body h5 {
    font-size: .93rem;
    font-weight: 700;
    margin-bottom: 7px;
}

.prod-card-body p {
    font-size: .8rem;
    color: var(--muted);
    margin: 0;
}

.prod-card-footer {
    padding: 13px 20px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}


/* ─── CONTACT PAGE ───────────────────────────────────────── */


/* ── Contact strip (4 info cards) ── */

.ctc-strip {
    background: var(--white);
    padding: 36px 0;
    border-bottom: 1px solid var(--border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, .05);
}

.ctc-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 20px 18px;
    height: 100%;
    transition: border-color .25s, box-shadow .25s, transform .25s;
    position: relative;
    overflow: hidden;
}

.ctc-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    border-radius: 14px 14px 0 0;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s ease;
}

.ctc-card:hover {
    border-color: transparent;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .1);
    transform: translateY(-3px);
}

.ctc-card:hover::before {
    transform: scaleX(1);
}

.ctc-card-ico {
    width: 50px;
    height: 50px;
    border-radius: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}

.ctc-ico-red {
    background: rgba(237, 28, 36, .1);
    color: var(--red);
}

.ctc-ico-blue {
    background: rgba(30, 100, 200, .1);
    color: #1e64c8;
}

.ctc-ico-green {
    background: rgba(39, 174, 96, .1);
    color: #27ae60;
}

.ctc-ico-purple {
    background: rgba(142, 68, 173, .1);
    color: #8e44ad;
}

.ctc-card:nth-child(1) .ctc-card::before,
.ctc-card:nth-child(1):hover .ctc-card::before {
    background: var(--red);
}


/* Top bar per card type */

.ctc-card:has(.ctc-ico-red)::before {
    background: var(--red);
}

.ctc-card:has(.ctc-ico-blue)::before {
    background: #1e64c8;
}

.ctc-card:has(.ctc-ico-green)::before {
    background: #27ae60;
}

.ctc-card:has(.ctc-ico-purple)::before {
    background: #8e44ad;
}

.ctc-card-body {
    flex: 1;
    min-width: 0;
}

.ctc-card-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--muted);
    margin-bottom: 5px;
}

.ctc-card-val {
    display: block;
    font-size: .92rem;
    font-weight: 700;
    color: var(--dark);
    text-decoration: none;
    line-height: 1.3;
    margin-bottom: 4px;
    word-break: break-all;
}

.ctc-card-val:hover {
    color: var(--red);
}

.ctc-card-sub {
    font-size: .73rem;
    color: var(--muted);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
}

.ctc-card-sub:hover {
    color: #27ae60;
}


/* ── Main section bg ── */

.ctc-main-section {
    background: #f6f6f6;
}


/* ── Contact Form wrap ── */

.ctc-form-wrap {
    background: var(--white);
    border-radius: 20px;
    padding: 38px 40px 32px;
    box-shadow: 0 4px 36px rgba(0, 0, 0, .09);
    border: 1px solid var(--border);
}

@media (max-width: 575px) {
    .ctc-form-wrap {
        padding: 26px 20px 22px;
    }
}

.ctc-form-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 28px;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--border);
}

.ctc-form-header-ico {
    width: 54px;
    height: 54px;
    background: #ed1c24;
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    font-size: 1.35rem;
    flex-shrink: 0;
}

.ctc-form-title {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--dark);
    margin: 0 0 4px;
}

.ctc-form-sub {
    font-size: .78rem;
    color: var(--muted);
    margin: 0;
}


/* Field with icon prefix */

.ctc-field-wrap {
    position: relative;
}

.ctc-field-ico {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted);
    font-size: .82rem;
    pointer-events: none;
    z-index: 1;
}

.ctc-input {
    padding-left: 38px !important;
    border-radius: 10px !important;
    border: 1.5px solid var(--border) !important;
    background: var(--lighter, #faf9f8) !important;
    font-size: .875rem !important;
    transition: border-color .2s, box-shadow .2s !important;
}

.ctc-input:focus {
    border-color: var(--red) !important;
    box-shadow: 0 0 0 3px rgba(237, 28, 36, .09) !important;
    background: var(--white) !important;
}

.ctc-input:focus+.ctc-field-ico,
.ctc-field-wrap:focus-within .ctc-field-ico {
    color: var(--red);
}

.ctc-textarea {
    border-radius: 10px !important;
    border: 1.5px solid var(--border) !important;
    background: var(--lighter, #faf9f8) !important;
    font-size: .875rem !important;
    resize: vertical;
    transition: border-color .2s, box-shadow .2s !important;
}

.ctc-textarea:focus {
    border-color: var(--red) !important;
    box-shadow: 0 0 0 3px rgba(237, 28, 36, .09) !important;
    background: var(--white) !important;
}

.ctc-req {
    color: var(--red);
}


/* Submit button */

.ctc-submit-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #ed1c24;
    color: var(--white);
    font-size: .95rem;
    font-weight: 700;
    padding: 15px 28px;
    border-radius: 12px;
    border: none;
    cursor: pointer;
    transition: all .28s;
    position: relative;
    overflow: hidden;
    letter-spacing: .2px;
}

.ctc-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(237, 28, 36, .48);
}

.ctc-submit-arrow {
    margin-left: auto;
    width: 28px;
    height: 28px;
    background: rgba(255, 255, 255, .18);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    transition: transform .25s;
}

.ctc-submit-btn:hover .ctc-submit-arrow {
    transform: translateX(4px);
}


/* Footer note */

.ctc-form-footer {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    font-size: .74rem;
    color: var(--muted);
}

.ctc-form-footer i {
    color: var(--red);
}


/* ── Direct Contact Card ── */

.ctc-direct-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 28px 26px;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
}

.ctc-direct-card::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    /* background: radial-gradient(circle, rgba(237, 28, 36, .18) 0%, transparent 65%); */
    pointer-events: none;
}

.ctc-direct-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px);
    background-size: 18px 18px;
    pointer-events: none;
}

.ctc-direct-card>* {
    position: relative;
    z-index: 2;
}

.ctc-direct-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgb(0 0 0 / 21%);
}

.ctc-direct-header-ico {
    width: 50px;
    height: 50px;
    background: rgba(237, 28, 36, .18);
    border-radius: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.3rem;
    flex-shrink: 0;
}

.ctc-direct-title {
    font-size: 1rem;
    font-weight: 700;
    color: #ed1c24;
}

.ctc-direct-sub {
    font-size: .73rem;
    color: #000000e3;
    margin-top: 0;
}


/* Contact person row */

.ctc-person {
    display: flex;
    align-items: center;
    gap: 13px;
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 12px;
    padding: 14px 16px;
    margin-bottom: 16px;
}

.ctc-person-avatar {
    width: 44px;
    height: 44px;
    background: rgba(237, 28, 36, .2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.1rem;
    flex-shrink: 0;
}

.ctc-person-name {
    font-size: .95rem;
    font-weight: 800;
    color: #000000e3;
    line-height: 1;
}

.ctc-person-role {
    font-size: .72rem;
    color: #000000e3;
    margin-top: 3px;
}

.ctc-person-badge {
    margin-left: auto;
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    background: rgba(39, 174, 96, .18);
    color: #52d68a;
    border: 1px solid rgba(39, 174, 96, .28);
    padding: 3px 9px;
    border-radius: 50px;
}


/* Contact links */

.ctc-links {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 18px;
}

.ctc-link {
    display: flex;
    align-items: center;
    gap: 13px;
    background: rgb(255 255 255);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 11px;
    padding: 13px 15px;
    text-decoration: none;
    transition: background .22s, border-color .22s;
}

.ctc-link:hover {
    background: rgba(237, 28, 36, .12);
    border-color: rgba(237, 28, 36, .25);
}

.ctc-link-ico {
    width: 36px;
    height: 36px;
    background: rgba(237, 28, 36, .18);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .9rem;
    flex-shrink: 0;
}

.ctc-link-label {
    font-size: .68rem;
    color: #000000e3;
    text-transform: uppercase;
    letter-spacing: .8px;
    font-weight: 600;
}

.ctc-link-val {
    font-size: .85rem;
    font-weight: 600;
    color: #000000e3;
    margin-top: 1px;
}

.ctc-link-arrow {
    margin-left: auto;
    color: rgba(255, 255, 255, .2);
    font-size: .75rem;
}


/* WhatsApp CTA */

.ctc-whatsapp-btn {
    display: flex;
    align-items: center;
    gap: 13px;
    background: #25d366;
    border-radius: 13px;
    padding: 16px 18px;
    text-decoration: none;
    margin-bottom: 14px;
    transition: opacity .22s, transform .22s;
}

.ctc-whatsapp-btn:hover {
    opacity: .92;
    transform: translateY(-2px);
}

.ctc-whatsapp-btn>.fab {
    font-size: 1.8rem;
    color: #fff;
    flex-shrink: 0;
}

.ctc-wa-title {
    font-size: .9rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1;
}

.ctc-wa-sub {
    font-size: .7rem;
    color: rgba(255, 255, 255);
    margin-top: 3px;
}

.ctc-wa-arrow {
    margin-left: auto;
    color: rgba(255, 255, 255);
    font-size: .82rem;
}


/* Response time note */

.ctc-response-note {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .8rem;
    color: #000000e3;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, .07);
}

.ctc-response-note i {
    color: rgb(0 0 0);
}


/* ── Downloads Card ── */

.ctc-downloads-card {
    background: var(--white);
    border-radius: 18px;
    border: 1px solid var(--border);
    overflow: hidden;
    box-shadow: 0 3px 20px rgba(0, 0, 0, .07);
}

.ctc-downloads-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 22px;
    background: var(--light);
    border-bottom: 1px solid var(--border);
    font-size: .85rem;
    font-weight: 700;
    color: var(--dark);
}

.ctc-downloads-header i {
    color: var(--red);
    font-size: 1rem;
}

.ctc-dl-item {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 14px 22px;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    transition: background .2s;
}

.ctc-dl-item:last-child {
    border-bottom: none;
}

.ctc-dl-item:hover {
    background: var(--light-red);
}

.ctc-dl-ico {
    width: 38px;
    height: 38px;
    background: rgba(237, 28, 36, .09);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1rem;
    flex-shrink: 0;
}

.ctc-dl-info {
    flex: 1;
    min-width: 0;
}

.ctc-dl-name {
    font-size: .82rem;
    font-weight: 700;
    color: var(--dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ctc-dl-desc {
    font-size: .7rem;
    color: var(--muted);
    margin-top: 1px;
}

.ctc-dl-badge {
    font-size: .6rem;
    font-weight: 700;
    text-transform: uppercase;
    background: var(--light-red);
    color: var(--red);
    border: 1px solid rgba(237, 28, 36, .2);
    padding: 2px 8px;
    border-radius: 4px;
    flex-shrink: 0;
}

.ctc-dl-arrow {
    font-size: .8rem;
    color: var(--muted);
    flex-shrink: 0;
    transition: color .2s, transform .2s;
}

.ctc-dl-item:hover .ctc-dl-arrow {
    color: var(--red);
    transform: translateY(2px);
}


/* ─── INTERNATIONAL BUSINESS PAGE ───────────────────────── */


/* KPI mini-cards grid */

.intl-kpi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 28px;
}

.intl-kpi {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px 18px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, .05);
    transition: border-color .25s, box-shadow .25s;
}

.intl-kpi:hover {
    border-color: rgba(237, 28, 36, .3);
    box-shadow: 0 4px 20px rgba(237, 28, 36, .1);
}

.intl-kpi-ico {
    width: 44px;
    height: 44px;
    background: #f5e0e1;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.15rem;
    flex-shrink: 0;
}

.intl-kpi-val {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--dark);
    line-height: 1;
}

.intl-kpi-label {
    font-size: .73rem;
    color: var(--muted);
    margin-top: 3px;
    font-weight: 500;
}


/* Markets panel */

.markets-panel {
    background: #f6f6f6;
    border-radius: 20px;
    padding: 32px 30px;
    position: relative;
    overflow: hidden;
    /* box-shadow: 0 12px 48px rgba(0, 0, 0, .25); */
}


/* .markets-panel::before {
    content: '';
    position: absolute;
    top: -80px;
    right: -80px;
    width: 260px;
    height: 260px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(237, 28, 36, .16) 0%, transparent 65%);
    pointer-events: none;
} */

.markets-panel::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, .03) 1px, transparent 1px);
    background-size: 18px 18px;
    pointer-events: none;
}

.markets-panel>* {
    position: relative;
    z-index: 2;
}

.markets-panel-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 22px;
}

.markets-panel-ico {
    width: 52px;
    height: 52px;
    background: rgba(237, 28, 36, .15);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.5rem;
    flex-shrink: 0;
}

.markets-panel-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: #ed1c24;
    line-height: 1;
}

.markets-panel-sub {
    font-size: .75rem;
    color: #000000e3;
    margin-top: 4px;
}

.markets-panel-badge {
    margin-left: auto;
    background: rgb(245 224 225);
    color: #ed1c24;
    border: 1px solid rgb(245 224 225);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 4px 11px;
    border-radius: 50px;
    white-space: nowrap;
}

.markets-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}


/* Override country-chip colors inside markets-panel */

.markets-panel .country-chip {
    background: rgb(255, 255, 255);
    border-color: rgba(255, 255, 255, .12);
    color: #000000e3;
    font-size: .9rem;
    padding: 6px 13px;
}

.markets-panel .country-chip:hover {
    background: rgba(237, 28, 36, .2);
    border-color: rgba(237, 28, 36, .35);
    color: #000000;
}


/* Office highlight */

.markets-office {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: rgba(237, 28, 36, .1);
    border: 1px solid rgba(237, 28, 36, .22);
    border-radius: 12px;
    padding: 14px 16px;
    margin-bottom: 14px;
}

.markets-office-dot {
    width: 10px;
    height: 10px;
    background: var(--red);
    border-radius: 50%;
    margin-top: 4px;
    flex-shrink: 0;
    box-shadow: 0 0 0 3px rgba(237, 28, 36, .25);
    animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
    0%,
    100% {
        box-shadow: 0 0 0 3px rgba(237, 28, 36, .25);
    }
    50% {
        box-shadow: 0 0 0 7px rgba(237, 28, 36, .08);
    }
}

.markets-office-name {
    font-size: .82rem;
    font-weight: 700;
    color: #ed1c24;
}

.markets-office-detail {
    font-size: .75rem;
    color: #000000e3;
    margin-top: 2px;
}


/* Expanding note */

.markets-expanding {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .76rem;
    color: #000000e3;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, .07);
}

.markets-expanding i {
    color: rgb(0 0 0);
    flex-shrink: 0;
}

.markets-expanding-link {
    margin-left: auto;
    color: var(--red) !important;
    font-weight: 700;
    font-size: .76rem;
    text-decoration: none;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: gap .2s;
}

.markets-expanding-link:hover {
    gap: 9px;
}


/* ── Private Label section ── */

.intl-pl-section {
    background: var(--light);
}


/* Vertical timeline */

.pl-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.pl-step {
    display: flex;
    gap: 18px;
    align-items: flex-start;
}

.pl-step-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
}

.pl-step-num {
    width: 38px;
    height: 38px;
    line-height: 38px;
    background: var(--red);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    font-weight: 700;
    flex-shrink: 0;
    z-index: 1;
    /* box-shadow: 0 4px 14px rgba(237, 28, 36, .35); */
}

.pl-step-line {
    width: 2px;
    flex: 1;
    min-height: 28px;
    background: linear-gradient(to bottom, rgba(237, 28, 36, .4), rgba(237, 28, 36, .1));
    margin: 4px 0;
}

.pl-step-content {
    padding-bottom: 28px;
    flex: 1;
}

.pl-step:last-child .pl-step-content {
    padding-bottom: 0;
}

.pl-step-icon {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: .75rem;
    color: var(--red);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-bottom: 4px;
}

.pl-step-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--dark);
    margin-bottom: 5px;
}

.pl-step-desc {
    font-size: .9rem;
    color: #212121;
    line-height: 1.65;
    margin: 0;
}


/* Benefits card */

.pl-benefits-wrap {
    background: var(--white);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 4px 32px rgba(0, 0, 0, .09);
    border: 1px solid var(--border);
}

.pl-benefits-head {
    background: #ed1c24;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: rgba(255, 255, 255, .85);
    font-size: .83rem;
    font-weight: 600;
}

.pl-benefits-head i {
    color: #ffffff;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.pl-benefits-list {
    padding: 8px 0;
}

.pl-benefit {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 11px 24px;
    border-bottom: 1px solid var(--border);
    font-size: .875rem;
    font-weight: 500;
    color: var(--dark);
    transition: background .18s;
}

.pl-benefit:last-child {
    border-bottom: none;
}

.pl-benefit:hover {
    background: var(--light-red);
}

.pl-benefit-check {
    width: 24px;
    height: 24px;
    background: rgba(237, 28, 36, .1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.pl-benefit-check i {
    font-size: .65rem;
    color: var(--red);
}

.pl-benefits-footer {
    padding: 20px 24px 24px;
    border-top: 1px solid var(--border);
    background: var(--light);
}

.pl-moq-note {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: .78rem;
    color: var(--muted);
    line-height: 1.6;
}

.pl-moq-note i {
    color: var(--red);
    margin-top: 2px;
    flex-shrink: 0;
}


/* ── Regulatory section ── */

.intl-reg-section {
    background: #f5e4e5;
    position: relative;
    overflow: hidden;
}

.intl-reg-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(237, 28, 36, .06) 1px, transparent 1px);
    background-size: 22px 22px;
    pointer-events: none;
}

.intl-reg-section .container {
    position: relative;
    z-index: 2;
}


/* Regulatory doc cards */

.reg-doc-card {
    background: rgb(255 255 255);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 16px;
    padding: 26px 24px;
    height: 100%;
    transition: background .3s, border-color .3s, transform .3s;
    backdrop-filter: blur(4px);
}

.reg-doc-card:hover {
    background: rgba(237, 28, 36, .1);
    border-color: rgba(237, 28, 36, .28);
    transform: translateY(-5px);
}

.reg-doc-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.reg-doc-icon {
    width: 52px;
    height: 52px;
    background: rgba(237, 28, 36, .15);
    border-radius: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.35rem;
    transition: background .3s;
}

.reg-doc-card:hover .reg-doc-icon {
    background: rgba(237, 28, 36, .25);
}

.reg-doc-tag {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    background: rgba(255, 255, 255, .07);
    color: rgba(255, 255, 255, .45);
    border: 1px solid rgba(255, 255, 255, .1);
    padding: 4px 10px;
    border-radius: 50px;
}

.reg-doc-title {
    font-size: .95rem;
    font-weight: 800;
    color: #000000;
    margin-bottom: 10px;
}

.reg-doc-desc {
    font-size: .81rem;
    color: rgb(0 0 0 / 82%);
    line-height: 1.68;
    margin: 0;
}


/* ── Why Partner section ── */

.intl-why-card {
    background: #f6f6f6;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 30px 26px;
    height: 100%;
    transition: border-color .28s, box-shadow .28s, transform .28s;
    position: relative;
    overflow: hidden;
}

.intl-why-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(to right, var(--red), var(--red-mid));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s ease;
}

.intl-why-card:hover {
    border-color: rgba(237, 28, 36, .25);
    /* box-shadow: 0 8px 36px rgba(237, 28, 36, .1); */
    transform: translateY(-5px);
}

.intl-why-card:hover::before {
    transform: scaleX(1);
}

.intl-why-ico {
    width: 56px;
    height: 56px;
    background: #f5e4e5;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.4rem;
    margin-bottom: 18px;
    transition: background .3s;
}

.intl-why-card:hover .intl-why-ico {
    background: var(--red);
    color: var(--white);
}

.intl-why-title {
    font-size: .98rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 10px;
}

.intl-why-desc {
    font-size: .82rem;
    color: var(--muted);
    line-height: 1.7;
    margin: 0;
}


/* ─── MANUFACTURING CAPABILITIES CARDS ──────────────────── */

.cap-section {
    background: #f4f2f1;
}

.cap-section-sub {
    font-size: .97rem;
    color: var(--muted);
    margin-top: 10px;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}


/* Card shell */

.cap-card {
    background: var(--white);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 4px 28px rgba(0, 0, 0, .08);
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform .32s ease, box-shadow .32s ease;
}

.cap-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 16px 48px rgba(0, 0, 0, .15);
}


/* ── Card head (dark) ── */

.cap-card-head {
    padding: 34px 30px 26px;
    position: relative;
    overflow: hidden;
}

.cap-pharma .cap-card-head {
    background: linear-gradient(135deg, #190e0d 0%, #2e1212 100%);
}

.cap-nutra .cap-card-head {
    background: linear-gradient(135deg, #0c1a11 0%, #123022 100%);
}

.cap-cosm .cap-card-head {
    background: linear-gradient(135deg, #110e1c 0%, #1c1230 100%);
}


/* Glowing orb decoration inside head */

.cap-card-head::before {
    content: '';
    position: absolute;
    bottom: -50px;
    right: -50px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    opacity: .22;
    pointer-events: none;
}

.cap-pharma .cap-card-head::before {
    background: radial-gradient(circle, var(--red) 0%, transparent 70%);
}

.cap-nutra .cap-card-head::before {
    background: radial-gradient(circle, #27ae60 0%, transparent 70%);
}

.cap-cosm .cap-card-head::before {
    background: radial-gradient(circle, #8e44ad 0%, transparent 70%);
}


/* Thin accent top-border */

.cap-card-head::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}

.cap-pharma .cap-card-head::after {
    background: linear-gradient(to right, var(--red), var(--red-mid));
}

.cap-nutra .cap-card-head::after {
    background: linear-gradient(to right, #1e8449, #27ae60);
}

.cap-cosm .cap-card-head::after {
    background: linear-gradient(to right, #6c3483, #8e44ad);
}


/* Icon box */

.cap-card-icon {
    width: 62px;
    height: 62px;
    border-radius: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.65rem;
    margin-bottom: 18px;
    position: relative;
    z-index: 1;
}

.cap-pharma .cap-card-icon {
    background: rgba(237, 28, 36, .16);
    color: #ff6b6b;
}

.cap-nutra .cap-card-icon {
    background: rgba(39, 174, 96, .16);
    color: #52d68a;
}

.cap-cosm .cap-card-icon {
    background: rgba(142, 68, 173, .16);
    color: #c39be0;
}


/* Title */

.cap-card-title {
    font-size: 1.13rem;
    font-weight: 800;
    color: var(--white);
    margin-bottom: 10px;
    position: relative;
    z-index: 1;
}


/* Desc */

.cap-card-desc {
    font-size: .81rem;
    color: rgba(255, 255, 255, .55);
    line-height: 1.68;
    margin-bottom: 18px;
    position: relative;
    z-index: 1;
}


/* Badge pill */

.cap-card-badge {
    display: inline-flex;
    align-items: center;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 5px 13px;
    border-radius: 50px;
    position: relative;
    z-index: 1;
}

.cap-pharma .cap-card-badge {
    background: rgba(237, 28, 36, .2);
    color: #ff9090;
    border: 1px solid rgba(237, 28, 36, .28);
}

.cap-nutra .cap-card-badge {
    background: rgba(39, 174, 96, .2);
    color: #7ee8a8;
    border: 1px solid rgba(39, 174, 96, .28);
}

.cap-cosm .cap-card-badge {
    background: rgba(142, 68, 173, .2);
    color: #d0a8f0;
    border: 1px solid rgba(142, 68, 173, .28);
}


/* ── Card body (white) ── */

.cap-card-body {
    padding: 26px 30px 30px;
    flex: 1;
    display: flex;
    flex-direction: column;
}


/* Checklist */

.cap-list {
    list-style: none;
    padding: 0;
    margin: 0 0 22px;
    flex: 1;
}

.cap-list li {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
    font-size: .875rem;
    font-weight: 500;
    color: var(--dark);
    transition: color .2s;
}

.cap-list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.cap-list li i {
    font-size: .78rem;
    flex-shrink: 0;
}

.cap-pharma .cap-list li i {
    color: var(--red);
}

.cap-nutra .cap-list li i {
    color: #27ae60;
}

.cap-cosm .cap-list li i {
    color: #8e44ad;
}

.cap-card:hover .cap-list li {
    color: var(--dark);
}


/* "View all" link */

.cap-card-link {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: .82rem;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: .2px;
    transition: gap .22s ease, opacity .2s;
    margin-top: auto;
}

.cap-pharma .cap-card-link {
    color: var(--red);
}

.cap-nutra .cap-card-link {
    color: #1e8449;
}

.cap-cosm .cap-card-link {
    color: #7d3c98;
}

.cap-card-link:hover {
    gap: 13px;
    opacity: .85;
}


/* ── Bottom trust strip ── */

.cap-bottom-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
    background: var(--white);
    border-radius: 14px;
    padding: 18px 32px;
    box-shadow: 0 2px 20px rgba(0, 0, 0, .07);
    border: 1px solid var(--border);
}

.cap-strip-item {
    display: flex;
    align-items: center;
    gap: 9px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--dark);
    padding: 10px 28px;
    white-space: nowrap;
}

.cap-strip-item i {
    font-size: .9rem;
    color: var(--red);
}

.cap-strip-sep {
    width: 1px;
    height: 30px;
    background: var(--border);
    flex-shrink: 0;
}

@media (max-width: 991px) {
    .cap-strip-sep:nth-child(6) {
        display: none;
    }
}

@media (max-width: 767px) {
    .cap-strip-sep {
        display: none;
    }
    .cap-strip-item {
        width: 50%;
        justify-content: center;
    }
    .cap-bottom-strip {
        padding: 14px 16px;
    }
}

@media (max-width: 400px) {
    .cap-strip-item {
        width: 100%;
    }
}


/* ─── FOOTER ─────────────────────────────────────────────── */

.site-footer {
    background: #f6f6f6;
    color: #000000;
    font-family: "Plus Jakarta Sans", sans-serif;
}


/* ─── FOOTER CTA STRIP — Premium redesign ─────────────── */

.footer-cta-strip {
    background: linear-gradient(115deg, #0f0b0a 0%, #1c0d0e 55%, #240e10 100%);
    padding: 44px 0;
    position: relative;
    overflow: hidden;
    border-top: 3px solid var(--red);
}


/* Dot grid */

.footer-cta-strip::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(237, 28, 36, .08) 1px, transparent 1px);
    background-size: 20px 20px;
    pointer-events: none;
}


/* Glow orb */

.footer-cta-strip::after {
    content: '';
    position: absolute;
    right: -120px;
    top: 50%;
    transform: translateY(-50%);
    width: 380px;
    height: 380px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(237, 28, 36, .2) 0%, transparent 65%);
    pointer-events: none;
}

.footer-cta-strip .container {
    position: relative;
    z-index: 2;
}


/* Eyebrow label */

.fcta-eyebrow {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(255, 255, 255, .38);
    margin-bottom: 9px;
}


/* Main headline */

.fcta-headline {
    font-size: clamp(1.05rem, 2.2vw, 1.45rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.3;
    margin: 0;
}

.fcta-headline span {
    color: var(--red);
}


/* Centre stats column */

.fcta-stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.fcta-stat {
    text-align: center;
    padding: 0 22px;
}

.fcta-stat strong {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1;
}

.fcta-stat small {
    font-size: .65rem;
    color: rgba(255, 255, 255, .4);
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-top: 5px;
    display: block;
}

.fcta-stat-sep {
    width: 1px;
    height: 36px;
    background: rgba(255, 255, 255, .1);
    flex-shrink: 0;
}


/* CTA buttons */

.fcta-btns {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: flex-end;
}

.fcta-btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--red);
    color: var(--white) !important;
    font-size: .82rem;
    font-weight: 700;
    padding: 12px 24px;
    border-radius: var(--radius);
    text-decoration: none;
    transition: all var(--dur);
    box-shadow: 0 4px 20px rgba(237, 28, 36, .42);
    white-space: nowrap;
}

.fcta-btn-primary:hover {
    background: var(--red-dark);
    transform: translateY(-2px);
    box-shadow: 0 7px 26px rgba(237, 28, 36, .52);
}

.fcta-btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, .07);
    color: rgba(255, 255, 255, .82) !important;
    font-size: .82rem;
    font-weight: 600;
    padding: 11px 24px;
    border-radius: var(--radius);
    border: 1.5px solid rgba(255, 255, 255, .16);
    text-decoration: none;
    transition: all var(--dur);
    white-space: nowrap;
    backdrop-filter: blur(6px);
}

.fcta-btn-ghost:hover {
    background: rgba(255, 255, 255, .13);
    border-color: rgba(255, 255, 255, .3);
    color: var(--white) !important;
    transform: translateY(-2px);
}

@media (max-width: 1199px) {
    .fcta-btns {
        flex-direction: row;
        align-items: center;
        flex-wrap: wrap;
    }
}

@media (max-width: 575px) {
    .fcta-btns {
        flex-direction: column;
        align-items: stretch;
    }
    .fcta-btn-primary,
    .fcta-btn-ghost {
        justify-content: center;
    }
}


/* Keep old footer-cta-btn aliases working just in case */

.footer-cta-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 4px;
}

.footer-cta-sub {
    font-size: .78rem;
    color: rgba(255, 255, 255, .72);
    margin: 0;
}

.footer-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: var(--white);
    color: var(--red)!important;
    font-size: .82rem;
    font-weight: 700;
    padding: 10px 22px;
    border-radius: var(--radius);
    text-decoration: none;
    transition: all var(--dur);
}

.footer-cta-btn.ghost {
    background: rgba(255, 255, 255, .12);
    color: var(--white)!important;
    border: 1.5px solid rgba(255, 255, 255, .3);
}


/* Footer body */

.footer-body {
    padding: 72px 0 56px;
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}


/* Logo */

.footer-logo {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
}

.footer-logo img {
    height: 75px;
    display: block;
}

.footer-tagline {
    font-size: .76rem;
    color: #000000e3;
    margin-top: 8px;
    font-style: italic;
    letter-spacing: .3px;
    text-align: center;
}

.footer-desc {
    font-size: .82rem;
    color: #000000e3;
    line-height: 1.9;
    margin: 14px 0 18px;
}


/* Cert badges */

.footer-badges {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.footer-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgb(245 228 229);
    border: 1px solid rgb(245 228 229);
    border-radius: 50px;
    padding: 4px 11px;
    font-size: .68rem;
    font-weight: 600;
    color: #000000;
    letter-spacing: .4px;
}

.footer-badge i {
    color: var(--red);
    font-size: .65rem;
}


/* Social icons */

.footer-social {
    display: flex;
    gap: 8px;
}

.footer-social a {
    width: 36px;
    height: 36px;
    background: rgb(237 28 36);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgb(255 255 255);
    font-size: .82rem;
    transition: all var(--dur);
    text-decoration: none;
}

.footer-social a:hover {
    background: var(--red);
    border-color: var(--red);
    color: var(--white);
    transform: translateY(-2px);
}


/* Section heading */

.footer-h {
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: #ed1c24;
    margin-bottom: 10px;
    padding-bottom: 12px;
    position: relative;
}

.footer-h::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 24px;
    height: 2px;
    background: var(--red);
    border-radius: 2px;
}


/* Nav links */

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links li {
    margin-bottom: 3px;
}

.footer-links a {
    font-size: .9rem;
    color: #000000e3;
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    transition: all .2s;
}

.footer-links a::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--red);
    flex-shrink: 0;
    opacity: .9;
    transition: opacity .2s;
}

.footer-links a:hover {
    color: #000000;
    padding-left: 4px;
}

.footer-links a:hover::before {
    opacity: 1;
}


/* Download buttons */

.footer-dl {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgb(245 228 229);
    border: 1px solid rgb(245 228 229);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    color: #000000;
    font-size: .79rem;
    margin-bottom: 8px;
    text-decoration: none;
    transition: all .2s;
}

.footer-dl:hover {
    background: rgba(237, 28, 36, .16);
    border-color: rgba(237, 28, 36, .32);
    color: #000000;
    transform: translateX(3px);
}

.footer-dl i:first-child {
    color: var(--red);
    font-size: .9rem;
}

.footer-dl span {
    flex: 1;
}

.footer-dl .fa-download {
    font-size: .7rem;
    opacity: 1;
}

.footer-dl:hover .fa-download {
    opacity: 1;
}


/* Contact rows */

.footer-contact-row {
    display: flex;
    align-items: flex-start;
    gap: 13px;
    margin-bottom: 14px;
    font-size: .82rem;
    color: #000000e3;
}

.footer-contact-row>i {
    color: var(--red);
    font-size: .9rem;
    margin-top: 2px;
    flex-shrink: 0;
    width: 16px;
    text-align: center;
}

.footer-contact-row strong {
    color: rgba(255, 255, 255, .8);
    font-size: .82rem;
    display: block;
}

.footer-contact-row a {
    color: #000000e3;
    text-decoration: none;
    transition: color .2s;
}

.footer-contact-row a:hover {
    color: var(--red);
}


/* Global office card */

.footer-global-office {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: rgba(237, 28, 36, .08);
    border: 1px solid rgba(237, 28, 36, .22);
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-top: 18px;
}

.footer-global-ico {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    background: rgba(237, 28, 36, .18);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: .95rem;
}

.footer-global-office strong {
    display: block;
    font-size: .78rem;
    font-weight: 700;
    color: #000000e3;
    margin-bottom: 2px;
}

.footer-global-office span {
    display: block;
    font-size: .78rem;
    color: #000000e3;
}

.footer-global-office small {
    display: block;
    font-size: .72rem;
    color: #000000e3;
}


/* Footer bottom bar */

.footer-bottom {
    padding: 15px 0;
    font-size: .77rem;
    color: rgb(255 255 255);
    background: #ed1c24;
}

.footer-bottom a {
    color: rgba(255, 255, 255);
    text-decoration: none;
    transition: color .2s;
}

.footer-bottom a:hover {
    color: #ffffff;
}

.footer-bottom-sep {
    margin: 0 8px;
    opacity: 1;
}


/* ─── DESKTOP HOVER DROPDOWNS ─────────────────────────────── */

@media (min-width: 992px) {
    /* Bootstrap dropdowns */
    .site-header .navbar-nav .nav-item.dropdown:hover > .dropdown-menu {
        display: block !important;
        animation: ddSlide .18s var(--ease);
    }

    /* Products mega menu */
    .site-header .navbar-nav .mega-dropdown:hover > .mega-menu {
        display: flex !important;
        animation: ddSlide .22s var(--ease);
    }

    /* Rotate arrow when mega menu is open via hover */
    .site-header .mega-dropdown:hover .mega-trigger .nav-arrow,
    .site-header .mega-dropdown:hover .mega-trigger .mega-arrow {
        opacity: .8;
        transform: rotate(180deg);
    }
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */

/* Large laptops (1200–1399px) — reduce horizontal padding so all nav items fit */
@media (min-width: 1200px) and (max-width: 1399px) {
    .navbar-nav>.nav-item>.nav-link,
    .navbar-nav>.nav-item>.mega-trigger {
        padding: 0 14px !important;
        font-size: .82rem;
    }
}

@media (max-width: 1199px) {
    .navbar-nav>.nav-item>.nav-link {
        padding: 26px 10px !important;
        font-size: .79rem;
    }
}

@media (max-width: 991px) {
    .site-header {
        position: relative;
    }
    .top-bar .top-bar-left {
        display: none;
    }
    .navbar-nav>.nav-item>.nav-link {
        padding: 11px 0 !important;
        font-size: .88rem;
    }
    .navbar-nav>.nav-item>.nav-link::after {
        display: none;
    }
    .dropdown-menu {
        box-shadow: none;
        border: none;
        animation: none;
        border-top: none;
        padding: 0 0 0 14px;
    }
    .mega-menu {
        position: static;
        box-shadow: none;
        animation: none;
        border: none;
        padding: 0 0 0 14px;
    }
    .hero-slide {
        min-height: 70vh;
    }
    .hero-h1 {
        font-size: clamp(1.9rem, 5vw, 3rem);
    }
    .section-pad {
        padding: 70px 0;
    }
    .about-img-frame img {
        height: 380px;
    }
}

@media (max-width: 767px) {
    .hero-slide {
        min-height: 100vh;
    }
    .hero-kpis {
        gap: 20px;
    }
    .stat-box+.stat-box::before {
        display: none;
    }
    .section-pad {
        padding: 56px 0;
    }
    .form-wrap {
        padding: 28px 22px;
    }
}

@media (max-width: 575px) {
    .hero-btns {
        flex-direction: column;
    }
    .hero-btns .btn-red,
    .hero-btns .btn-white-ghost {
        width: 100%;
        justify-content: center;
    }
}


/* ──────────────────────────────────────────────────────────
   BACKWARDS COMPATIBILITY ALIASES
   (keeps all existing pages working with v2 CSS)
   ────────────────────────────────────────────────────────── */


/* Button aliases */

.btn-brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--red);
    color: var(--white);
    font-size: .875rem;
    font-weight: 600;
    padding: 13px 30px;
    border-radius: var(--radius);
    border: 2px solid var(--red);
    letter-spacing: .2px;
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-brand:hover {
    background: #ed1c24;
    border-color: #ed1c24;
    color: var(--white);
    transform: translateY(-2px);
}

.btn-brand-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--red);
    font-size: .875rem;
    font-weight: 600;
    padding: 12px 28px;
    border-radius: var(--radius);
    border: 2px solid var(--red);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-brand-outline:hover {
    background: var(--red);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: var(--shadow-red);
}

.btn-white-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, .08);
    color: var(--white);
    font-size: .875rem;
    font-weight: 600;
    padding: 12px 28px;
    border-radius: var(--radius);
    border: 2px solid rgba(255, 255, 255, .35);
    backdrop-filter: blur(8px);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

.btn-white-outline:hover {
    background: var(--white);
    color: var(--red);
    border-color: var(--white);
}


/* Section label (old eyebrow) */

.section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 14px;
}

.section-label::before {
    content: '';
    display: block;
    width: 28px;
    height: 2px;
    background: var(--red);
    border-radius: 2px;
}


/* Section title em fallback (span.highlight) */

.section-title span,
.section-title .highlight {
    color: var(--red);
}


/* Divider */

.divider {
    width: 60px;
    height: 3px;
    background: var(--red);
    border-radius: 2px;
    margin: 16px 0;
}

.divider-center {
    margin: 16px auto;
}


/* Feature card (old name) */

.feature-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 32px 26px;
    box-shadow: var(--shadow-xs);
    transition: all var(--dur) var(--ease);
    height: 100%;
    position: relative;
    overflow: hidden;
}

.feature-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--red);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s var(--ease);
}

.feature-card:hover::after {
    transform: scaleX(1);
}

.feature-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: transparent;
}

.feature-icon {
    width: 58px;
    height: 58px;
    background: #fff0f0;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--red);
    margin-bottom: 18px;
    transition: all var(--dur);
}

.feature-card:hover .feature-icon {
    background: var(--red);
    color: var(--white);
}

.feature-card h5 {
    font-size: .97rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.feature-card p {
    font-size: .83rem;
    color: var(--muted);
    margin: 0;
    line-height: 1.7;
}


/* Product category card (old name) */

.product-category-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: all var(--dur) var(--ease);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.product-category-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: transparent;
}

.product-cat-header {
    padding: 30px 26px 22px;
    background: linear-gradient(135deg, #1e1917 0%, #3a2020 100%);
    color: var(--white);
}

.product-cat-icon {
    font-size: 2.4rem;
    color: var(--red);
    display: block;
    margin-bottom: 12px;
}

.product-cat-header h4 {
    color: var(--white);
    margin-bottom: 8px;
}

.product-cat-header p {
    font-size: .82rem;
    color: rgba(255, 255, 255);
    margin: 0;
}

.product-cat-body {
    padding: 20px 22px;
    flex: 1;
}

.product-tag {
    display: inline-block;
    font-size: .72rem;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 50px;
    border: 1.5px solid var(--border);
    color: var(--muted);
    background: var(--white);
    margin: 3px 2px;
    transition: all var(--dur);
}

.product-tag:hover {
    border-color: var(--red);
    color: var(--red);
    background: #fff5f5;
}

.product-cat-footer {
    padding: 14px 22px;
    border-top: 1px solid var(--border);
}


/* About home image fallback */

.about-home-img {
    position: relative;
}

.exp-badge {
    position: absolute;
    bottom: 24px;
    left: 24px;
    background: var(--red);
    color: var(--white);
    border-radius: var(--radius-lg);
    padding: 14px 20px;
    box-shadow: var(--shadow-red);
}

.exp-badge strong {
    display: block;
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}

.exp-badge span {
    font-size: .72rem;
    opacity: .88;
}


/* Strength items */

.strength-item {
    display: flex;
    align-items: flex-start;
    gap: 13px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
}

.strength-item:last-child {
    border-bottom: none;
}

.strength-icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    background: #fff0f0;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    font-size: 1.1rem;
}

.strength-item h6 {
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 2px;
}

.strength-item p {
    font-size: .81rem;
    color: var(--muted);
    margin: 0;
    line-height: 1.6;
}


/* Mega menu show class — must be flex to support dark-panel + columns layout */

.mega-menu.show,
.mega-menu.open {
    display: flex !important;
}

.mega-dropdown {
    position: static !important;
}

.mega-parent {
    position: static !important;
}


/* WhatsApp float (header.php uses .whatsapp-float, CSS has .wa-float) */

.whatsapp-float {
    position: fixed;
    bottom: 28px;
    right: 28px;
    width: 58px;
    height: 58px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.65rem;
    color: var(--white);
    box-shadow: 0 6px 24px rgba(37, 211, 102, .5);
    z-index: 9999;
    transition: all var(--dur);
    animation: waPulse 2.5s infinite;
}

.whatsapp-float:hover {
    color: var(--white);
    transform: scale(1.1);
}


/* Back to top (header.php uses #backToTop, CSS had #backTop; JS adds .visible) */

#backToTop {
    position: fixed;
    bottom: 98px;
    right: 28px;
    width: 44px;
    height: 44px;
    background: var(--dark);
    color: var(--white);
    border: none;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    box-shadow: var(--shadow-md);
    z-index: 9998;
    opacity: 0;
    transform: translateY(10px);
    transition: all var(--dur);
    cursor: pointer;
}

#backToTop.visible,
#backToTop.show {
    opacity: 1;
    transform: translateY(0);
}

#backToTop:hover {
    background: var(--red);
    transform: translateY(-3px);
}


/* Old reveal .visible compatibility (JS now adds .in but some cached pages may still use .visible) */

.reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

.reveal-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.reveal-right.visible {
    opacity: 1;
    transform: translateX(0);
}

.reveal-scale.visible {
    opacity: 1;
    transform: scale(1);
}


/* Old stats bar classes */

.stats-bar .stat-item {
    padding: 36px 20px;
    text-align: center;
    position: relative;
}

.stats-bar .stat-icon {
    font-size: 1.8rem;
    color: var(--red);
    display: block;
    margin-bottom: 10px;
}

.stats-bar .stat-number {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1;
}

.stats-bar .stat-label {
    font-size: .74rem;
    color: #000000e3;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-weight: 600;
    margin-top: 4px;
}


/* Old global map section */

.global-map-section {
    background: #f6f6f6;
    position: relative;
    overflow: hidden;
}


/* .global-map-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url('../images/silok/map.svg');
    background-size: 70%;
    background-position: right center;
    background-repeat: no-repeat;
    opacity: .05;
} */


/* ─── CTA SECTION — Premium dark redesign ─────────────── */


/* .cta-section {
    background: #0c0908;
    padding: 88px 0;
    position: relative;
    overflow: hidden;
    border-top: 1px solid rgba(255, 255, 255, .06);
    border-bottom: 1px solid rgba(255, 255, 255, .06);
} */

.cta-section {
    background: #f5e4e5;
    padding: 88px 0;
    position: relative;
    overflow: hidden;
    border-top: 3px solid rgb(237 28 36);
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}


/* Angled red ambient glow — right half */

.cta-section::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 60%;
    height: 100%;
    background: linear-gradient(120deg, transparent 30%, rgba(192, 16, 26, .13) 100%);
    pointer-events: none;
}


/* Dot-grid texture */

.cta-section::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, .042) 1px, transparent 1px);
    background-size: 24px 24px;
    pointer-events: none;
}

.cta-section .container {
    position: relative;
    z-index: 2;
}


/* Radial glow orb on right */

.cta-section .container::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -200px;
    transform: translateY(-50%);
    width: 440px;
    height: 440px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(237, 28, 36, .14) 0%, transparent 65%);
    pointer-events: none;
    z-index: -1;
}


/* Decorative red bar above headline */

.cta-section h2::before {
    content: '';
    display: block;
    width: 44px;
    height: 3px;
    background: var(--red);
    border-radius: 2px;
    margin-bottom: 18px;
}

.cta-section h2 {
    color: #1e1917;
    font-size: clamp(1.65rem, 3.2vw, 2.35rem);
    font-weight: 800;
    line-height: 1.22;
    margin-bottom: 14px;
}

.cta-section h2 strong {
    color: var(--red);
}

.cta-section p {
    color: #121212;
    font-size: .97rem;
    line-height: 1.68;
    max-width: 520px;
}


/* Centre-text variant (products.php) */

.cta-section .container.text-center p {
    margin-left: auto;
    margin-right: auto;
}

.cta-section .container.text-center h2::before {
    margin-left: auto;
    margin-right: auto;
}


/* Cert strip legacy stub */

.cert-strip {
    background: var(--light);
}


/* Old blog card / blog-img placeholder */

.blog-img {
    height: 196px;
    background: linear-gradient(135deg, #fff0f0, #fde8e8);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: var(--red);
    position: relative;
}

.blog-category {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--red);
    color: var(--white);
    font-size: .68rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 50px;
    letter-spacing: .8px;
    text-transform: uppercase;
}

.blog-body {
    padding: 22px;
}

.blog-meta {
    font-size: .75rem;
    color: var(--muted);
    margin-bottom: 8px;
}

.blog-body h5 {
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: 8px;
    line-height: 1.4;
}

.blog-body h5 a {
    color: var(--dark);
}

.blog-body h5 a:hover {
    color: var(--red);
}

.blog-body p {
    font-size: .82rem;
    color: var(--muted);
}

.blog-link {
    font-size: .8rem;
    font-weight: 700;
    color: var(--red);
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.blog-link:hover {
    gap: 10px;
    color: var(--red-dark);
}


/* Old hero classes */

.hero-section {
    position: relative;
}

.hero-title {
    font-size: clamp(2.2rem, 5vw, 3.8rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.1;
    margin-bottom: 18px;
}

.hero-title span {
    color: var(--red);
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(237, 28, 36, .18);
    border: 1px solid rgba(237, 28, 36, .4);
    color: #ffaaad;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 7px 18px;
    border-radius: 50px;
    margin-bottom: 20px;
    backdrop-filter: blur(6px);
}

.hero-text {
    font-size: 1.05rem;
    color: rgba(255, 255, 255, .78);
    line-height: 1.85;
    margin-bottom: 34px;
}

.hero-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

.hero-stats {
    display: flex;
    gap: 28px;
    flex-wrap: wrap;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, .12);
}

.hero-stat strong {
    display: block;
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1;
}

.hero-stat small {
    font-size: .7rem;
    color: rgba(255, 255, 255, .5);
    text-transform: uppercase;
    letter-spacing: .8px;
}

.hero-card-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 9px 0;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
    font-size: .875rem;
    color: rgba(255, 255, 255, .85);
}

.hero-card-icon {
    width: 36px;
    height: 36px;
    background: rgba(237, 28, 36, .22);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ff8b8f;
    font-size: .85rem;
    flex-shrink: 0;
}


/* Old hero slides gradient backgrounds */

.hero-slide-1 {
    background: linear-gradient(100deg, rgba(10, 5, 3, .92) 0%, rgba(10, 5, 3, .55) 60%, rgba(120, 10, 14, .4) 100%), url('../../images/05.jpg') center/cover no-repeat;
}

.hero-slide-2 {
    background: linear-gradient(100deg, rgba(5, 15, 5, .92) 0%, rgba(5, 15, 5, .55) 60%, rgba(10, 60, 15, .4) 100%), url('../../images/04.jpg') center/cover no-repeat;
}

.hero-slide-3 {
    background: linear-gradient(100deg, rgba(8, 8, 20, .92) 0%, rgba(8, 8, 20, .55) 60%, rgba(15, 10, 60, .4) 100%), url('../../images/21.jpg') center/cover no-repeat;
}


/* Old section backgrounds */

.bg-light-brand {
    background: var(--light);
}

.section-pad-sm {
    padding: 68px 0;
}

.section-sub {
    font-size: 1rem;
    color: var(--muted);
    line-height: 1.8;
}

.country-chip .flag {
    font-size: 1.1rem;
}


/* Mobile offcanvas CTA padding */

.nav-oc-body>.btn-red {
    margin: 0 16px 16px;
    width: calc(100% - 32px) !important;
}

.mob-nav-group {
    margin: 0;
}


/* Responsive: on lg+ always show desktop nav */

@media (min-width: 992px) {
    .navbar-collapse {
        display: flex !important;
    }
    .mega-menu {
        left: 0;
        right: 0;
    }
}

@media (max-width: 991px) {
    .site-header .navbar {
        min-height: 64px;
    }
    .navbar-brand img {
        height: 44px;
    }
}


/* fw-700 utility */

.fw-700 {
    font-weight: 700 !important;
}


/* ════════════════════════════════════════════════════════════
   HOME PAGE — MANUFACTURING SNAPSHOT (PREMIUM)
════════════════════════════════════════════════════════════ */

.hm-mfg-section {
    background: var(--light);
    position: relative;
    overflow: hidden;
}

.hm-mfg-section::before {
    content: '';
    position: absolute;
    top: -160px;
    right: -160px;
    width: 440px;
    height: 440px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(237, 28, 36, .055) 0%, transparent 70%);
    pointer-events: none;
}

.hm-mfg-lead {
    font-size: .95rem;
    color: var(--muted);
    line-height: 1.9;
    margin-bottom: 2rem;
    max-width: 500px;
}


/* ── Capability Tiles Grid ── */

.hm-caps-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 2rem;
}

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

.hm-cap-item {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 18px 16px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    position: relative;
    overflow: hidden;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}

.hm-cap-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom, var(--red), var(--red-mid));
    transform: scaleY(0);
    transform-origin: top;
    transition: transform .28s ease;
    border-radius: 0 3px 3px 0;
}

.hm-cap-item:hover {
    border-color: rgba(237, 28, 36, .22);
    box-shadow: 0 6px 24px rgba(237, 28, 36, .08);
    transform: translateY(-3px);
}

.hm-cap-item:hover::before {
    transform: scaleY(1);
}

.hm-cap-ico {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
    transition: transform .25s ease;
}

.hm-cap-item:hover .hm-cap-ico {
    transform: scale(1.08);
}

.hm-cap-text {
    flex: 1;
    min-width: 0;
}

.hm-cap-name {
    font-size: .85rem;
    font-weight: 700;
    color: var(--dark);
    margin-bottom: 4px;
    line-height: 1.3;
}

.hm-cap-desc {
    font-size: .75rem;
    color: var(--muted);
    line-height: 1.55;
    margin: 0;
}

.hm-mfg-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
}


/* ── Image Panel ── */

.hm-mfg-img-wrap {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.hm-mfg-img-wrap img {
    width: 100%;
    /* height: 480px; */
    object-fit: cover;
    display: block;
}


/* .hm-mfg-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, .1) 0%, rgba(0, 0, 0, .45) 100%);
    pointer-events: none;
} */

.hm-mfg-badge {
    position: absolute;
    background: var(--white);
    border-radius: var(--radius);
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 8px 28px rgba(0, 0, 0, .18);
    z-index: 2;
    animation: floatBadge 3.5s ease-in-out infinite alternate;
}

.hm-mfg-badge-tl {
    top: 22px;
    left: 22px;
    animation-delay: 0s;
}

.hm-mfg-badge-br {
    bottom: 62px;
    right: 22px;
    animation-delay: .8s;
}

@keyframes floatBadge {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(-7px);
    }
}

.hm-mfg-badge-ico {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    flex-shrink: 0;
}

.hm-mfg-badge-text strong {
    display: block;
    font-size: .83rem;
    font-weight: 700;
    color: var(--dark);
    line-height: 1.2;
}

.hm-mfg-badge-text small {
    font-size: .7rem;
    color: var(--muted);
}

.hm-mfg-strip {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(14, 10, 9, .78);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
    padding: 14px 20px;
    z-index: 2;
}

.hm-mfg-strip span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .72rem;
    font-weight: 700;
    color: rgba(255, 255, 255, .85);
    text-transform: uppercase;
    letter-spacing: .8px;
}

.hm-mfg-strip span i {
    color: var(--red);
    font-size: .7rem;
}

@media (max-width: 575px) {
    .hm-mfg-strip {
        gap: 14px;
    }
    .hm-mfg-strip span {
        font-size: .63rem;
    }
    .hm-mfg-img-wrap img {
        height: 340px;
    }
}


/* ════════════════════════════════════════════════════════════
   HOME PAGE — CERTIFICATIONS STRIP (PREMIUM)
════════════════════════════════════════════════════════════ */

.hm-cert-section {
    background: var(--white);
    position: relative;
    overflow: hidden;
}

.hm-cert-section::before {
    content: '';
    position: absolute;
    inset: 0;
    /* background:
        radial-gradient(circle at 5% 50%, rgba(237,28,36,.04) 0%, transparent 50%),
        radial-gradient(circle at 95% 50%, rgba(30,100,200,.04) 0%, transparent 50%); */
    pointer-events: none;
}

.hm-cert-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 28px 20px 22px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-xs);
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}

.hm-cert-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(to right, var(--red), var(--red-mid));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .32s ease;
}

.hm-cert-card:hover {
    transform: translateY(-7px);
    box-shadow: var(--shadow-md);
    border-color: rgba(237, 28, 36, .2);
}

.hm-cert-card:hover::after {
    transform: scaleX(1);
}

.hm-cert-ico {
    width: 62px;
    height: 62px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.45rem;
    margin-bottom: 16px;
    transition: transform .28s ease;
}

.hm-cert-card:hover .hm-cert-ico {
    transform: scale(1.1) rotate(-4deg);
}

.hm-cert-title {
    font-size: .88rem;
    font-weight: 800;
    color: var(--dark);
    margin-bottom: 6px;
    line-height: 1.3;
}

.hm-cert-desc {
    font-size: .74rem;
    color: var(--muted);
    line-height: 1.55;
    flex: 1;
    margin-bottom: 14px;
}

.hm-cert-check {
    font-size: .67rem;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 5px;
}

.hm-cert-check i {
    font-size: .78rem;
}


/* ─── CERTIFICATIONS — DOCUMENTATION PANEL + DOC ITEMS ─── */


/* Section bg */

.cert-docs-section {
    background: var(--light);
}


/* Left dark intro panel */

.cert-docs-panel {
    background: #ffffff;
    border-radius: var(--radius-xl);
    padding: 36px 32px;
    color: var(--white);
    height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    /* box-shadow: var(--shadow-lg); */
}

.cert-docs-panel::before {
    content: '';
    position: absolute;
    inset: 0;
    /* background: radial-gradient(circle at 80% 20%, rgba(237, 28, 36, .18) 0%, transparent 65%); */
    pointer-events: none;
}

.cert-docs-panel-ico {
    width: 60px;
    height: 60px;
    background: rgba(237, 28, 36, .18);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--red);
    margin-bottom: 20px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

.cert-docs-panel-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: #1e1917;
    margin-bottom: 12px;
    line-height: 1.35;
    position: relative;
    z-index: 1;
}

.cert-docs-panel-desc {
    font-size: .83rem;
    color: #000000e3;
    line-height: 1.7;
    flex: 1;
    margin-bottom: 24px;
    position: relative;
    z-index: 1;
}

.cert-docs-panel-stats {
    display: flex;
    align-items: center;
    gap: 0;
    background: #f6f6f6;
    border-radius: var(--radius);
    padding: 16px 20px;
    margin-bottom: 24px;
    border: 1px solid rgba(255, 255, 255, .1);
    position: relative;
    z-index: 1;
}

.cert-docs-ps {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
}

.cert-docs-ps-num {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--red);
    line-height: 1;
}

.cert-docs-ps-lbl {
    font-size: .72rem;
    color: #000000e3;
    font-weight: 500;
    margin-top: 4px;
}

.cert-docs-ps-sep {
    width: 1px;
    height: 36px;
    background: rgb(0 0 0 / 40%);
    flex-shrink: 0;
    margin: 0 16px;
}

.cert-docs-panel-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--red);
    color: var(--white);
    font-size: .82rem;
    font-weight: 700;
    padding: 12px 22px;
    border-radius: 8px;
    letter-spacing: .4px;
    transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
    position: relative;
    z-index: 1;
    align-self: flex-start;
}

.cert-docs-panel-cta:hover {
    background: var(--red-dark);
    color: var(--white);
    transform: translateY(-2px);
}


/* Right doc grid items */

.cert-doc-item {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
    height: 100%;
}

.cert-doc-item:hover {
    border-color: rgba(237, 28, 36, .35);
    box-shadow: 0 4px 18px rgba(237, 28, 36, .08);
    transform: translateY(-3px);
}

.cert-doc-num {
    font-size: .65rem;
    font-weight: 700;
    color: var(--red);
    background: rgba(237, 28, 36, .08);
    border-radius: 6px;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    letter-spacing: .4px;
    margin-top: 2px;
}

.cert-doc-ico {
    width: 32px;
    height: 32px;
    background: var(--light);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    color: var(--dark);
    flex-shrink: 0;
    margin-top: 2px;
    transition: background var(--dur), color var(--dur);
}

.cert-doc-item:hover .cert-doc-ico {
    background: rgba(237, 28, 36, .1);
    color: var(--red);
}

.cert-doc-info {
    flex: 1;
    min-width: 0;
}

.cert-doc-name {
    font-size: .82rem;
    font-weight: 700;
    color: var(--dark);
    line-height: 1.3;
    margin-bottom: 3px;
}

.cert-doc-desc {
    font-size: .72rem;
    color: var(--muted);
    line-height: 1.5;
}


/* ─── CERTIFICATIONS RESPONSIVE ──────────────────────────── */

@media (max-width: 991px) {
    .cert-docs-panel {
        margin-bottom: 8px;
    }
}

@media (max-width: 575px) {
    .cert-card-body {
        padding: 18px 16px 12px;
    }
    .cert-card-foot {
        padding: 8px 16px 14px;
    }
    .cert-docs-panel {
        padding: 28px 22px;
    }
    .cert-docs-panel-stats {
        padding: 12px 14px;
    }
}

.btn_border_red:hover {
    background: transparent;
    color: #ed1c24 !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(255, 255, 255, .18);
    border: 1px solid #ed1c24 !important;
}


/* ════════════════════════════════════════════════════════════
   PHARMACEUTICALS PAGE — PREMIUM
════════════════════════════════════════════════════════════ */


/* ── Filter Bar ── */

.pf-bar {
    background: #ffffff;
    border-top: 3px solid var(--red);
    border-bottom: 3px solid rgba(237, 28, 36, .15);
    padding: 16px 0;
    position: -webkit-sticky;
    /* iOS Safari */
    position: sticky;
    top: 78px;
    /* navbar height — same on desktop & mobile */
    z-index: 90;
}


/* Bootstrap nav-pills override inside filter bar */

.pf-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    justify-content: center;
    align-items: center;
    --bs-nav-pills-border-radius: 50px;
    --bs-nav-pills-link-active-color: #fff;
    --bs-nav-pills-link-active-bg: transparent;
}


/* Base pill button */

.pf-pills .nav-link {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: .78rem;
    font-weight: 500;
    letter-spacing: .3px;
    padding: 10px 18px;
    border-radius: 50px !important;
    border: 1.5px solid rgba(255, 255, 255, .14);
    background: #f6f6f6;
    color: rgb(0 0 0);
    white-space: nowrap;
    line-height: 1;
    transition: all .22s ease;
}


/* Hover */

.pf-pills .nav-link:hover:not(.active) {
    border-color: var(--red);
    color: #000000;
    background: rgba(237, 28, 36, .12);
}


/* Active */

.pf-pills .nav-link.active,
.pf-pills .show>.nav-link {
    background: #ed1c24 !important;
    border-color: transparent !important;
    color: var(--white) !important;
    /* box-shadow: 0 4px 14px rgba(237, 28, 36, .45); */
    font-weight: 600;
}


/* Tab pane transitions */

.tab-pane {
    animation: tabFadeIn .28s ease;
}

@keyframes tabFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


/* ── Catalogue section ── */

.ph-catalogue-section {
    background: var(--light);
}

.ph-cat-block {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 32px 28px;
    box-shadow: var(--shadow-xs);
    transition: box-shadow .25s;
    scroll-margin-top: 110px;
}

.ph-cat-block:hover {
    box-shadow: var(--shadow-sm);
}


/* ── Category Header ── */

.ph-cat-header {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

.ph-cat-icon {
    width: 58px;
    height: 58px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.ph-cat-meta {
    flex: 1;
    min-width: 0;
}

.ph-cat-top {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}

.ph-cat-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--dark);
    margin: 0;
    line-height: 1.2;
}

.ph-cat-badge {
    font-size: .68rem;
    font-weight: 700;
    padding: 4px 11px;
    border-radius: 50px;
    border: 1px solid;
    letter-spacing: .4px;
    text-transform: uppercase;
    white-space: nowrap;
}

.ph-cat-desc {
    font-size: .83rem;
    color: #000000e3;
    margin: 0;
    line-height: 1.6;
}

.ph-cat-cta {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 8px;
    background: var(--dark);
    color: var(--white);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .3px;
    white-space: nowrap;
    flex-shrink: 0;
    align-self: flex-start;
    transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
}

.ph-cat-cta:hover {
    background: var(--red);
    color: var(--white);
    transform: translateY(-2px);
}

@media (max-width: 575px) {
    .ph-cat-cta span {
        display: none;
    }
    .ph-cat-cta {
        padding: 9px 12px;
    }
}


/* Divider between stacked blocks in "All" tab */

.ph-cat-divider {
    margin-top: 28px;
    /* padding-top: 0;
    border-top: 2px dashed var(--border) !important; */
}


/* ── Product Items ── */

.ph-prod-item {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 13px 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
    position: relative;
    overflow: hidden;
    cursor: default;
    height: 100%;
}

.ph-prod-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom, var(--red), var(--red-mid));
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform .25s ease;
}

.ph-prod-item:hover {
    border-color: rgba(237, 28, 36, .25);
    box-shadow: 0 4px 16px rgba(237, 28, 36, .07);
    transform: translateY(-2px);
}

.ph-prod-item:hover::before {
    transform: scaleY(1);
}

.ph-prod-ico {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    flex-shrink: 0;
    transition: transform .22s ease;
}

.ph-prod-item:hover .ph-prod-ico {
    transform: scale(1.08);
}

.ph-prod-name {
    flex: 1;
    font-size: .83rem;
    font-weight: 600;
    color: var(--dark);
    line-height: 1.35;
}

.ph-prod-inquire {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(237, 28, 36, .08);
    color: var(--red);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    flex-shrink: 0;
    opacity: 0;
    transform: translateX(6px);
    transition: opacity .2s ease, transform .2s ease, background .2s ease;
}

.ph-prod-item:hover .ph-prod-inquire {
    opacity: 1;
    transform: translateX(0);
    background: var(--red);
    color: var(--white);
}


/* ── Responsive ── */

@media (max-width: 767px) {
    .ph-cat-block {
        padding: 22px 16px;
    }
    .ph-cat-title {
        font-size: 1.05rem;
    }
    .pf-btn {
        padding: 6px 13px;
        font-size: .73rem;
    }
}


/* ── Product Inquiry — Selected state & Banner ── */


/* Highlight the product row that was clicked */

.ph-prod-item.ph-prod-selected {
    border-color: var(--red) !important;
    background: rgba(237, 28, 36, .035);
    box-shadow: 0 0 0 3px rgba(237, 28, 36, .12) !important;
    transform: translateY(-2px);
}

.ph-prod-item.ph-prod-selected::before {
    transform: scaleY(1) !important;
}

.ph-prod-item.ph-prod-selected .ph-prod-inquire {
    opacity: 1 !important;
    transform: translateX(0) !important;
    background: var(--red) !important;
    color: var(--white) !important;
}


/* Selected product banner inside the form */

.ph-inquiry-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    background: linear-gradient(to right, rgba(237, 28, 36, .07), rgba(237, 28, 36, .03));
    border: 1.5px solid rgba(237, 28, 36, .25);
    border-radius: var(--radius);
    padding: 13px 16px;
    animation: bannerSlideIn .28s ease;
}

@keyframes bannerSlideIn {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ph-inquiry-banner-ico {
    width: 38px;
    height: 38px;
    background: rgba(237, 28, 36, .1);
    color: var(--red);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}

.ph-inquiry-banner-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ph-inquiry-banner-lbl {
    font-size: .68rem;
    font-weight: 600;
    color: var(--red);
    text-transform: uppercase;
    letter-spacing: .6px;
}

.ph-inquiry-banner-name {
    font-size: .9rem;
    font-weight: 700;
    color: var(--dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ph-inquiry-banner-clear {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1.5px solid rgba(237, 28, 36, .25);
    background: transparent;
    color: var(--red);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .78rem;
    cursor: pointer;
    flex-shrink: 0;
    transition: background var(--dur), color var(--dur);
}

.ph-inquiry-banner-clear:hover {
    background: var(--red);
    color: var(--white);
    border-color: var(--red);
}

.ph-prod-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.ph-prod-info .ph-prod-name {
    flex: unset;
    font-size: .83rem;
    font-weight: 700;
    color: var(--dark);
    line-height: 1.3;
}

.ph-prod-contents {
    font-size: .72rem;
    font-weight: 500;
    color: #202020;
    line-height: 1.4;
    white-space: normal;
    margin-top: 1px;
}


/* ── Nutraceuticals sub-category grouping ──────────────────────────── */

.nutra-subcat {
    margin-top: 24px;
}

.nutra-subcat-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    border-radius: var(--radius);
    margin-bottom: 4px;
    font-size: .82rem;
    font-weight: 700;
    color: var(--dark);
    letter-spacing: .2px;
}

.nutra-subcat-header i {
    font-size: .95rem;
    flex-shrink: 0;
}

.nutra-subcat-header span {
    font-family: 'Poppins', sans-serif;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
}


/* ── Nutra catalogue section padding fix ───────────────────────────── */

.ph-catalogue-section .ctc-form-wrap {
    margin-top: 0;
}

.cta_btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, .08);
    color: #ed1c24;
    font-size: .875rem;
    font-weight: 600;
    padding: 12px 28px;
    border-radius: var(--radius);
    border: 2px solid rgb(237 28 36);
    backdrop-filter: blur(8px);
    transition: all var(--dur) var(--ease);
    white-space: nowrap;
}

@media (max-width: 640px) {
    .page-hero {
        min-height: 220px;
        padding: 40px 0 40px;
    }
    .page-hero h1 {
        font-size: 25px;
    }
    .page-hero p {
        font-size: 0.8rem;
    }
    .ph-cat-desc {
        font-size: .8rem !important;
        line-height: 1.4 !important;
    }
    .ph-cat-title {
        font-size: 0.9rem !important;
    }
    .pf-bar {
        position: unset !important;
    }
    .markets-panel-header {
        flex-direction: column !important;
    }
    .stats-bar .stat-label {
        font-size: .6rem !important;
    }
    .stat-num {
        font-size: 2.0rem !important;
    }
    .stat-box {
        padding: 25px 20px !important;
    }
    .feature-card p {
        font-size: .7rem !important;
        line-height: 1.4 !important;
    }
    .feature-card h5 {
        font-size: .8rem !important;
        margin-bottom: 5px !important;
    }
    .feature-card {
        padding: 18px 18px !important;
    }
    .global-map-section {
        padding: 35px 35px !important;
    }
    .intl-kpi {
        flex-direction: column !important;
        text-align: center !important;
    }
    .intl-kpi-label {
        font-size: .7rem !important;
    }
    .markets-panel-badge {
        margin-left: unset !important;
    }
}