/**
 * B2B Factory Starter — layout & components
 */

:root {
    --color-bg: #f4f3ef;
    --color-bg-alt: #ebe8e1;
    --color-surface: #ffffff;
    --color-ink: #1c1c1c;
    --color-muted: #5c5c5c;
    --color-line: #e0ddd4;
    --color-accent: #b8954a;
    --color-accent-mid: #9a7b3c;
    --color-accent-hover: #8a6e36;
    --color-header: #0d0d0d;
    --color-header-elevated: #161616;
    --font-sans: "DM Sans", system-ui, -apple-system, sans-serif;
    --font-display: "Cormorant Garamond", "Times New Roman", Times, serif;
    --container: 1440px;
    --radius: 2px;
    --radius-pill: 999px;
    --shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
    --shadow-soft: 0 8px 30px rgba(0, 0, 0, 0.06);
    --tracking-wide: 0.12em;
    --tracking-nav: 0.08em;
}

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

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 1rem;
    font-optical-sizing: auto;
    color: var(--color-ink);
    background: var(--color-bg);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
}

.section__title,
.cta-band__title,
.hero__title,
.tile-hero__title,
.site-footer__heading,
.page-title,
.post-card__title {
    font-family: var(--font-display);
    font-weight: 600;
    letter-spacing: 0.01em;
}

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

a {
    color: var(--color-accent-mid);
    text-decoration-thickness: 1px;
    text-underline-offset: 0.15em;
}

a:hover {
    color: var(--color-ink);
}

.container {
    width: min(100% - clamp(0.75rem, 2.5vw, 1.25rem), var(--container));
    margin-inline: auto;
}

.container--narrow {
    width: min(100% - clamp(0.75rem, 2.5vw, 1.25rem), 720px);
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.skip-link:focus {
    position: fixed;
    top: 1rem;
    left: 1rem;
    z-index: 1000;
    padding: 0.75rem 1rem;
    background: var(--color-surface);
    color: var(--color-ink);
    clip: auto;
    width: auto;
    height: auto;
    box-shadow: var(--shadow);
}

.top-bar {
    background: #faf9f6;
    color: var(--color-muted);
    font-size: 0.72rem;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    border-bottom: 1px solid var(--color-line);
}

.top-bar__inner {
    padding: 0.5rem 0;
}

.top-bar__text {
    margin: 0;
    text-align: center;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: #fff;
    color: var(--color-ink);
    border-bottom: 1px solid var(--color-line);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 88px;
    position: relative;
}

.site-title {
    color: var(--color-ink);
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1.65rem;
    letter-spacing: 0.12em;
    text-decoration: none;
    text-transform: uppercase;
}

.site-title:hover {
    color: var(--color-accent-mid);
}

.custom-logo-link {
    display: inline-flex;
    align-items: center;
}

.custom-logo-link img {
    max-height: 52px;
    width: auto;
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 0.5rem;
}

.nav-toggle__bar {
    width: 24px;
    height: 2px;
    background: var(--color-ink);
    border-radius: 1px;
}

.primary-nav {
    display: flex;
    align-items: center;
    gap: 0.5rem clamp(1.2rem, 2vw, 2.25rem);
    flex: 1;
    justify-content: flex-end;
}

.primary-nav__menus {
    display: flex;
    flex: 1;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.35rem 1.25rem;
    min-width: 0;
}

.mega-nav.mega-nav--primary-addon {
    flex: 0 0 auto;
}

.mega-nav.mega-nav--primary-addon .mega-nav__root {
    justify-content: flex-start;
    gap: 0.15rem clamp(1.75rem, 3vw, 3.25rem);
}

.menu.menu--primary.menu--after-products-mega {
    flex: 1 1 auto;
    min-width: 0;
    justify-content: flex-end;
}

.primary-nav__hint {
    margin: 0 0.75rem 0 0;
    padding: 0.4rem 0.65rem;
    max-width: min(28rem, 100%);
    font-size: 0.75rem;
    line-height: 1.35;
    color: #92400e;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: 4px;
}

.header-toolbar {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding-left: clamp(1rem, 2vw, 1.6rem);
    margin-left: clamp(0.75rem, 1.4vw, 1.25rem);
    border-left: 1px solid var(--color-line);
}

.header-product-search {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.header-product-search__input {
    width: clamp(7.5rem, 12vw, 12.5rem);
    height: 2.35rem;
    padding: 0 0.7rem;
    font: inherit;
    font-size: 0.82rem;
    color: var(--color-ink);
    border: 1px solid rgba(184, 149, 74, 0.55);
    border-radius: 4px;
    background: #fff;
    outline: none;
}

.header-product-search__input::placeholder {
    color: #8a8170;
}

.header-product-search__input:focus {
    border-color: var(--color-accent-mid);
    box-shadow: 0 0 0 3px rgba(184, 149, 74, 0.16);
}

.header-search,
.header-mail,
.header-wa {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    color: var(--color-accent-mid);
    text-decoration: none;
    cursor: pointer;
    border-radius: 4px;
    border: 1px solid rgba(184, 149, 74, 0.55);
    background: #fff;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.header-search:hover,
.header-mail:hover,
.header-wa:hover {
    color: var(--color-ink);
    border-color: var(--color-accent-mid);
    background: rgba(184, 149, 74, 0.08);
}

.header-search__icon {
    display: block;
    width: 1rem;
    height: 1rem;
    border: 2px solid currentColor;
    border-radius: 50%;
    position: relative;
}

.header-search__icon::after {
    content: "";
    position: absolute;
    width: 0.4rem;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    right: -4px;
    bottom: -2px;
    transform: rotate(45deg);
}

.header-mail__icon {
    display: block;
    width: 1.1rem;
    height: 0.75rem;
    border: 2px solid currentColor;
    border-radius: 2px;
    position: relative;
}

.header-mail__icon::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 5px solid currentColor;
    opacity: 0.9;
}

.header-wa__icon {
    display: block;
    width: 1.05rem;
    height: 1.05rem;
    border: 2px solid currentColor;
    border-radius: 50%;
    position: relative;
}

.header-wa__icon::before {
    content: "";
    position: absolute;
    inset: 3px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-right-color: currentColor;
    border-radius: 50%;
    transform: rotate(-35deg);
}

.menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem 1.25rem;
    align-items: center;
}

.menu a {
    color: var(--color-ink);
    text-decoration: none;
    font-weight: 500;
    font-size: 0.95rem;
}

.menu a:hover {
    color: var(--color-accent-mid);
}

.lang-switcher ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0.35rem;
}

.lang-switcher a {
    color: var(--color-muted);
    text-decoration: none;
    font-size: 0.72rem;
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    font-weight: 600;
}

.lang-switcher .current-lang a {
    color: var(--color-accent-mid);
}

.lang-switcher--boxed {
    padding: 0.35rem 0.65rem;
    border: 1px solid rgba(184, 149, 74, 0.55);
    border-radius: 4px;
    background: #fff;
}

@media (max-width: 900px) {
    .nav-toggle {
        display: flex;
    }

    .primary-nav {
        position: absolute;
        right: 1rem;
        top: 100%;
        background: #fff;
        flex-direction: column;
        align-items: stretch;
        padding: 1rem 1.25rem;
        border-radius: 4px;
        box-shadow: var(--shadow);
        min-width: min(100vw - 2rem, 340px);
        display: none;
        border: 1px solid var(--color-line);
    }

    .primary-nav.is-open {
        display: flex;
    }

    .primary-nav .menu--primary {
        flex-direction: column;
        align-items: flex-start;
    }

    .primary-nav__hint {
        margin: 0 0 0.75rem;
        max-width: none;
    }

    .primary-nav__menus {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: 0.75rem;
    }

    .mega-nav.mega-nav--primary-addon .mega-nav__root {
        justify-content: flex-start;
    }

    .menu.menu--primary.menu--after-products-mega {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
    }

    .header-toolbar {
        border-left: 0;
        margin-left: 0;
        padding-left: 0;
        padding-top: 0.85rem;
        margin-top: 0.5rem;
        border-top: 1px solid var(--color-line);
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 0.65rem;
    }

    .header-product-search {
        width: 100%;
    }

    .header-product-search__input {
        flex: 1 1 auto;
        width: auto;
        min-width: 0;
    }
}

.hero {
    position: relative;
    background: radial-gradient(120% 80% at 70% 20%, #2a2418 0%, #0d0d0d 45%, #0a0a0a 100%);
    color: #fafafa;
    padding: clamp(3rem, 8vw, 5.5rem) clamp(0.75rem, 3vw, 2rem) clamp(3rem, 6vw, 4.5rem);
    min-height: min(78vh, 52rem);
    display: flex;
    align-items: center;
}

.hero__inner {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: clamp(1.5rem, 4vw, 3.5rem);
    align-items: center;
    width: 100%;
}

.hero__content {
    padding-inline-start: clamp(0.35rem, 2.5vw, 1.75rem);
    padding-inline-end: clamp(0, 1.5vw, 0.75rem);
}

@media (max-width: 900px) {
    .hero__inner {
        grid-template-columns: 1fr;
    }

    .hero {
        min-height: 0;
    }
}

.hero__kicker {
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    font-size: 0.72rem;
    color: var(--color-accent);
    margin: 0 0 0.85rem;
    font-family: var(--font-sans);
    font-weight: 600;
}

.hero__title {
    font-size: clamp(2.25rem, 4.8vw, 3.75rem);
    line-height: 1.08;
    margin: 0 0 1.1rem;
    font-weight: 600;
    color: #fff;
}

.hero__lead {
    color: rgba(255, 255, 255, 0.78);
    margin: 0 0 1.25rem;
    max-width: 42rem;
    font-size: 1.05rem;
    line-height: 1.7;
    font-family: var(--font-sans);
    font-weight: 400;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.hero__media {
    position: relative;
    min-height: clamp(220px, 36vw, 380px);
}

.hero__photo {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    border-radius: var(--radius);
    object-fit: cover;
    border: 1px solid rgba(184, 149, 74, 0.25);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.hero__photo--empty {
    object-fit: unset;
    background: linear-gradient(145deg, #e2e8f0 0%, #f1f5f9 48%, #cbd5e1 100%);
}

.hero--home-bg {
    overflow: hidden;
    justify-content: center;
    min-height: clamp(34rem, 82vh, 54rem);
    padding: clamp(4.5rem, 9vw, 7rem) clamp(1rem, 3vw, 2rem);
    background: #0d0d0d;
}

.hero--home-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(circle at 50% 48%, rgba(0, 0, 0, 0.54) 0%, rgba(0, 0, 0, 0.42) 38%, rgba(0, 0, 0, 0.68) 100%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.64) 0%, rgba(0, 0, 0, 0.18) 48%, rgba(0, 0, 0, 0.6) 100%);
    pointer-events: none;
}

.hero--home-bg .hero__inner {
    position: static;
    z-index: 2;
    display: flex;
    justify-content: center;
    width: min(100%, 62rem);
}

.hero--home-bg .hero__content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 48rem;
    padding-inline: 0;
    text-align: center;
}

.hero--home-bg .hero__pills,
.hero--home-bg .hero__actions {
    justify-content: center;
}

.hero--home-bg .hero__lead,
.hero--home-bg .hero__note {
    margin-inline: auto;
}

.hero--home-bg .hero__kicker,
.hero--home-bg .hero__title,
.hero--home-bg .hero__lead,
.hero--home-bg .hero__note {
    text-shadow: 0 0.125rem 1.5rem rgba(0, 0, 0, 0.55);
}

.hero--home-bg .hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
    min-height: 0;
}

.hero--home-bg .hero__photo {
    width: 100%;
    height: 100%;
    min-height: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    object-fit: cover;
}

.hero--home-bg .hero__photo--empty {
    background:
        radial-gradient(circle at 50% 36%, rgba(184, 149, 74, 0.22), transparent 32rem),
        linear-gradient(135deg, #24201a 0%, #0d0d0d 56%, #050505 100%);
}

@media (max-width: 900px) {
    .hero--home-bg {
        min-height: clamp(32rem, 78vh, 42rem);
        padding-block: clamp(3.5rem, 14vw, 5rem);
    }
}

.hero--page-bg {
    overflow: hidden;
    justify-content: center;
    min-height: clamp(30rem, 64vh, 44rem);
    padding: clamp(4rem, 8vw, 6.5rem) clamp(1rem, 3vw, 2rem);
    background: #0d0d0d;
}

.hero--page-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(circle at 50% 48%, rgba(0, 0, 0, 0.52) 0%, rgba(0, 0, 0, 0.44) 38%, rgba(0, 0, 0, 0.7) 100%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.66) 0%, rgba(0, 0, 0, 0.2) 48%, rgba(0, 0, 0, 0.62) 100%);
    pointer-events: none;
}

.hero--page-bg .hero__inner {
    position: static;
    z-index: 2;
    display: flex;
    justify-content: center;
    width: min(100%, 64rem);
}

.hero--page-bg .hero__content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 54rem;
    padding-inline: 0;
    text-align: center;
}

.hero--page-bg .about-breadcrumb {
    color: rgba(255, 255, 255, 0.72);
    margin-inline: auto;
}

.hero--page-bg .about-breadcrumb a:hover {
    color: var(--color-accent);
}

.hero--page-bg .hero__actions {
    justify-content: center;
}

.hero--page-bg .hero__lead {
    margin-inline: auto;
}

.hero--page-bg .hero__kicker,
.hero--page-bg .hero__title,
.hero--page-bg .hero__lead,
.hero--page-bg .about-breadcrumb {
    text-shadow: 0 0.125rem 1.5rem rgba(0, 0, 0, 0.58);
}

.hero--page-bg .hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
    min-height: 0;
}

.hero--page-bg .hero__photo {
    width: 100%;
    height: 100%;
    min-height: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    object-fit: cover;
}

.hero--page-bg .hero__photo--empty {
    background:
        radial-gradient(circle at 50% 36%, rgba(184, 149, 74, 0.2), transparent 30rem),
        linear-gradient(135deg, #24201a 0%, #0d0d0d 56%, #050505 100%);
}

@media (max-width: 900px) {
    .hero--page-bg {
        min-height: clamp(28rem, 72vh, 38rem);
        padding-block: clamp(3rem, 13vw, 4.75rem);
    }
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.85rem 1.75rem;
    border-radius: var(--radius-pill);
    font-weight: 600;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    font-size: 0.8rem;
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    font-family: var(--font-sans);
    transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s;
}

.btn--primary {
    background: var(--color-accent);
    color: #1a1208;
    border-color: var(--color-accent);
    box-shadow: 0 4px 20px rgba(184, 149, 74, 0.35);
}

.btn--primary:hover {
    background: #c4a660;
    border-color: #c4a660;
    color: #1a1208;
}

.btn--ghost {
    background: transparent;
    color: #fafafa;
    border-color: rgba(250, 250, 250, 0.45);
}

.btn--ghost:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.trust-row {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-line);
}

.trust-row__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem 1rem;
    padding: 1.5rem 0;
    text-align: center;
}

@media (max-width: 768px) {
    .trust-row__inner {
        grid-template-columns: repeat(2, 1fr);
    }
}

.trust-item__value {
    display: block;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-ink);
    font-family: var(--font-display);
}

.trust-item__label {
    font-size: 0.72rem;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
}

.section {
    padding: clamp(3rem, 6vw, 4.25rem) 0;
}

.section--muted {
    background: var(--color-bg-alt);
}

.section--blog {
    padding-bottom: 4rem;
}

.section__header {
    margin-bottom: 2rem;
    max-width: 60ch;
}

.section__title {
    font-size: clamp(1.75rem, 2.8vw, 2.35rem);
    margin: 0 0 0.65rem;
    line-height: 1.15;
    color: var(--color-ink);
}

.section__desc {
    margin: 0;
    color: var(--color-muted);
}

.card-grid {
    display: grid;
    gap: 1.25rem;
}

.card-grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

.card-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 900px) {
    .card-grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }

    .card-grid--3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .card-grid--4 {
        grid-template-columns: 1fr;
    }
}

.tile-card,
.post-card,
.info-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    border: 1px solid var(--color-line);
    padding: 1.25rem;
    box-shadow: var(--shadow-soft);
}

.tile-card__thumb,
.post-card__thumb {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: 8px;
    background: linear-gradient(120deg, #e2e8f0, #f1f5f9);
    margin-bottom: 1rem;
    overflow: hidden;
}

.post-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-card__thumb--empty img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.tile-card__title,
.post-card__title,
.info-card__title {
    font-size: 1.1rem;
    margin: 0 0 0.35rem;
}

.tile-card__excerpt,
.post-card__excerpt,
.info-card__excerpt {
    margin: 0 0 0.75rem;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.tile-card__link {
    font-weight: 600;
    text-decoration: none;
    color: var(--color-accent-hover);
}

.split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: center;
}

@media (max-width: 900px) {
    .split {
        grid-template-columns: 1fr;
    }
}

.checklist {
    padding-left: 1.1rem;
    color: var(--color-muted);
}

.info-card__step {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--color-header);
    color: #fff;
    font-weight: 700;
    font-size: 0.85rem;
    margin-bottom: 0.75rem;
}

.faq__item {
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    padding: 0.5rem 1rem;
    margin-bottom: 0.75rem;
    background: var(--color-surface);
}

.faq__q {
    font-weight: 600;
    cursor: pointer;
}

.faq__a {
    color: var(--color-muted);
    padding-bottom: 0.5rem;
}

.lead-placeholder {
    padding: 2rem;
    text-align: center;
    background: var(--color-surface);
    border: 1px dashed var(--color-line);
    border-radius: var(--radius);
    color: var(--color-muted);
}

.lead-form .wpcf7 {
    background: var(--color-surface);
    padding: 1.5rem;
    border-radius: var(--radius);
    border: 1px solid var(--color-line);
}

.site-footer {
    background: #080808;
    color: #b8b8b8;
    padding-top: 3.5rem;
}

.site-footer a {
    color: rgba(255, 255, 255, 0.82);
}

.site-footer a:hover {
    color: var(--color-accent);
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 2rem;
    padding-bottom: 2rem;
}

@media (max-width: 768px) {
    .site-footer__grid {
        grid-template-columns: 1fr;
    }
}

.site-footer__heading {
    color: #fff;
    margin-top: 0;
}

.site-footer__subheading {
    color: #fff;
    font-size: 1rem;
    margin-top: 0;
}

.site-footer__contact {
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-footer__contact li {
    margin-bottom: 0.5rem;
}

.site-footer__social {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 1.35rem;
}

.site-footer__social-link {
    --social-color: var(--color-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.86);
    text-decoration: none;
    transition: transform 0.16s ease, color 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}

.site-footer__social-link svg {
    display: block;
    width: 1.15rem;
    height: 1.15rem;
    fill: currentColor;
}

.site-footer__social-link:hover {
    transform: translateY(-2px);
    border-color: var(--social-color);
    background: var(--social-color);
    color: #fff;
}

.site-footer__social-link--facebook {
    --social-color: #1877f2;
}

.site-footer__social-link--instagram {
    --social-color: #c13584;
}

.site-footer__social-link--youtube {
    --social-color: #ff0033;
}

.site-footer__social-link--linkedin {
    --social-color: #0a66c2;
}

.site-footer__social-link--tiktok {
    --social-color: #ff0050;
}

.site-footer__social-link--x {
    --social-color: #ffffff;
}

.site-footer__social-link--x:hover {
    color: #080808;
}

.menu--footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
}

.site-footer__bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 1rem 0;
    font-size: 0.875rem;
}

.site-footer__bottom-inner p {
    margin: 0;
}

.page-content .page-title {
    margin-top: 0;
}

.entry-content {
    max-width: 70ch;
}

.post-slim {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-line);
}

.post-slim__title {
    margin: 0 0 0.5rem;
}

.post-slim__title a {
    text-decoration: none;
    color: var(--color-ink);
}

.post-meta {
    color: var(--color-muted);
    font-size: 0.9rem;
}

/* —— Mega navigation (light bar + full-width visual panels) —— */
.mega-nav {
    flex: 1;
    display: flex;
    justify-content: center;
}

.mega-nav__root {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.15rem clamp(1rem, 2.5vw, 2.25rem);
}

.mega-nav__item {
    position: relative;
}

.mega-nav__trigger {
    background: none;
    border: 0;
    color: #3a3a3a;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    padding: 0.5rem 0;
    text-transform: uppercase;
    letter-spacing: var(--tracking-nav);
    font-size: 1rem;
    transition: color 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.mega-nav__trigger::after {
    content: "";
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
    opacity: 0.55;
    margin-top: 2px;
}

.mega-nav__item--open > .mega-nav__trigger,
.mega-nav__trigger:hover {
    color: var(--color-accent-mid);
}

.mega-nav__flat-link {
    display: inline-flex;
    align-items: center;
    color: #3a3a3a;
    text-decoration: none;
    font-weight: 600;
    padding: 0.5rem 0;
    text-transform: uppercase;
    letter-spacing: var(--tracking-nav);
    font-size: 1rem;
    line-height: 1.2;
    transition: color 0.15s;
}

.mega-nav__flat-link:hover {
    color: var(--color-accent-mid);
}

.mega-nav__panel {
    display: none;
}

.mega-nav__item--open > .mega-nav__panel {
    display: block;
}

@media (min-width: 901px) {
    .mega-nav__panel--visual {
        position: fixed;
        left: 0;
        right: 0;
        top: var(--b2b-header-bottom, 120px);
        width: 100%;
        max-height: calc(100vh - var(--b2b-header-bottom, 120px));
        overflow-y: auto;
        background: #f0efeb;
        border-top: 1px solid var(--color-line);
        box-shadow: 0 18px 40px rgba(0, 0, 0, 0.1);
        z-index: 99;
        padding: 0;
    }
}

.mega-nav__visual-outer {
    padding: 2.25rem 0 2.75rem;
}

.mega-nav__visual-grid {
    display: grid;
    gap: 1.25rem 1rem;
}

.mega-nav__visual-grid--cols-6 {
    grid-template-columns: repeat(6, 1fr);
}

.mega-nav__visual-grid--cols-4 {
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1100px) {
    .mega-nav__visual-grid--cols-6 {
        grid-template-columns: repeat(3, 1fr);
    }

    .mega-nav__visual-grid--cols-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

.mega-nav__visual-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    text-decoration: none;
    color: var(--color-ink);
    transition: transform 0.2s, opacity 0.2s;
}

.mega-nav__visual-card:hover {
    transform: translateY(-3px);
}

.mega-nav__visual-card:hover .mega-nav__visual-label {
    color: var(--color-accent-mid);
}

.mega-nav__visual-thumb {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 2px;
    margin-bottom: 0.85rem;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
    object-fit: cover;
    background: #e8e4dc;
}

span.mega-nav__visual-thumb--empty {
    object-fit: unset;
    background: linear-gradient(145deg, #e2e8f0 0%, #f1efe8 100%);
}

.mega-nav__visual-label {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 500;
    line-height: 1.35;
    color: #3a3a3a;
    max-width: 12rem;
}

.mega-nav__visual-foot {
    margin: 1.75rem 0 0;
    text-align: center;
    font-size: 0.85rem;
}

.mega-nav__visual-foot a {
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tracking-nav);
    font-size: 0.72rem;
}

/* Products mega: 4 text columns + collection column */
.mega-nav__products-outer {
    padding: 2.25rem 0 2.75rem;
}

.mega-nav__products-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.5rem clamp(1rem, 2vw, 2rem);
    align-items: start;
}

.mega-nav__products-head {
    margin: 0 0 0.9rem;
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 700;
    color: #2d2d2d;
    letter-spacing: 0.03em;
    line-height: 1.3;
}

.mega-nav__products-head-link {
    color: inherit;
    text-decoration: none;
}

.mega-nav__products-head-link:hover {
    color: var(--color-accent-mid);
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

.mega-nav__panel--products .mega-nav__links {
    margin: 0;
    padding: 0;
}

.mega-nav__panel--products .mega-nav__links li {
    margin: 0 0 0.32rem;
}

.mega-nav__panel--products .mega-nav__links a {
    display: inline;
    padding: 0;
    font-size: 0.8125rem;
    font-weight: 400;
    color: #6f6f6f;
    text-decoration: none;
    line-height: 1.55;
}

.mega-nav__panel--products .mega-nav__links a:hover {
    color: var(--color-accent-mid);
    text-decoration: underline;
}

.mega-nav__collection-shot {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    border-radius: 2px;
    margin-bottom: 0.85rem;
    object-fit: cover;
    background: #f2efe8;
    box-shadow:
        inset 0 0 0 1px rgba(0, 0, 0, 0.05),
        0 8px 24px rgba(0, 0, 0, 0.08);
}

.mega-nav__collection-shot--empty {
    object-fit: unset;
    background: linear-gradient(145deg, #e8e4dc 0%, #f1efe8 100%);
}

.mega-nav__collection-cta {
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 600;
    color: #3d3d3d;
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

.mega-nav__collection-cta:hover {
    color: var(--color-accent-mid);
}

@media (max-width: 1100px) {
    .mega-nav__products-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .mega-nav__products-col--collection {
        grid-column: 1 / -1;
        max-width: 28rem;
    }
}

@media (max-width: 900px) {
    .mega-nav {
        flex: none;
        width: 100%;
        justify-content: flex-start;
    }

    .mega-nav__root {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
    }

    .mega-nav__trigger,
    .mega-nav__flat-link {
        text-align: left;
        width: 100%;
        justify-content: space-between;
    }

    .mega-nav__panel--visual {
        position: static;
        width: 100%;
        max-height: none;
        overflow: visible;
        background: #f7f6f2;
        border: 1px solid var(--color-line);
        border-radius: 4px;
        margin: 0.35rem 0 0.75rem;
        box-shadow: none;
    }

    .mega-nav__visual-outer {
        padding: 1rem 0.75rem 1.25rem;
    }

    .mega-nav__products-outer {
        padding: 1rem 0.75rem 1.25rem;
    }

    .mega-nav__products-grid {
        grid-template-columns: 1fr;
    }

    .mega-nav__products-col--collection {
        grid-column: auto;
        max-width: none;
    }

    .mega-nav__visual-grid--cols-6,
    .mega-nav__visual-grid--cols-4 {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 520px) {
    .mega-nav__visual-grid--cols-6,
    .mega-nav__visual-grid--cols-4 {
        grid-template-columns: 1fr;
    }
}

/* Legacy text columns (WP primary menu mode) */
.mega-nav__panel-inner {
    padding-top: 0.5rem;
}

.mega-nav__cols {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}

.mega-nav__cols--2 {
    grid-template-columns: repeat(2, 1fr);
    max-width: 520px;
}

.mega-nav__heading {
    margin: 0 0 0.5rem;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-muted);
}

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

.mega-nav__links a {
    display: block;
    padding: 0.25rem 0;
    color: var(--color-ink);
    text-decoration: none;
    font-size: 0.9rem;
}

.mega-nav__links a:hover {
    color: var(--color-accent-hover);
}

.mega-nav__more {
    margin: 0.75rem 0 0;
    font-size: 0.85rem;
}

/* —— Homepage extensions —— */
.hero__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.pill {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    padding: 0.4rem 0.75rem;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(184, 149, 74, 0.45);
    color: rgba(255, 255, 255, 0.88);
    background: rgba(0, 0, 0, 0.2);
}

.hero__note {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.55);
    margin: -0.5rem 0 1rem;
    max-width: 50ch;
    font-family: var(--font-sans);
}

.section--intro-showcase {
    background: #fff;
    border-bottom: 1px solid var(--color-line);
    padding-block: clamp(2.25rem, 5vw, 3.75rem);
}

.intro-showcase__inner {
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 5vw, 3.25rem);
}

.intro-band {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: clamp(1.25rem, 3vw, 2.5rem);
}

.intro-band__text {
    flex: 1 1 16rem;
    max-width: min(42rem, 100%);
}

.intro-band__title {
    margin: 0 0 0.85rem;
    font-size: clamp(1.35rem, 2.6vw, 2rem);
    font-weight: 700;
    line-height: 1.2;
    color: #1e293b;
    font-family: var(--font-sans);
    letter-spacing: -0.02em;
}

.intro-band__lead {
    margin: 0;
    max-width: 52ch;
    font-size: 1rem;
    line-height: 1.65;
    color: #64748b;
    font-family: var(--font-sans);
}

.intro-band__cta {
    flex: 0 0 auto;
    margin-inline-start: auto;
}

.btn--intro-catalog {
    background: #f0bc5e;
    color: #1c1917;
    border: 1px solid #e5a84a;
    border-radius: 4px;
    text-transform: none;
    letter-spacing: 0.01em;
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.9rem 1.35rem;
    box-shadow: none;
}

.btn--intro-catalog:hover {
    background: #e8ad4a;
    border-color: #d9a042;
    color: #0f0f0f;
}

@media (max-width: 640px) {
    .intro-band__cta {
        margin-inline-start: 0;
        width: 100%;
    }

    .btn--intro-catalog {
        width: 100%;
    }
}

.intro-showcase__grid {
    list-style: none;
    margin: 0;
    padding: 0;
}

.intro-showcase__cell {
    margin: 0;
    min-width: 0;
}

.showcase-tile {
    display: block;
    text-decoration: none;
    color: #1e293b;
}

.showcase-tile__media {
    display: block;
    position: relative;
    aspect-ratio: 4 / 5;
    width: 100%;
    border-radius: 0;
    overflow: hidden;
    background: #e8e4dc;
}

.showcase-tile__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.showcase-tile__label {
    display: block;
    margin-top: 0.85rem;
    font-size: 0.95rem;
    font-weight: 600;
    font-family: var(--font-sans);
    line-height: 1.35;
}

.showcase-tile:hover .showcase-tile__label {
    color: var(--color-accent, #b8860b);
}

.btn--dark {
    background: var(--color-header);
    color: #fafafa;
    border-color: var(--color-header);
}

.btn--dark:hover {
    background: #2a2a2a;
    border-color: #2a2a2a;
    color: #fff;
}

.section--tight {
    padding-top: 2rem;
}

.tile-hero {
    position: relative;
    display: block;
    border-radius: var(--radius);
    overflow: hidden;
    min-height: 220px;
    text-decoration: none;
    color: #fff;
    box-shadow: var(--shadow);
}

.tile-hero__media {
    position: absolute;
    inset: 0;
    background: linear-gradient(165deg, #4a4338 0%, #2a2620 45%, #151311 100%);
}

.tile-hero__body {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.25rem;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.75));
}

.tile-hero__title {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 0.25rem;
}

.tile-hero__sub {
    font-size: 0.85rem;
    opacity: 0.9;
    font-family: var(--font-sans);
}

.tile-hero:hover .tile-hero__title {
    color: var(--color-accent);
}

.cert-strip {
    text-align: center;
    background: var(--color-surface);
    border-block: 1px solid var(--color-line);
}

.cert-strip__label {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.cert-strip__badges {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
}

.cert-strip__badges li {
    padding: 0.4rem 0.85rem;
    border-radius: 6px;
    background: #eef1f5;
    font-weight: 600;
    font-size: 0.8rem;
    color: var(--color-ink);
}

.section--oem-features {
    padding-block: clamp(2rem, 5vw, 3.5rem);
    background: #fff;
}

.oem-feature-grid {
    gap: clamp(0.5rem, 1.2vw, 0.85rem);
}

.oem-feature {
    position: relative;
    min-height: clamp(17rem, 38vw, 24rem);
    border-radius: 0;
    overflow: hidden;
    background-color: #2d2d2d;
}

.oem-feature__bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    z-index: 0;
}

.oem-feature__scrim {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.72) 100%);
    pointer-events: none;
}

.oem-feature__inner {
    position: relative;
    z-index: 2;
    box-sizing: border-box;
    min-height: clamp(17rem, 38vw, 24rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: clamp(1.2rem, 3vw, 2.25rem);
    text-align: left;
}

.oem-feature__title {
    margin: 0 0 0.65rem;
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    font-weight: 700;
    line-height: 1.25;
    color: #fff;
    font-family: var(--font-sans);
    letter-spacing: 0.01em;
}

.oem-feature__text {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.55;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.9);
    font-family: var(--font-sans);
    max-width: 36ch;
}

.split--reverse {
    direction: rtl;
}

.split--reverse > * {
    direction: ltr;
}

.split__media--photo {
    position: relative;
    min-height: clamp(220px, 32vw, 360px);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--color-line, #e2e8f0);
    background: #f1f5f9;
}

.split__photo {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
}

.split__photo--empty {
    object-fit: unset;
    background: linear-gradient(145deg, #e2e8f0 0%, #f8fafc 50%, #cbd5e1 100%);
}

.cta-band {
    background: linear-gradient(180deg, #14120e 0%, #0d0d0d 100%);
    color: #fafafa;
    padding: clamp(3rem, 6vw, 4.5rem) 0;
    text-align: center;
    border-block: 1px solid rgba(184, 149, 74, 0.25);
}

.cta-band__title {
    margin: 0 0 0.85rem;
    font-size: clamp(1.85rem, 3.2vw, 2.65rem);
    font-weight: 600;
    color: #fff;
}

.cta-band__text {
    margin: 0 auto 1.75rem;
    max-width: 46ch;
    color: rgba(255, 255, 255, 0.72);
    font-family: var(--font-sans);
    font-size: 1.05rem;
}

.prefooter {
    background: #111827;
    color: #94a3b8;
    padding: 1.25rem 0;
    text-align: center;
    font-size: 0.9rem;
}

.prefooter__text {
    margin: 0;
}

.form-note {
    font-size: 0.85rem;
    color: var(--color-muted);
    margin: 0 0 1rem;
}

.site-footer__grid--4 {
    grid-template-columns: 1.3fr repeat(3, 1fr);
}

@media (max-width: 900px) {
    .site-footer__grid--4 {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 520px) {
    .site-footer__grid--4 {
        grid-template-columns: 1fr;
    }
}

.site-footer__tagline {
    color: #94a3b8;
    margin-top: 0;
}

.site-footer__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer__list a {
    text-decoration: none;
    color: #cbd5e1;
    font-size: 0.9rem;
    display: inline-block;
    padding: 0.2rem 0;
}

.site-footer__list a:hover {
    color: #fff;
}

.site-footer__bottom-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.site-footer__copy {
    margin: 0;
}

.site-footer__legal {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.site-footer__legal a {
    color: #94a3b8;
    text-decoration: none;
    font-size: 0.85rem;
}

.site-footer__legal a:hover {
    color: #fff;
}

/* ----- Contact page (page-contact.php) ----- */

.contact-page {
    padding: 2rem 0 4rem;
    background: linear-gradient(180deg, #f8fafc 0%, #fff 28%);
}

.contact-page__inner {
    max-width: 960px;
}

.contact-breadcrumb {
    font-size: 0.85rem;
    color: var(--color-muted, #64748b);
    margin-bottom: 1.5rem;
}

.contact-breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.contact-breadcrumb a:hover {
    color: var(--color-accent, #b8860b);
}

.contact-breadcrumb__sep {
    margin: 0 0.4rem;
    opacity: 0.6;
}

.contact-page__header {
    margin-bottom: 2.5rem;
}

.contact-page__title {
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    line-height: 1.2;
    margin: 0 0 1rem;
    color: #0f172a;
}

.contact-page__lead {
    font-size: 1.05rem;
    line-height: 1.65;
    color: #334155;
    margin: 0 0 1rem;
    max-width: 52rem;
}

.contact-page__note {
    font-size: 0.85rem;
    color: var(--color-muted, #64748b);
    margin: 0;
}

.contact-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-bottom: 2.5rem;
}

@media (max-width: 820px) {
    .contact-cards {
        grid-template-columns: 1fr;
    }
}

.contact-card {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1.25rem 1.35rem;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.contact-card__title {
    font-size: 1rem;
    margin: 0 0 0.75rem;
    color: #0f172a;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}

.contact-card__schedule {
    font-size: 0.8rem;
    color: var(--color-muted, #64748b);
    margin: 0 0 0.35rem;
}

.contact-card__value {
    font-size: 1rem;
    margin: 0.75rem 0 1rem;
    color: #0f172a;
    word-break: break-word;
}

.contact-card__value a {
    color: var(--color-accent, #b8860b);
    text-decoration: none;
    font-weight: 600;
}

.contact-card__value a:hover {
    text-decoration: underline;
}

.contact-card__muted {
    font-size: 0.85rem;
    color: var(--color-muted, #64748b);
    margin: 0.75rem 0 0;
    line-height: 1.5;
}

.contact-card__btn {
    display: inline-block;
    width: 100%;
    text-align: center;
    margin-top: 0.25rem;
}

.contact-card__btn.btn--ghost {
    color: #0f172a;
    border-color: var(--color-accent-mid);
    background: #f3bd49;
    box-shadow: 0 10px 20px rgba(184, 149, 74, 0.18);
}

.contact-card__btn.btn--ghost:hover {
    color: #fff;
    border-color: var(--color-ink);
    background: var(--color-ink);
}

.contact-factory {
    border-top: 1px solid #e2e8f0;
    padding-top: 2rem;
    margin-bottom: 2.5rem;
}

.contact-factory__title {
    font-size: 1.15rem;
    margin: 0 0 0.5rem;
    color: #0f172a;
}

.contact-factory__addr {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    color: #334155;
}

.contact-form-wrap {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1.5rem 1.35rem 1.75rem;
    background: #fff;
    margin-bottom: 2rem;
}

.contact-form-wrap__title {
    font-size: 1.15rem;
    margin: 0 0 1rem;
    color: #0f172a;
}

.contact-form-wrap__form :where(input[type="text"], input[type="email"], input[type="tel"], textarea, select) {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.contact-form-wrap__empty {
    margin: 0;
    color: var(--color-muted, #64748b);
    font-size: 0.95rem;
}

.contact-page__editor {
    font-size: 0.95rem;
    color: #475569;
}

.contact-page__editor > *:first-child {
    margin-top: 0;
}

/* ----- Exhibitions page (page-exhibitions.php) ----- */

.exhibitions-page__breadcrumb {
    color: rgba(255, 255, 255, 0.62);
}

.exhibitions-page__breadcrumb a:hover {
    color: var(--color-accent);
}

.exhibitions-page__editor-wrap {
    padding-top: clamp(2rem, 4vw, 3rem);
    padding-bottom: clamp(2rem, 4vw, 3rem);
}

.exhibitions-page__editor {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-ink);
}

.exhibitions-page__editor > *:first-child {
    margin-top: 0;
}

.exhibitions-page__editor > *:last-child {
    margin-bottom: 0;
}

.expo-spotlight {
    margin-top: 1.75rem;
    padding: clamp(1.5rem, 3vw, 2.25rem);
    background: var(--color-surface);
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
    max-width: 52rem;
}

.expo-spotlight__title {
    font-family: var(--font-display);
    font-size: clamp(1.15rem, 2.2vw, 1.45rem);
    font-weight: 600;
    margin: 0 0 1rem;
    line-height: 1.25;
    color: var(--color-ink);
}

.expo-spotlight__text {
    margin: 0 0 0.85rem;
    color: var(--color-muted);
    line-height: 1.65;
}

.expo-spotlight__text:last-of-type {
    margin-bottom: 1.25rem;
}

.expo-spotlight__cta {
    margin: 0;
}

.expo-footprint {
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 4vw, 2.75rem);
    margin-top: 0.5rem;
}

.expo-footprint__region-title {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.4vw, 1.6rem);
    font-weight: 600;
    margin: 0 0 1.25rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-accent);
    color: var(--color-ink);
}

.expo-footprint__fairs {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .expo-footprint__fairs {
        grid-template-columns: repeat(2, 1fr);
    }
}

.expo-fair {
    background: var(--color-surface);
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    padding: 1.25rem 1.35rem;
    box-shadow: var(--shadow-soft);
}

.expo-fair__name {
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 0.65rem;
    color: var(--color-ink);
    line-height: 1.35;
}

.expo-fair__body {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--color-muted);
}

.exhibitions-page__cta .cta-band__text {
    margin-bottom: 1rem;
}

.exhibitions-page__cta .cta-band__text:last-of-type {
    margin-bottom: 1.75rem;
}

.exhibitions-page__cta-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
}

.exhibitions-page__cta .btn--ghost {
    border-color: rgba(250, 250, 250, 0.45);
    color: #fafafa;
}

.exhibitions-page__cta .btn--ghost:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

/* ----- About us page (page-about-us.php) ----- */

.about-page {
    padding-bottom: 4rem;
}

.about-hero {
    padding: 2rem 0 3rem;
    background: linear-gradient(165deg, #f8fafc 0%, #fff 55%, #f1f5f9 100%);
    border-bottom: 1px solid #e2e8f0;
}

.about-breadcrumb {
    font-size: 0.85rem;
    color: var(--color-muted, #64748b);
    margin-bottom: 1.25rem;
}

.about-breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.about-breadcrumb a:hover {
    color: var(--color-accent, #b8860b);
}

.about-breadcrumb__sep {
    margin: 0 0.4rem;
    opacity: 0.6;
}

.about-hero__kicker {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-accent, #b8860b);
    font-weight: 600;
    margin: 0 0 0.75rem;
}

.about-hero__title {
    font-size: clamp(1.85rem, 4.5vw, 2.6rem);
    line-height: 1.15;
    margin: 0 0 1rem;
    color: #0f172a;
}

.about-hero__lead {
    font-size: 1.1rem;
    line-height: 1.65;
    color: #334155;
    margin: 0 0 1.75rem;
    max-width: 40rem;
}

.about-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.about-page__body {
    padding-top: 2.5rem;
}

.about-section {
    margin-bottom: 3rem;
}

.about-section--muted {
    margin-left: -1rem;
    margin-right: -1rem;
    padding: 2rem 1rem;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
}

@media (min-width: 768px) {
    .about-section--muted {
        margin-left: 0;
        margin-right: 0;
        padding: 2rem 1.5rem;
    }
}

.about-section__title {
    font-size: 1.35rem;
    margin: 0 0 1rem;
    color: #0f172a;
}

.about-section__lead {
    margin: 0 0 1rem;
    color: #475569;
    font-size: 0.98rem;
    line-height: 1.55;
}

.about-prose {
    color: #334155;
    line-height: 1.65;
    font-size: 1rem;
}

.about-prose p {
    margin: 0 0 1rem;
}

.about-prose p:last-child {
    margin-bottom: 0;
}

.about-values {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

@media (max-width: 820px) {
    .about-values {
        grid-template-columns: 1fr;
    }
}

.about-values__card {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1.25rem;
    background: #fff;
}

.about-values__card-title {
    font-size: 1rem;
    margin: 0 0 0.5rem;
    color: #0f172a;
}

.about-values__card-text {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #475569;
}

.about-bullets {
    margin: 1rem 0 0;
    padding-left: 1.2rem;
    color: #334155;
    line-height: 1.65;
}

.about-bullets li {
    margin-bottom: 0.35rem;
}

.about-cert-list {
    margin: 0;
    padding-left: 1.2rem;
    color: #334155;
    line-height: 1.65;
}

.about-cert-list li {
    margin-bottom: 0.35rem;
}

.about-inline-cta {
    font-weight: 600;
    color: var(--color-accent, #b8860b);
    text-decoration: none;
}

.about-inline-cta:hover {
    text-decoration: underline;
}

.about-faq {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
}

.about-faq__item {
    border-bottom: 1px solid #e2e8f0;
}

.about-faq__item:last-child {
    border-bottom: 0;
}

.about-faq__item summary {
    cursor: pointer;
    padding: 1rem 1.1rem;
    font-weight: 600;
    color: #0f172a;
    list-style: none;
}

.about-faq__item summary::-webkit-details-marker {
    display: none;
}

.about-faq__item summary::after {
    content: "+";
    float: right;
    font-weight: 400;
    color: var(--color-muted, #64748b);
}

.about-faq__item[open] summary::after {
    content: "–";
}

.about-faq__item p {
    margin: 0;
    padding: 0 1.1rem 1rem;
    color: #475569;
    font-size: 0.95rem;
    line-height: 1.55;
}

.faq {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
}

.faq__item {
    border: 0;
    border-bottom: 1px solid #e2e8f0;
    border-radius: 0;
    margin: 0;
    padding: 0;
    background: #fff;
}

.faq__item:last-child {
    border-bottom: 0;
}

.about-faq__item summary,
.faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.faq__q {
    padding: 1rem 1.1rem;
    color: #0f172a;
    list-style: none;
}

.faq__q::-webkit-details-marker {
    display: none;
}

.about-faq__item summary::after,
.faq__q::after {
    content: "+";
    flex: 0 0 auto;
    float: none;
    font-weight: 400;
    color: var(--color-muted, #64748b);
}

.about-faq__item[open] summary::after,
.faq__item[open] .faq__q::after {
    content: "-";
}

.faq__a {
    padding: 0;
    color: #475569;
}

.faq__a p {
    margin: 0;
    padding: 0 1.1rem 1rem;
    color: #475569;
    font-size: 0.95rem;
    line-height: 1.55;
}

#about-faq,
#case-studies-faq,
#catalogs-faq,
#certs-faq,
#commercial-faq,
#expo-faq,
#faq.factory-ref__section,
#marketing-faq,
#oem-faq,
#finishes-faq,
#sustainability-faq,
#why-faq {
    background: #fff !important;
}

.faq-hub {
    background: #f7f4ef;
}

.faq-hub__hero {
    min-height: clamp(28rem, 58vh, 38rem);
}

.faq-hub__section {
    background: #f7f4ef;
}

.faq-hub__tools {
    display: grid;
    gap: 0.9rem;
    margin-bottom: clamp(2rem, 5vw, 3.5rem);
    padding: clamp(1.25rem, 3vw, 1.75rem);
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.07);
}

.faq-hub__tools-title {
    margin: 0;
    color: var(--color-ink);
    font-size: clamp(1.45rem, 3vw, 2.1rem);
    line-height: 1.2;
}

.faq-hub__label {
    color: var(--color-ink);
    font-size: 0.9rem;
    font-weight: 700;
}

.faq-hub__search {
    width: 100%;
    min-height: 3.2rem;
    border: 1px solid rgba(184, 149, 74, 0.44);
    border-radius: 6px;
    padding: 0 1rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
}

.faq-hub__search:focus {
    border-color: var(--color-accent-mid);
    outline: none;
    box-shadow: 0 0 0 3px rgba(184, 149, 74, 0.16);
}

.faq-hub__count {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.94rem;
}

.faq-hub__empty {
    margin: 0 0 1.5rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(184, 149, 74, 0.28);
    border-radius: 8px;
    background: #fff;
    color: var(--color-ink);
}

.faq-hub__group {
    margin-bottom: clamp(2rem, 5vw, 3.5rem);
}

.faq-hub__group:last-child {
    margin-bottom: 0;
}

.faq-hub__group-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.faq-hub__group-title {
    margin: 0;
    color: var(--color-ink);
    font-size: clamp(1.35rem, 3vw, 2rem);
    line-height: 1.2;
}

.faq-hub__source {
    flex: 0 0 auto;
    color: var(--color-accent-hover);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: var(--tracking-nav);
    text-decoration: none;
    text-transform: uppercase;
}

.faq-hub__source:hover {
    color: var(--color-ink);
}

.faq-hub__items {
    border-color: #e2e8f0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.faq-hub__item[hidden],
.faq-hub__group[hidden],
.faq-hub__empty[hidden] {
    display: none !important;
}

@media (max-width: 700px) {
    .faq-hub__group-head {
        display: block;
    }

    .faq-hub__source {
        display: inline-flex;
        margin-top: 0.65rem;
    }
}

.about-cta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    align-items: start;
    padding: 1.75rem 1.5rem;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
    margin-bottom: 2.5rem;
}

@media (max-width: 820px) {
    .about-cta {
        grid-template-columns: 1fr;
    }
}

.about-cta__title {
    font-size: 1.25rem;
    margin: 0 0 0.5rem;
    color: #0f172a;
}

.about-cta__lead {
    margin: 0 0 1rem;
    color: #475569;
    font-size: 0.95rem;
    line-height: 1.55;
}

.about-cta__contact {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #334155;
}

/* ================================================
   FACTORY / MANUFACTURING PAGE STYLES
   ================================================ */

.factory-page {
    padding-bottom: 4rem;
}

.factory-hero {
    padding: 3.5rem 0 2.5rem;
    background: linear-gradient(165deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    color: #fff;
}

.factory-hero__inner {
    max-width: 900px;
}

.factory-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.7);
}

.factory-breadcrumb a {
    color: rgba(255,255,255,0.7);
    text-decoration: none;
}

.factory-breadcrumb a:hover {
    color: #fff;
}

.factory-breadcrumb__sep {
    opacity: 0.5;
}

.factory-hero__title {
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 600;
    margin: 0 0 1rem;
    line-height: 1.2;
}

.factory-hero__lead {
    font-size: 1.1rem;
    line-height: 1.6;
    margin: 0;
    max-width: 700px;
    opacity: 0.9;
}

.factory-hero__kicker {
    margin: 0 0 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.75);
    font-family: var(--font-sans);
    font-weight: 600;
}

.factory-hero__actions {
    margin-top: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.factory-subnav {
    position: sticky;
    top: var(--b2b-header-bottom, 120px);
    z-index: 80;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid #e2e8f0;
}

.factory-subnav__list {
    list-style: none;
    margin: 0;
    padding: 0.75rem 0;
    display: flex;
    gap: 0.75rem 1.25rem;
    flex-wrap: wrap;
    align-items: center;
}

.factory-subnav__link {
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    color: #0f172a;
    font-family: var(--font-sans);
}

.factory-subnav__link:hover {
    color: var(--color-accent-mid);
}

.factory-media {
    padding: 3.5rem 0;
    background: #fff;
}

.factory-section-title--left {
    text-align: left;
}

.factory-media__inner {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    gap: 2rem;
    align-items: start;
}

@media (max-width: 900px) {
    .factory-media__inner {
        grid-template-columns: 1fr;
    }

    .factory-subnav__list {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.85rem;
    }
}

.factory-media__lead {
    margin: 0 0 1rem;
    font-size: 1rem;
    line-height: 1.6;
    color: #475569;
}

.factory-media__bullets {
    margin: 0;
    padding-left: 1.1rem;
    color: #334155;
    line-height: 1.65;
}

.factory-media__video {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    background: #0f172a;
}

.factory-video {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    background: #0f172a;
}

.factory-surface,
.factory-pvd {
    padding: 3.5rem 0;
    background: #f8fafc;
}

.factory-pvd {
    background: #fff;
}

.factory-surface__inner,
.factory-pvd__inner {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 2rem;
    align-items: center;
}

.factory-pvd__inner {
    grid-template-columns: 1fr 1.1fr;
}

@media (max-width: 900px) {
    .factory-surface__inner,
    .factory-pvd__inner {
        grid-template-columns: 1fr;
    }
}

.factory-surface__photo,
.factory-pvd__photo {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    object-fit: cover;
}

.factory-highlight {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1.25rem;
}

@media (max-width: 600px) {
    .factory-highlight {
        grid-template-columns: 1fr;
    }
}

.factory-highlight__item {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1rem;
}

.factory-highlight__value {
    display: block;
    font-weight: 800;
    font-size: 1.35rem;
    color: #0f3460;
    margin-bottom: 0.25rem;
}

.factory-highlight__label {
    display: block;
    font-size: 0.88rem;
    color: #475569;
    line-height: 1.45;
}

.factory-testing {
    padding: 3.5rem 0;
    background: #fff;
}

.factory-testing__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
}

@media (max-width: 1100px) {
    .factory-testing__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    .factory-testing__grid {
        grid-template-columns: 1fr;
    }
}

.factory-testing__item {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 1.25rem;
    background: #f8fafc;
}

.factory-testing__title {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
}

.factory-testing__desc {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #475569;
}

.factory-faq {
    padding: 3.5rem 0;
    background: #f8fafc;
}

.factory-cta__form {
    margin: 1.5rem 0 1.25rem;
}

.factory-stats {
    padding: 2.5rem 0;
    background: #fff;
    border-bottom: 1px solid #e2e8f0;
}

.factory-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}

@media (max-width: 768px) {
    .factory-stats__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.factory-stat {
    text-align: center;
    padding: 1.5rem 1rem;
}

.factory-stat__number {
    display: block;
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: 2.5rem;
    font-weight: 700;
    color: #0f3460;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.factory-stat__unit {
    font-size: 1.25rem;
    margin-left: 2px;
}

.factory-stat__label {
    font-size: 0.9rem;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.factory-process {
    padding: 3.5rem 0;
    background: #f8fafc;
}

.factory-section-title {
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: 1.75rem;
    font-weight: 600;
    text-align: center;
    margin: 0 0 2.5rem;
    color: #0f172a;
}

.factory-process__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

@media (max-width: 900px) {
    .factory-process__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .factory-process__grid {
        grid-template-columns: 1fr;
    }
}

.factory-process__step {
    background: #fff;
    padding: 1.75rem;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
    border: 1px solid #e2e8f0;
}

.factory-process__icon {
    width: 48px;
    height: 48px;
    margin-bottom: 1rem;
    background: #0f3460;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.factory-process__icon::before {
    content: "";
    width: 20px;
    height: 20px;
    background: #fff;
    border-radius: 2px;
}

.factory-process__icon--casting::before { border-radius: 50% 50% 0 0; }
.factory-process__icon--machining::before { clip-path: polygon(50% 0%, 100% 100%, 0% 100%); }
.factory-process__icon--polishing::before { border-radius: 50%; }
.factory-process__icon--plating::before { clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); }
.factory-process__icon--assembly::before { clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%); }
.factory-process__icon--packing::before { border-radius: 3px; }

.factory-process__title {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: #0f172a;
}

.factory-process__desc {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #475569;
}

.factory-equipment {
    padding: 3.5rem 0;
    background: #fff;
}

.factory-equipment__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

@media (max-width: 900px) {
    .factory-equipment__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .factory-equipment__grid {
        grid-template-columns: 1fr;
    }
}

.factory-equipment__item {
    padding: 1.25rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.factory-equipment__name {
    font-size: 0.95rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: #0f3460;
}

.factory-equipment__detail {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.5;
    color: #64748b;
}

.factory-quality {
    padding: 3.5rem 0;
    background: #0f3460;
    color: #fff;
}

.factory-quality .factory-section-title {
    color: #fff;
}

.factory-quality__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}

@media (max-width: 768px) {
    .factory-quality__inner {
        grid-template-columns: 1fr;
    }
}

.factory-quality__desc {
    font-size: 1rem;
    line-height: 1.65;
    margin: 0 0 1.5rem;
    opacity: 0.9;
}

.factory-quality__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.factory-quality__list li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.75rem;
    font-size: 0.95rem;
    line-height: 1.5;
}

.factory-quality__list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #4ade80;
    font-weight: 700;
}

.factory-quality__image img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

.factory-capability {
    padding: 3.5rem 0;
    background: #f8fafc;
}

.factory-capability__table {
    overflow-x: auto;
}

.factory-capability__table table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
}

.factory-capability__table th,
.factory-capability__table td {
    padding: 1rem 1.25rem;
    text-align: left;
    border-bottom: 1px solid #e2e8f0;
}

.factory-capability__table th {
    background: #0f3460;
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.factory-capability__table td {
    font-size: 0.95rem;
    color: #334155;
}

.factory-capability__table tr:last-child td {
    border-bottom: none;
}

.factory-capability__table tr:hover td {
    background: #f1f5f9;
}

.factory-cta {
    padding: 4rem 0;
    background: linear-gradient(165deg, #1a1a2e 0%, #16213e 100%);
    color: #fff;
    text-align: center;
}

.factory-cta__inner {
    max-width: 600px;
    margin: 0 auto;
}

.factory-cta__title {
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: 2rem;
    font-weight: 600;
    margin: 0 0 1rem;
}

.factory-cta__desc {
    font-size: 1rem;
    line-height: 1.6;
    margin: 0 0 2rem;
    opacity: 0.9;
}

.factory-cta__buttons {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

/* ----- Factory reference layout (long-form OEM page) ----- */

.factory-ref {
    --factory-ref-max: 1120px;
    --factory-ref-muted: #f4f6f8;
    --factory-ref-dark: #0f172a;
    --factory-ref-line: #e2e8f0;
}

.factory-ref__banner {
    background: var(--factory-ref-dark);
    color: #e2e8f0;
    font-size: 0.9rem;
    padding: 0.65rem 0;
}

.factory-ref__banner-inner {
    max-width: var(--factory-ref-max);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1.25rem;
}

.factory-ref__banner-text {
    margin: 0;
    flex: 1 1 280px;
}

.factory-ref__banner-link {
    color: var(--color-accent, #c9a227);
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
}

.factory-ref__banner-link:hover {
    text-decoration: underline;
}

.factory-ref__hero {
    padding: 3rem 0 3.25rem;
    background: #fff;
    border-bottom: 1px solid var(--factory-ref-line);
}

.factory-ref__hero-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

.factory-ref__h1 {
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: clamp(1.75rem, 4vw, 2.35rem);
    font-weight: 600;
    line-height: 1.2;
    margin: 0 0 1rem;
    color: var(--factory-ref-dark);
}

.factory-ref__lead {
    margin: 0 0 1.75rem;
    font-size: 1.05rem;
    line-height: 1.65;
    color: #475569;
}

.factory-ref__hero-actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.factory-ref__section {
    padding: 3.5rem 0;
    background: #fff;
}

.factory-ref__section--muted {
    background: var(--factory-ref-muted);
}

.factory-ref__section--dark {
    background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
    color: #e2e8f0;
}

.factory-ref__section--contact {
    padding-bottom: 4.5rem;
    border-top: 1px solid var(--factory-ref-line);
}

.factory-ref__h2 {
    font-family: var(--font-heading, 'Cormorant Garamond', serif);
    font-size: clamp(1.45rem, 3vw, 1.85rem);
    font-weight: 600;
    text-align: center;
    margin: 0 0 1rem;
    color: var(--factory-ref-dark);
}

.factory-ref__h2--left {
    text-align: left;
}

.factory-ref__h2--light {
    color: #f8fafc;
}

.factory-ref__narrow {
    max-width: 760px;
    margin: 0 auto 2.25rem;
}

.factory-ref__p {
    margin: 0 0 1rem;
    font-size: 0.98rem;
    line-height: 1.65;
    color: #475569;
}

.factory-ref__p:last-child {
    margin-bottom: 0;
}

.factory-ref__p--center {
    text-align: center;
}

.factory-ref__p--light {
    color: #cbd5e1;
}

.factory-ref__h3 {
    font-size: 1.08rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--factory-ref-dark);
}

.factory-ref__h3--light {
    color: #f8fafc;
}

.factory-ref__kicker {
    margin: 0 0 0.5rem;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-accent, #c9a227);
}

.factory-ref__trio {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
    max-width: var(--factory-ref-max);
    margin: 0 auto;
}

@media (max-width: 960px) {
    .factory-ref__trio {
        grid-template-columns: 1fr;
    }
}

.factory-ref__trio-card {
    background: #fff;
    border: 1px solid var(--factory-ref-line);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(15, 23, 42, 0.05);
}

.factory-ref__section--muted .factory-ref__trio-card {
    background: #fff;
}

.factory-ref__media {
    aspect-ratio: 16 / 10;
    background: #0f172a;
}

.factory-ref__media--img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.factory-ref__media-empty {
    width: 100%;
    height: 100%;
    min-height: 10rem;
    background: linear-gradient(145deg, #1e293b 0%, #475569 100%);
}

.factory-ref__video {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.factory-ref__trio-card .factory-ref__h3,
.factory-ref__trio-card .factory-ref__p {
    padding: 0 1.25rem;
}

.factory-ref__trio-card .factory-ref__h3 {
    margin-top: 1.15rem;
}

.factory-ref__trio-card .factory-ref__p {
    padding-bottom: 1.35rem;
}

.factory-ref__grid6 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    max-width: var(--factory-ref-max);
    margin: 0 auto;
}

@media (max-width: 900px) {
    .factory-ref__grid6 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 560px) {
    .factory-ref__grid6 {
        grid-template-columns: 1fr;
    }
}

.factory-ref__card {
    background: #fff;
    border: 1px solid var(--factory-ref-line);
    border-radius: 12px;
    padding: 1.35rem 1.25rem;
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.04);
}

.factory-ref__card--on-dark {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: none;
}

.factory-ref__test-row {
    max-width: var(--factory-ref-max);
    margin: 0 auto 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--factory-ref-line);
}

.factory-ref__test-row:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.factory-ref__test-title {
    font-size: 1.2rem;
    font-weight: 600;
    margin: 0 0 0.65rem;
    color: var(--factory-ref-dark);
}

.factory-ref__timeline {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    max-width: 720px;
    position: relative;
}

.factory-ref__timeline::before {
    content: "";
    position: absolute;
    left: 11px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--factory-ref-line);
}

.factory-ref__timeline-item {
    position: relative;
    padding-left: 3rem;
    margin-bottom: 1.75rem;
}

.factory-ref__timeline-item:last-child {
    margin-bottom: 0;
}

.factory-ref__timeline-dot {
    position: absolute;
    left: 0;
    top: 0.35rem;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--color-accent, #c9a227);
    box-shadow: 0 0 0 2px var(--factory-ref-muted);
}

.factory-ref__timeline-body .factory-ref__p {
    margin-bottom: 0;
}

.factory-ref__grid4 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    max-width: var(--factory-ref-max);
    margin: 2rem auto 0;
}

@media (max-width: 640px) {
    .factory-ref__grid4 {
        grid-template-columns: 1fr;
    }
}

.factory-ref__cat {
    background: #fff;
    border: 1px solid var(--factory-ref-line);
    border-radius: 12px;
    padding: 1.5rem 1.35rem;
}

.factory-ref__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    align-items: center;
    max-width: var(--factory-ref-max);
    margin: 0 auto;
}

@media (max-width: 900px) {
    .factory-ref__split {
        grid-template-columns: 1fr;
    }
}

.factory-ref__split-media img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    display: block;
    border: 1px solid var(--factory-ref-line);
}

.factory-ref__split-media-empty {
    width: 100%;
    min-height: clamp(14rem, 28vw, 22rem);
    border-radius: 12px;
    border: 1px solid var(--factory-ref-line);
    background: linear-gradient(145deg, #e2e8f0 0%, #f8fafc 100%);
}

.factory-ref__text-link {
    color: var(--color-accent, #c9a227);
    font-weight: 600;
    text-decoration: none;
}

.factory-ref__text-link:hover {
    text-decoration: underline;
}

.factory-ref__center-btns {
    display: flex;
    justify-content: center;
    margin-top: 1.5rem;
}

.factory-ref__quotes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    max-width: var(--factory-ref-max);
    margin: 0 auto;
}

@media (max-width: 900px) {
    .factory-ref__quotes {
        grid-template-columns: 1fr;
    }
}

.factory-ref__quote {
    margin: 0;
    padding: 1.35rem 1.25rem;
    background: #fff;
    border: 1px solid var(--factory-ref-line);
    border-radius: 12px;
    border-left: 4px solid var(--color-accent, #c9a227);
}

.factory-ref__quote-text {
    margin: 0 0 0.85rem;
    font-size: 0.95rem;
    line-height: 1.6;
    color: #334155;
    font-style: italic;
}

.factory-ref__quote-cite {
    font-size: 0.85rem;
    font-style: normal;
    color: #64748b;
}

.factory-ref__contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    max-width: var(--factory-ref-max);
    margin: 0 auto;
    align-items: start;
}

@media (max-width: 900px) {
    .factory-ref__contact-grid {
        grid-template-columns: 1fr;
    }
}

.factory-ref__contact-card {
    background: var(--factory-ref-muted);
    border: 1px solid var(--factory-ref-line);
    border-radius: 12px;
    padding: 1.75rem 1.5rem;
}

.factory-ref__contact-list {
    margin: 0;
    padding-left: 1.1rem;
    color: #334155;
    line-height: 1.65;
}

.factory-ref__contact-list li {
    margin-bottom: 0.5rem;
}

.factory-ref__form :where(input, textarea, select) {
    max-width: 100%;
    box-sizing: border-box;
}

.factory-ref__fineprint {
    margin: 1rem 0 0;
    font-size: 0.82rem;
    color: #64748b;
}

.factory-ref__follow {
    margin: 1rem 0 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: #334155;
}

.about-cta__contact li {
    margin-bottom: 0.35rem;
}

.about-cta__alt {
    margin: 0;
    font-size: 0.9rem;
}

.about-cta__alt a {
    color: var(--color-accent, #b8860b);
    font-weight: 600;
    text-decoration: none;
}

.about-cta__alt a:hover {
    text-decoration: underline;
}

.about-cta__form :where(input[type="text"], input[type="email"], input[type="tel"], textarea, select) {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.about-cta__form-empty {
    margin: 0;
    color: var(--color-muted, #64748b);
    font-size: 0.95rem;
}

.about-page__editor {
    font-size: 0.95rem;
    color: #475569;
    padding-top: 0.5rem;
    border-top: 1px solid #e2e8f0;
}

.about-page__editor > *:first-child {
    margin-top: 0;
}

/* ----- Menu landing pages (why choose us / sustainability / OEM / case studies / commercial / finishes / catalogs / marketing) ----- */

.insight-page__breadcrumb {
    color: rgba(255, 255, 255, 0.68);
}

.insight-page__breadcrumb a:hover {
    color: var(--color-accent);
}

.insight-page,
.certs-page,
.exhibitions-page {
    --info-image: linear-gradient(160deg, #cbd5e1 0%, #f1f5f9 100%);
    --info-text-bg: #ebe8e1;
}

.insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header,
.certs-page > .section:not(.cta-band) > .container > .section__header,
.exhibitions-page > .section:not(.cta-band) > .container > .section__header {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    grid-template-rows: auto 1fr;
    gap: 0 clamp(1.5rem, 5vw, 4.5rem);
    align-items: stretch;
    max-width: none;
    min-height: clamp(19rem, 36vw, 28rem);
    margin-bottom: clamp(2rem, 4vw, 3rem);
    position: relative;
}

.insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header::before,
.certs-page > .section:not(.cta-band) > .container > .section__header::before,
.exhibitions-page > .section:not(.cta-band) > .container > .section__header::before {
    content: "";
    grid-column: 1;
    grid-row: 1 / 3;
    border-radius: 8px;
    background: var(--info-text-bg);
    border: 1px solid rgba(224, 221, 212, 0.75);
}

.insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header::after,
.certs-page > .section:not(.cta-band) > .container > .section__header::after,
.exhibitions-page > .section:not(.cta-band) > .container > .section__header::after {
    content: "";
    grid-column: 2;
    grid-row: 1 / 3;
    border-radius: 8px;
    background-image: var(--info-image);
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(224, 221, 212, 0.8);
    min-height: clamp(17rem, 34vw, 27rem);
}

.insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__title,
.certs-page > .section:not(.cta-band) > .container > .section__header > .section__title,
.exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__title {
    grid-column: 1;
    grid-row: 1;
    align-self: end;
    position: relative;
    z-index: 1;
    margin: 0;
    padding: clamp(1.5rem, 4vw, 3rem) clamp(1.35rem, 3vw, 2.5rem) 0;
}

.insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__desc,
.certs-page > .section:not(.cta-band) > .container > .section__header > .section__desc,
.exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__desc {
    grid-column: 1;
    grid-row: 2;
    position: relative;
    z-index: 1;
    max-width: none;
    margin: 0;
    padding: 1rem clamp(1.35rem, 3vw, 2.5rem) clamp(1.5rem, 4vw, 3rem);
    color: var(--color-muted);
}

.insight-page > .section:nth-of-type(even):not(.insight-page__stats):not(.cta-band) > .container > .section__header::before,
.certs-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header::before,
.exhibitions-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header::before {
    grid-column: 2;
}

.insight-page > .section:nth-of-type(even):not(.insight-page__stats):not(.cta-band) > .container > .section__header::after,
.certs-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header::after,
.exhibitions-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header::after {
    grid-column: 1;
}

.insight-page > .section:nth-of-type(even):not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__title,
.insight-page > .section:nth-of-type(even):not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__desc,
.certs-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header > .section__title,
.certs-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header > .section__desc,
.exhibitions-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header > .section__title,
.exhibitions-page > .section:nth-of-type(even):not(.cta-band) > .container > .section__header > .section__desc {
    grid-column: 2;
}

.insight-page > .section:nth-of-type(3n + 1),
.certs-page > .section:nth-of-type(3n + 1),
.exhibitions-page > .section:nth-of-type(3n + 1) {
    --info-text-bg: #ebe8e1;
}

.insight-page > .section:nth-of-type(3n + 2),
.certs-page > .section:nth-of-type(3n + 2),
.exhibitions-page > .section:nth-of-type(3n + 2) {
    --info-text-bg: #f4f0e7;
}

.insight-page > .section:nth-of-type(3n),
.certs-page > .section:nth-of-type(3n),
.exhibitions-page > .section:nth-of-type(3n) {
    --info-text-bg: #eef2ef;
}

#why-trust,
#case-studies-backbone,
#commercial-logistics,
#oem-system,
#catalogs-kits {
    --info-image: linear-gradient(145deg, #94a3b8 0%, #cbd5e1 55%, #e2e8f0 100%);
}

#why-difference,
#sustainability-water,
#certs-regions,
#certs-advantage {
    --info-image: linear-gradient(135deg, #64748b 0%, #94a3b8 100%);
}

#why-portfolio,
#sustainability-material,
#commercial-projects,
#finishes-gallery,
#catalogs-categories,
#marketing-groups {
    --info-image: linear-gradient(145deg, #e2e8f0 0%, #e8e4dc 50%, #f8fafc 100%);
}

#case-studies-projects,
#marketing-support,
#footprint {
    --info-image: linear-gradient(135deg, #475569 0%, #94a3b8 100%);
}

.insight-page .section > .container.split {
    gap: clamp(1.5rem, 5vw, 4.5rem);
    align-items: stretch;
}

.insight-page .section > .container.split > div:first-child:not(.split__media--photo) {
    border-radius: 8px;
    background: var(--info-text-bg);
    border: 1px solid rgba(224, 221, 212, 0.75);
    padding: clamp(1.5rem, 4vw, 3rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.insight-page .section:nth-of-type(even) > .container.split {
    direction: rtl;
}

.insight-page .section:nth-of-type(even) > .container.split > * {
    direction: ltr;
}

.insight-page .section > .container.split .split__media--photo {
    border-radius: 8px;
    min-height: clamp(17rem, 34vw, 27rem);
}

@media (max-width: 900px) {
    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header,
    .certs-page > .section:not(.cta-band) > .container > .section__header,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        min-height: 0;
        gap: 0;
    }

    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header::before,
    .certs-page > .section:not(.cta-band) > .container > .section__header::before,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header::before {
        grid-column: 1 !important;
        grid-row: 2 / 4;
    }

    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header::after,
    .certs-page > .section:not(.cta-band) > .container > .section__header::after,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header::after {
        grid-column: 1 !important;
        grid-row: 1;
        min-height: clamp(14rem, 58vw, 22rem);
        margin-bottom: 1rem;
    }

    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__title,
    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__desc,
    .certs-page > .section:not(.cta-band) > .container > .section__header > .section__title,
    .certs-page > .section:not(.cta-band) > .container > .section__header > .section__desc,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__title,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__desc {
        grid-column: 1 !important;
    }

    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__title,
    .certs-page > .section:not(.cta-band) > .container > .section__header > .section__title,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__title {
        grid-row: 2;
    }

    .insight-page > .section:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__desc,
    .certs-page > .section:not(.cta-band) > .container > .section__header > .section__desc,
    .exhibitions-page > .section:not(.cta-band) > .container > .section__header > .section__desc {
        grid-row: 3;
    }

    .insight-page .section:nth-of-type(even) > .container.split {
        direction: ltr;
    }
}

.insight-page,
.certs-page,
.exhibitions-page {
    --card-media-size: 4rem;
    --card-media-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 5h10l4 4v18H9z'/%3E%3Cpath d='M19 5v5h5'/%3E%3Cpath d='M12 16h8'/%3E%3Cpath d='M12 21h8'/%3E%3C/svg%3E");
    --icon-audit: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11 5h10l2 3v19H9V8z'/%3E%3Cpath d='M12 12h8'/%3E%3Cpath d='M12 17h8'/%3E%3Cpath d='M12 22h5'/%3E%3C/svg%3E");
    --icon-building: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 27V9l9-4 9 4v18'/%3E%3Cpath d='M11 13h2'/%3E%3Cpath d='M19 13h2'/%3E%3Cpath d='M11 18h2'/%3E%3Cpath d='M19 18h2'/%3E%3Cpath d='M14 27v-5h4v5'/%3E%3C/svg%3E");
    --icon-calendar: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='6' y='8' width='20' height='18' rx='2'/%3E%3Cpath d='M10 5v6'/%3E%3Cpath d='M22 5v6'/%3E%3Cpath d='M6 14h20'/%3E%3Cpath d='M11 19h4'/%3E%3Cpath d='M18 19h3'/%3E%3C/svg%3E");
    --icon-cash: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='9' width='22' height='14' rx='2'/%3E%3Ccircle cx='16' cy='16' r='3'/%3E%3Cpath d='M9 13v6'/%3E%3Cpath d='M23 13v6'/%3E%3C/svg%3E");
    --icon-certificate: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 5h16v18H8z'/%3E%3Cpath d='M12 10h8'/%3E%3Cpath d='M12 15h8'/%3E%3Cpath d='M13 23l-2 5 5-2 5 2-2-5'/%3E%3C/svg%3E");
    --icon-droplet: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 4s8 8 8 15a8 8 0 0 1-16 0C8 12 16 4 16 4z'/%3E%3Cpath d='M12 20a4 4 0 0 0 4 4'/%3E%3C/svg%3E");
    --icon-eye: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 16s4-7 12-7 12 7 12 7-4 7-12 7S4 16 4 16z'/%3E%3Ccircle cx='16' cy='16' r='3'/%3E%3C/svg%3E");
    --icon-factory: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 27V14l7 4v-4l7 4V8h6v19z'/%3E%3Cpath d='M9 23h3'/%3E%3Cpath d='M16 23h3'/%3E%3Cpath d='M23 23h2'/%3E%3C/svg%3E");
    --icon-gear: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='16' cy='16' r='4'/%3E%3Cpath d='M16 4v4'/%3E%3Cpath d='M16 24v4'/%3E%3Cpath d='M4 16h4'/%3E%3Cpath d='M24 16h4'/%3E%3Cpath d='M7.5 7.5l3 3'/%3E%3Cpath d='M21.5 21.5l3 3'/%3E%3Cpath d='M24.5 7.5l-3 3'/%3E%3Cpath d='M10.5 21.5l-3 3'/%3E%3C/svg%3E");
    --icon-globe: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='16' cy='16' r='11'/%3E%3Cpath d='M5 16h22'/%3E%3Cpath d='M16 5c3 3 4.5 7 4.5 11S19 24 16 27c-3-3-4.5-7-4.5-11S13 8 16 5z'/%3E%3C/svg%3E");
    --icon-grid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='5' width='9' height='9'/%3E%3Crect x='18' y='5' width='9' height='9'/%3E%3Crect x='5' y='18' width='9' height='9'/%3E%3Crect x='18' y='18' width='9' height='9'/%3E%3C/svg%3E");
    --icon-hotel: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 27V6h12v21'/%3E%3Cpath d='M18 13h8v14'/%3E%3Cpath d='M10 11h4'/%3E%3Cpath d='M10 16h4'/%3E%3Cpath d='M10 21h4'/%3E%3Cpath d='M21 18h2'/%3E%3Cpath d='M21 23h2'/%3E%3C/svg%3E");
    --icon-label: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 16L16 5h9v9L14 27z'/%3E%3Ccircle cx='21' cy='10' r='2'/%3E%3C/svg%3E");
    --icon-leaf: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M25 7c-9 1-15 6-17 15'/%3E%3Cpath d='M23 7c2 9-2 16-11 17'/%3E%3Cpath d='M10 22c3-1 6-3 9-7'/%3E%3C/svg%3E");
    --icon-package: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 10l11-5 11 5-11 5z'/%3E%3Cpath d='M5 10v12l11 5 11-5V10'/%3E%3Cpath d='M16 15v12'/%3E%3C/svg%3E");
    --icon-pen: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 24l3 3 15-15-3-3z'/%3E%3Cpath d='M18 7l3-3 7 7-3 3'/%3E%3Cpath d='M5 27l4-1'/%3E%3C/svg%3E");
    --icon-recycle: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 6l4-3 4 7'/%3E%3Cpath d='M16 3l-3 7h8'/%3E%3Cpath d='M25 17l4 2-5 7'/%3E%3Cpath d='M29 19l-7-1 4 7'/%3E%3Cpath d='M8 26l-5-1 4-8'/%3E%3Cpath d='M3 25l7-2-4-6'/%3E%3C/svg%3E");
    --icon-shield: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 4l10 4v7c0 6-4 11-10 13C10 26 6 21 6 15V8z'/%3E%3Cpath d='M11 16l3 3 7-7'/%3E%3C/svg%3E");
    --icon-spark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 3l3 10 10 3-10 3-3 10-3-10-10-3 10-3z'/%3E%3C/svg%3E");
    --icon-swatches: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 23V7h8v16a4 4 0 0 1-8 0z'/%3E%3Cpath d='M16 10l6 6-8 8'/%3E%3Cpath d='M22 16h4v8H12'/%3E%3C/svg%3E");
    --icon-timer: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='16' cy='17' r='10'/%3E%3Cpath d='M13 4h6'/%3E%3Cpath d='M16 17l4-4'/%3E%3Cpath d='M16 7v3'/%3E%3C/svg%3E");
    --icon-truck: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 9h15v12H4z'/%3E%3Cpath d='M19 13h5l4 4v4h-9z'/%3E%3Ccircle cx='10' cy='24' r='2'/%3E%3Ccircle cx='23' cy='24' r='2'/%3E%3C/svg%3E");
    --icon-users: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='11' r='4'/%3E%3Ccircle cx='22' cy='13' r='3'/%3E%3Cpath d='M5 26c1-5 4-8 7-8s6 3 7 8'/%3E%3Cpath d='M18 22c1-3 3-5 5-5 3 0 5 3 6 7'/%3E%3C/svg%3E");
    --icon-video: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='9' width='15' height='14' rx='2'/%3E%3Cpath d='M20 14l7-4v12l-7-4z'/%3E%3C/svg%3E");
    --icon-wrench: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 5a7 7 0 0 0-7 9L5 23l4 4 9-9a7 7 0 0 0 9-8l-5 5-4-4z'/%3E%3C/svg%3E");
}

.insight-page .tile-card,
.certs-page .tile-card,
.exhibitions-page .expo-fair,
.insight-stat {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-height: 100%;
}

.insight-page .tile-card::before,
.certs-page .tile-card::before,
.exhibitions-page .expo-fair::before,
.insight-stat::before {
    content: "";
    display: block;
    width: var(--card-media-size);
    height: var(--card-media-size);
    flex: 0 0 var(--card-media-size);
    margin-bottom: 1rem;
    border: 1px solid rgba(184, 149, 74, 0.22);
    border-radius: 8px;
    background-image: var(--card-media-icon), linear-gradient(135deg, #f7f4eb 0%, #fff 48%, #ece6d8 100%);
    background-position: center;
    background-repeat: no-repeat;
    background-size: 1.85rem 1.85rem, auto;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.insight-page .tile-card:nth-child(3n + 2)::before,
.certs-page .tile-card:nth-child(3n + 2)::before,
.exhibitions-page .expo-fair:nth-child(3n + 2)::before,
.insight-stat:nth-child(3n + 2)::before {
    background-image: var(--card-media-icon), linear-gradient(135deg, #eef3f1 0%, #fff 48%, #dfe8e4 100%);
}

.insight-page .tile-card:nth-child(3n)::before,
.certs-page .tile-card:nth-child(3n)::before,
.exhibitions-page .expo-fair:nth-child(3n)::before,
.insight-stat:nth-child(3n)::before {
    background-image: var(--card-media-icon), linear-gradient(135deg, #f0f2f6 0%, #fff 48%, #e2e5ec 100%);
}

.insight-page--sustainability,
.insight-page--commercial {
    --card-media-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M25 7c-9 1-15 6-17 15'/%3E%3Cpath d='M23 7c2 9-2 16-11 17'/%3E%3Cpath d='M10 22c3-1 6-3 9-7'/%3E%3C/svg%3E");
}

.insight-page--oem,
.insight-page--case-studies {
    --card-media-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 22l10-10'/%3E%3Cpath d='M18 6l8 8'/%3E%3Cpath d='M13 11l8 8'/%3E%3Cpath d='M8 24h8'/%3E%3C/svg%3E");
}

.insight-page--catalogs,
.insight-page--marketing,
.certs-page {
    --card-media-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32' fill='none' stroke='%238a6e36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 8h18'/%3E%3Cpath d='M7 16h18'/%3E%3Cpath d='M7 24h12'/%3E%3Cpath d='M5 5h22v22H5z'/%3E%3C/svg%3E");
}

/* Contextual card icons. */
.insight-page--why .insight-stat:nth-child(1),
#why-trust .tile-card:nth-child(2),
#oem-system .insight-step:nth-child(4) {
    --card-media-icon: var(--icon-factory);
}

.insight-page--why .insight-stat:nth-child(2),
#why-difference .tile-card:nth-child(1),
#sustainability-esg .tile-card:nth-child(1),
#certs-regions .certs-region:nth-of-type(1) .tile-card:nth-child(3),
#footprint .expo-footprint__region:nth-child(4) .expo-fair:nth-child(2) {
    --card-media-icon: var(--icon-shield);
}

.insight-page--why .insight-stat:nth-child(3),
#why-trust .tile-card:nth-child(3),
#why-difference .tile-card:nth-child(3) {
    --card-media-icon: var(--icon-timer);
}

.insight-page--why .insight-stat:nth-child(4),
#footprint .expo-footprint__region:nth-child(5) .expo-fair:nth-child(2),
#finishes-process .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-spark);
}

#why-trust .tile-card:nth-child(1),
#oem-support .tile-card:nth-child(2),
#case-studies-backbone .tile-card:nth-child(2),
#certs-regions .certs-region:nth-of-type(1) .tile-card:nth-child(1),
#certs-regions .certs-region:nth-of-type(2) .tile-card:nth-child(1),
#certs-regions .certs-region:nth-of-type(3) .tile-card:nth-child(1) {
    --card-media-icon: var(--icon-certificate);
}

#why-trust .tile-card:nth-child(4),
#sustainability-material .tile-card:nth-child(2),
#catalogs-kits .tile-card:nth-child(2),
#finishes-process .tile-card:nth-child(3),
#certs-regions .certs-region:nth-of-type(4) .tile-card {
    --card-media-icon: var(--icon-audit);
}

#why-difference .tile-card:nth-child(2),
#why-portfolio .tile-card:nth-child(2),
#oem-support .tile-card:nth-child(3) {
    --card-media-icon: var(--icon-cash);
}

#why-difference .tile-card:nth-child(4),
.insight-page--sustainability .insight-stat:nth-child(4),
#sustainability-esg .tile-card:nth-child(3),
#commercial-projects .tile-card:nth-child(3) {
    --card-media-icon: var(--icon-leaf);
}

#why-portfolio .tile-card:nth-child(1),
#catalogs-kits .tile-card:nth-child(1),
#catalogs-kits .tile-card:nth-child(4),
#catalogs-categories .tile-card:nth-child(7) {
    --card-media-icon: var(--icon-grid);
}

#why-portfolio .tile-card:nth-child(3),
#oem-system .insight-step:nth-child(5),
#case-studies-backbone .tile-card:nth-child(3),
#commercial-logistics .insight-step:nth-child(2),
#marketing-support .tile-card:nth-child(3),
#catalogs-categories .tile-card:nth-child(9) {
    --card-media-icon: var(--icon-package);
}

#why-portfolio .tile-card:nth-child(4),
#commercial-logistics .insight-step:nth-child(3),
#marketing-support .tile-card:nth-child(2),
#marketing-groups .tile-card:nth-child(3),
#catalogs-categories .tile-card:nth-child(5) {
    --card-media-icon: var(--icon-wrench);
}

#why-process .insight-step:nth-child(1),
#oem-system .insight-step:nth-child(1) {
    --card-media-icon: var(--icon-shield);
}

#why-process .insight-step:nth-child(2),
#oem-system .insight-step:nth-child(2),
#case-studies-backbone .tile-card:nth-child(1) {
    --card-media-icon: var(--icon-pen);
}

#why-process .insight-step:nth-child(3),
#oem-support .tile-card:nth-child(1),
#oem-system .insight-step:nth-child(3),
#finishes-process .tile-card:nth-child(1),
#catalogs-categories .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-gear);
}

#why-process .insight-step:nth-child(4),
#commercial-logistics .insight-step:nth-child(1) {
    --card-media-icon: var(--icon-truck);
}

.insight-page--sustainability .insight-stat:nth-child(1),
.insight-page--sustainability .insight-stat:nth-child(2),
#sustainability-material .tile-card:nth-child(1),
#sustainability-water .tile-card:nth-child(1),
#certs-regions .certs-region:nth-of-type(1) .tile-card:nth-child(2),
#certs-regions .certs-region:nth-of-type(2) .tile-card:nth-child(2),
#catalogs-categories .tile-card:nth-child(1),
#catalogs-categories .tile-card:nth-child(4),
#catalogs-categories .tile-card:nth-child(6),
#catalogs-categories .tile-card:nth-child(8),
#marketing-groups .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-droplet);
}

.insight-page--sustainability .insight-stat:nth-child(3),
#case-studies-projects .tile-card:nth-child(2),
#catalogs-categories .tile-card:nth-child(10) {
    --card-media-icon: var(--icon-swatches);
}

#sustainability-material .tile-card:nth-child(3),
#catalogs-categories .tile-card:nth-child(3) {
    --card-media-icon: var(--icon-certificate);
}

#sustainability-water .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-gear);
}

#sustainability-water .tile-card:nth-child(3),
.insight-page--case-studies .insight-stat:nth-child(1),
#case-studies-projects .tile-card:nth-child(3),
#finishes-selection .tile-card:nth-child(3),
#footprint .expo-footprint__region:nth-child(1) .expo-fair:nth-child(1),
#footprint .expo-footprint__region:nth-child(4) .expo-fair:nth-child(1),
#footprint .expo-footprint__region:nth-child(5) .expo-fair:nth-child(1) {
    --card-media-icon: var(--icon-globe);
}

#sustainability-esg .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-recycle);
}

.insight-page--case-studies .insight-stat:nth-child(2) {
    --card-media-icon: var(--icon-factory);
}

.insight-page--case-studies .insight-stat:nth-child(3) {
    --card-media-icon: var(--icon-pen);
}

#case-studies-projects .tile-card:nth-child(1),
#catalogs-kits .tile-card:nth-child(3) {
    --card-media-icon: var(--icon-label);
}

#commercial-projects .tile-card:nth-child(1),
#footprint .expo-footprint__region:nth-child(3) .expo-fair:nth-child(1) {
    --card-media-icon: var(--icon-building);
}

#commercial-projects .tile-card:nth-child(2),
#footprint .expo-footprint__region:nth-child(3) .expo-fair:nth-child(2),
#finishes-selection .tile-card:nth-child(2) {
    --card-media-icon: var(--icon-hotel);
}

#marketing-support .tile-card:nth-child(1),
#marketing-groups .tile-card:nth-child(1) {
    --card-media-icon: var(--icon-video);
}

#footprint .expo-footprint__region:nth-child(2) .expo-fair:nth-child(1) {
    --card-media-icon: var(--icon-gear);
}

#footprint .expo-footprint__region:nth-child(2) .expo-fair:nth-child(2) {
    --card-media-icon: var(--icon-swatches);
}

#footprint .expo-footprint__region:nth-child(2) .expo-fair:nth-child(3) {
    --card-media-icon: var(--icon-droplet);
}

.insight-page .insight-gallery__item::before {
    content: none;
}

.insight-page__stats {
    padding-top: 0;
}

.insight-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: -2.25rem;
    position: relative;
    z-index: 2;
}

.insight-stat-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 900px) {
    .insight-stat-grid,
    .insight-stat-grid--3 {
        grid-template-columns: repeat(2, 1fr);
        margin-top: 0;
    }
}

@media (max-width: 560px) {
    .insight-stat-grid,
    .insight-stat-grid--3 {
        grid-template-columns: 1fr;
    }
}

.insight-stat {
    background: var(--color-surface);
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    padding: 1.25rem 1.2rem;
    box-shadow: var(--shadow-soft);
}

.insight-stat__value {
    margin: 0 0 0.4rem;
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 2.2vw, 1.9rem);
    line-height: 1.1;
    color: var(--color-ink);
}

.insight-stat__label {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.92rem;
    line-height: 1.55;
}

.insight-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 1rem;
}

.insight-step {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    align-items: start;
    background: var(--color-surface);
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    padding: 1.15rem 1.2rem;
    box-shadow: var(--shadow-soft);
}

.insight-step__index {
    width: var(--card-media-size);
    height: var(--card-media-size);
    border: 1px solid rgba(184, 149, 74, 0.22);
    border-radius: 8px;
    flex: 0 0 var(--card-media-size);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-image: var(--card-media-icon), linear-gradient(135deg, #f7f4eb 0%, #fff 48%, #ece6d8 100%);
    background-position: center;
    background-repeat: no-repeat;
    background-size: 1.85rem 1.85rem, auto;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
    color: transparent;
    font-size: 0;
    line-height: 0;
}

.insight-step__title {
    margin: 0 0 0.45rem;
    font-size: 1.02rem;
    line-height: 1.35;
    color: var(--color-ink);
}

.insight-step__text {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.65;
}

:where(.insight-page, .certs-page, .exhibitions-page) > .section.section--visual-cards:not(.insight-page__stats):not(.cta-band) > .container > .section__header {
    display: block;
    min-height: 0;
    max-width: 68rem;
    margin-inline: auto;
    margin-bottom: clamp(2rem, 4vw, 3rem);
    text-align: center;
}

:where(.insight-page, .certs-page, .exhibitions-page) > .section.section--visual-cards:not(.insight-page__stats):not(.cta-band) > .container > .section__header::before,
:where(.insight-page, .certs-page, .exhibitions-page) > .section.section--visual-cards:not(.insight-page__stats):not(.cta-band) > .container > .section__header::after {
    content: none;
}

:where(.insight-page, .certs-page, .exhibitions-page) > .section.section--visual-cards:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__title {
    margin: 0;
    padding: 0;
}

:where(.insight-page, .certs-page, .exhibitions-page) > .section.section--visual-cards:not(.insight-page__stats):not(.cta-band) > .container > .section__header > .section__desc {
    display: none;
}

.visual-info-cards {
    --visual-info-columns: 3;
    display: grid;
    grid-template-columns: repeat(var(--visual-info-columns), minmax(0, 1fr));
    gap: clamp(1.4rem, 3vw, 2rem);
    align-items: start;
}

.visual-info-cards--2 {
    --visual-info-columns: 2;
}

.visual-info-cards--4 {
    --visual-info-columns: 4;
}

.visual-info-card {
    min-width: 0;
}

.visual-info-card__media {
    width: 100%;
    aspect-ratio: 1.08 / 0.95;
    overflow: hidden;
    background: #eef0ed;
}

.visual-info-card__media img,
.visual-info-card__media-empty {
    display: block;
    width: 100%;
    height: 100%;
}

.visual-info-card__media img {
    object-fit: cover;
}

.visual-info-card__media-empty {
    background:
        radial-gradient(circle at 50% 36%, rgba(184, 149, 74, 0.2), transparent 65%),
        linear-gradient(135deg, #eef2ef 0%, #dbe2df 100%);
}

.visual-info-card__body {
    padding-top: 1.1rem;
}

.visual-info-card__title {
    margin: 0 0 1rem;
    font-size: 1.02rem;
    line-height: 1.35;
    color: var(--color-ink);
}

.visual-info-card__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.85rem;
}

.visual-info-card__list li {
    position: relative;
    padding-left: 1.55rem;
    color: var(--color-ink);
    font-size: 0.92rem;
    line-height: 1.65;
}

.visual-info-card__list li::before {
    content: "";
    position: absolute;
    left: 0.2rem;
    top: 0.55rem;
    width: 0.45rem;
    height: 0.25rem;
    border-left: 2px solid var(--color-accent);
    border-bottom: 2px solid var(--color-accent);
    transform: rotate(-45deg);
}

.visual-info-card__list strong {
    color: var(--color-ink);
    font-weight: 700;
}

@media (max-width: 980px) {
    .visual-info-cards,
    .visual-info-cards--4 {
        --visual-info-columns: 2;
    }
}

@media (max-width: 620px) {
    .visual-info-cards,
    .visual-info-cards--2,
    .visual-info-cards--4 {
        --visual-info-columns: 1;
    }
}

#oem-system > .container > .section__header {
    display: block;
    min-height: 0;
    max-width: 68rem;
    margin-inline: auto;
    margin-bottom: clamp(2rem, 4vw, 3rem);
    text-align: center;
}

#oem-system > .container > .section__header::before,
#oem-system > .container > .section__header::after {
    content: none;
}

#oem-system > .container > .section__header > .section__title {
    margin: 0;
    padding: 0;
}

#oem-system > .container > .section__header > .section__desc {
    display: none;
}

#oem-system .oem-process-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.4rem, 3vw, 2rem);
    align-items: start;
}

#oem-system .oem-process-card {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.oem-process-card__media {
    width: 100%;
    aspect-ratio: 1.08 / 0.95;
    overflow: hidden;
    background: #eef0ed;
}

.oem-process-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.oem-process-card__body {
    padding-top: 1.1rem;
}

#oem-system .oem-process-card .insight-step__title {
    margin-bottom: 1rem;
    font-size: 1.02rem;
    line-height: 1.35;
}

.oem-process-card__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.85rem;
}

.oem-process-card__list li {
    position: relative;
    padding-left: 1.55rem;
    color: var(--color-ink);
    font-size: 0.92rem;
    line-height: 1.65;
}

.oem-process-card__list li::before {
    content: "";
    position: absolute;
    left: 0.2rem;
    top: 0.55rem;
    width: 0.45rem;
    height: 0.25rem;
    border-left: 2px solid var(--color-accent);
    border-bottom: 2px solid var(--color-accent);
    transform: rotate(-45deg);
}

.oem-process-card__list strong {
    color: var(--color-ink);
    font-weight: 700;
}

@media (max-width: 980px) {
    #oem-system .oem-process-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    #oem-system .oem-process-cards {
        grid-template-columns: 1fr;
    }
}

.insight-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    background: var(--color-surface);
    box-shadow: var(--shadow-soft);
}

.insight-table {
    width: 100%;
    min-width: 680px;
    border-collapse: collapse;
}

.insight-table th,
.insight-table td {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid var(--color-line);
    text-align: left;
    vertical-align: top;
    font-size: 0.94rem;
    line-height: 1.55;
}

.insight-table th {
    background: #f8fafc;
    color: var(--color-ink);
    font-weight: 600;
}

.insight-table td {
    color: var(--color-muted);
}

.insight-table tbody tr:last-child td {
    border-bottom: 0;
}

.insight-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

@media (max-width: 900px) {
    .insight-gallery {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 560px) {
    .insight-gallery {
        grid-template-columns: 1fr;
    }
}

.insight-gallery__item {
    padding-top: 1rem;
}

.insight-swatch {
    width: var(--card-media-size);
    height: var(--card-media-size);
    flex: 0 0 var(--card-media-size);
    border-radius: 8px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    margin-bottom: 1rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16);
}

.insight-cta-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
}

.insight-page .btn--ghost {
    border-color: rgba(250, 250, 250, 0.45);
}

.insight-page .btn--ghost:hover {
    border-color: var(--color-accent);
}

/* ----- Catalog line archive + single product ----- */

.catalog-page {
    padding-bottom: 4rem;
}

.catalog-hero {
    padding: 2rem 0 2.5rem;
    background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
    border-bottom: 1px solid #e2e8f0;
}

.catalog-hero__inner {
    max-width: 960px;
}

.catalog-breadcrumb {
    font-size: 0.85rem;
    color: var(--color-muted, #64748b);
    margin-bottom: 1.25rem;
}

.catalog-breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.catalog-breadcrumb a:hover {
    color: var(--color-accent, #b8860b);
}

.catalog-breadcrumb__sep {
    margin: 0 0.4rem;
    opacity: 0.6;
}

.catalog-breadcrumb--compact {
    margin-bottom: 1rem;
}

.catalog-hero__title {
    font-size: clamp(1.75rem, 4vw, 2.35rem);
    margin: 0 0 1rem;
    color: #0f172a;
    line-height: 1.15;
}

.catalog-hero__lead {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.65;
    color: #475569;
    max-width: 48rem;
}

.catalog-hero__desc {
    font-size: 1.05rem;
    line-height: 1.65;
    color: #334155;
    max-width: 48rem;
}

.catalog-hero__desc p {
    margin: 0 0 0.75rem;
}

.catalog-hero__desc p:last-child {
    margin-bottom: 0;
}

.catalog-search-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.35rem;
    max-width: 42rem;
}

.catalog-search-form__input {
    flex: 1 1 16rem;
    min-width: 0;
    height: 3rem;
    padding: 0 0.95rem;
    font: inherit;
    color: #0f172a;
    border: 1px solid #d8d2c2;
    border-radius: 8px;
    background: #fff;
    outline: none;
}

.catalog-search-form__input:focus {
    border-color: var(--color-accent-mid);
    box-shadow: 0 0 0 3px rgba(184, 149, 74, 0.16);
}

.catalog-search-form__button {
    min-height: 3rem;
    padding: 0 1.4rem;
    color: #fff;
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    border: 0;
    border-radius: var(--radius-pill);
    background: #0d0d0d;
    cursor: pointer;
}

.catalog-search-form__button:hover {
    background: var(--color-accent-mid);
}

.catalog-page__body {
    padding-top: 2rem;
}

.catalog-grid {
    list-style: none;
    margin: 0 0 2rem;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(1.15rem, 2vw, 1.65rem);
}

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

@media (max-width: 900px) {
    .catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 520px) {
    .catalog-grid {
        grid-template-columns: 1fr;
    }
}

.catalog-grid__cell {
    margin: 0;
}

.catalog-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: clamp(22rem, 31vw, 29.5rem);
    padding: clamp(1rem, 2vw, 1.25rem);
    text-decoration: none;
    color: inherit;
    border: 0;
    border-radius: 0;
    overflow: hidden;
    background: #f7f7f9;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.catalog-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.catalog-card__media {
    position: relative;
    aspect-ratio: 1 / 1;
    flex: 1 1 auto;
    min-height: 0;
    background: transparent;
    display: block;
    overflow: hidden;
}

.catalog-card__img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.catalog-card__placeholder {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 100%;
    background: transparent;
}

.catalog-card__placeholder-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.catalog-card__placeholder--empty {
    min-height: 100%;
    background: linear-gradient(145deg, #f0f0f2 0%, #fafafa 100%);
}

.catalog-card__title {
    display: block;
    margin-top: clamp(1rem, 2vw, 1.4rem);
    padding-top: clamp(1rem, 2vw, 1.35rem);
    border-top: 1px dashed #e7d4b3;
    font-size: clamp(0.92rem, 1.2vw, 1rem);
    font-weight: 700;
    color: #111827;
    line-height: 1.45;
    word-break: normal;
    overflow-wrap: anywhere;
}

.catalog-card__meta {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.76rem;
    color: #64748b;
    line-height: 1.35;
}

.catalog-empty {
    margin: 2rem 0;
    padding: 1.5rem;
    border: 1px dashed #cbd5e1;
    border-radius: 12px;
    color: #64748b;
    text-align: center;
}

.catalog-pagination {
    margin-bottom: 3rem;
}

.catalog-pagination .nav-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.5rem 0.75rem;
}

.catalog-pagination a,
.catalog-pagination span {
    display: inline-block;
    min-width: 2.25rem;
    padding: 0.45rem 0.65rem;
    text-align: center;
    border-radius: 8px;
    font-size: 0.9rem;
    text-decoration: none;
    border: 1px solid #e2e8f0;
    color: #334155;
    background: #fff;
}

.catalog-pagination a:hover {
    border-color: var(--color-accent, #b8860b);
    color: var(--color-accent, #b8860b);
}

.catalog-pagination span.current {
    background: #0f172a;
    color: #fff;
    border-color: #0f172a;
}

.catalog-pagination span.dots {
    border: none;
    background: transparent;
}

.catalog-cta {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 1.5rem;
    align-items: start;
    padding: 1.75rem 1.5rem;
    margin-bottom: 2.5rem;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 6px 20px rgba(15, 23, 42, 0.05);
}

@media (max-width: 820px) {
    .catalog-cta {
        grid-template-columns: 1fr;
    }
}

.catalog-cta__title {
    font-size: 1.25rem;
    margin: 0 0 0.5rem;
    color: #0f172a;
}

.catalog-cta__lead {
    margin: 0;
    color: #475569;
    font-size: 0.95rem;
    line-height: 1.55;
}

.catalog-cta__form :where(input[type="text"], input[type="email"], input[type="tel"], textarea, select) {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.catalog-cta__empty {
    margin: 0;
    color: var(--color-muted, #64748b);
    font-size: 0.95rem;
}

.catalog-trust {
    margin-top: 0.5rem;
}

.single-product {
    background: #fff;
}

.single-product__body {
    padding: clamp(2rem, 4vw, 3rem) 0 clamp(3rem, 6vw, 5rem);
}

.single-product__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(22rem, 0.92fr);
    gap: clamp(2rem, 6vw, 5rem);
    align-items: start;
}

.single-product__gallery {
    min-width: 0;
    padding-top: clamp(1rem, 5vw, 4rem);
}

.single-product__media {
    display: grid;
    place-items: center;
    min-height: clamp(24rem, 48vw, 42rem);
    background: #fff;
}

.single-product__img {
    width: min(78%, 34rem);
    max-height: clamp(21rem, 44vw, 38rem);
    object-fit: contain;
    display: block;
    vertical-align: middle;
    transition: filter 0.18s ease, opacity 0.18s ease;
}

.single-product__img--tone-chrome {
    filter: saturate(0.82) brightness(1.06) contrast(0.96);
}

.single-product__img--tone-nickel {
    filter: sepia(0.1) saturate(0.75) brightness(0.98) contrast(1.02);
}

.single-product__img--tone-black {
    filter: grayscale(0.75) brightness(0.5) contrast(1.42);
}

.single-product__img--tone-gold {
    filter: sepia(0.55) saturate(1.45) brightness(1.08) contrast(1.02);
}

.single-product__img--tone-gunmetal {
    filter: grayscale(0.55) brightness(0.66) contrast(1.25);
}

.single-product__img--tone-rose-gold {
    filter: sepia(0.45) saturate(1.15) hue-rotate(325deg) brightness(1.04);
}

.single-product__ph {
    width: min(78%, 34rem);
    aspect-ratio: 1 / 1;
    background: #f7f7f9;
}

.single-product__ph--empty {
    min-height: 18rem;
    background: linear-gradient(145deg, #e2e8f0 0%, #f8fafc 100%);
}

.single-product__thumbs {
    display: flex;
    justify-content: center;
    gap: clamp(2rem, 7vw, 5.5rem);
    margin-top: clamp(1.5rem, 4vw, 3rem);
}

.single-product__thumb {
    display: grid;
    place-items: center;
    width: 4.4rem;
    height: 4.4rem;
    padding: 0.25rem;
    border: 1px solid transparent;
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.single-product__thumb.is-active {
    border-color: #171717;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.12);
}

.single-product__thumb:hover {
    border-color: rgba(184, 149, 74, 0.75);
    transform: translateY(-1px);
}

.single-product__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.single-product__thumb--tone-gold {
    background: #fff4c7;
}

.single-product__thumb--tone-gold img {
    mix-blend-mode: multiply;
    opacity: 0.78;
}

.single-product__thumb--tone-black,
.single-product__thumb--tone-gunmetal {
    background: #f3f4f6;
}

.single-product__thumb--tone-black img {
    filter: grayscale(0.75) brightness(0.55) contrast(1.35);
}

.single-product__thumb--tone-gunmetal img {
    filter: grayscale(0.55) brightness(0.7) contrast(1.2);
}

.single-product__thumb--tone-rose-gold {
    background: #fff0ea;
}

.single-product__thumb--tone-rose-gold img {
    filter: sepia(0.45) saturate(1.15) hue-rotate(325deg) brightness(1.04);
}

.single-product__panel {
    padding: clamp(1.5rem, 3vw, 2.4rem);
    border: 1px solid #cfcfcf;
    border-radius: 14px;
    background: #fff;
}

.single-product__breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-bottom: 1.6rem;
    color: #4b5563;
    font-size: 0.68rem;
    line-height: 1.5;
}

.single-product__breadcrumb a {
    color: inherit;
    text-decoration: none;
}

.single-product__breadcrumb a:hover {
    color: var(--color-accent-mid);
}

.single-product__rule {
    border-top: 1px dashed #e5cfa8;
    margin-bottom: clamp(1.25rem, 2vw, 1.6rem);
}

.single-product__title {
    margin: 0 0 1.4rem;
    color: #262626;
    font-size: clamp(1.35rem, 2.1vw, 1.75rem);
    line-height: 1.35;
    font-weight: 700;
}

.single-product__intro {
    margin: 0 0 clamp(1.5rem, 2.6vw, 2.15rem);
    color: #5f6673;
    font-size: 0.86rem;
    line-height: 1.85;
}

.single-product__specs {
    margin: 0 0 1.5rem;
}

.single-product__spec-list {
    display: grid;
    gap: 0;
    margin: 0;
}

.single-product__spec-row {
    display: grid;
    grid-template-columns: minmax(8.5rem, 0.42fr) 1fr;
    gap: 1rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid #d7d7d7;
}

.single-product__spec-row:first-child {
    border-top: 0;
}

.single-product__spec-row dt {
    margin: 0;
    color: #3f4652;
    font-size: 0.78rem;
    font-weight: 700;
}

.single-product__spec-row dd {
    margin: 0;
    color: #5f6673;
    font-size: 0.82rem;
    line-height: 1.5;
}

.single-product__finishes {
    margin: 0 0 1.8rem;
}

.single-product__finishes-title {
    margin: 0 0 0.65rem;
    color: #3f4652;
    font-size: 0.78rem;
    font-weight: 700;
}

.single-product__swatches {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 0.45rem;
}

.single-product__swatch {
    width: 1.85rem;
    height: 1.85rem;
    padding: 0;
    border: 1px solid #aeb4bd;
    border-radius: 8px;
    background: var(--swatch-color, #f4f4f2);
    box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.7);
    cursor: pointer;
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.single-product__swatch:hover {
    border-color: #171717;
    transform: translateY(-1px);
}

.single-product__swatch.is-active {
    border-color: #171717;
    box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.7), 0 0 0 2px #fff, 0 0 0 3px #171717;
}

.single-product__finish-text {
    margin: 0;
    color: #5f6673;
    font-size: 0.72rem;
}

.single-product__quote {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    margin: 0 0 1.35rem;
    padding: 0.7rem 1rem;
    color: #171717;
    font-size: 0.76rem;
    font-weight: 700;
    font-family: inherit;
    text-decoration: none;
    border: 0;
    border-radius: var(--radius-pill);
    background: #f4b942;
    transition: background 0.16s ease, transform 0.16s ease;
    cursor: pointer;
}

.single-product__quote:hover {
    color: #171717;
    background: #dfa530;
    transform: translateY(-1px);
}

.single-product__note {
    margin: 0 0 1.25rem;
    padding-bottom: 1.25rem;
    color: #525b68;
    font-size: 0.76rem;
    line-height: 1.7;
    border-bottom: 1px solid #d7d7d7;
}

.single-product__note strong {
    color: #222;
}

.single-product__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.55rem;
    padding-bottom: 0.85rem;
    color: #5f6673;
    font-size: 0.76rem;
    border-bottom: 1px solid #d7d7d7;
}

.single-product__tags span {
    font-weight: 700;
}

.single-product__tags a {
    color: #5f6673;
    text-decoration: none;
}

.single-product__tags a:hover {
    color: var(--color-accent-mid);
}

.has-product-modal-open {
    overflow: hidden;
}

.single-product-quote-modal[hidden] {
    display: none;
}

.single-product-quote-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
    padding: clamp(0.75rem, 3vw, 2rem);
}

.single-product-quote-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.58);
}

.single-product-quote-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 52rem);
    max-height: min(90vh, 58rem);
    overflow: auto;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.28);
}

.single-product-quote-modal__close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    color: #111827;
    font-size: 1.5rem;
    line-height: 1;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    cursor: pointer;
}

.single-product-quote-modal__close:hover {
    color: var(--color-accent-mid);
    border-color: rgba(184, 149, 74, 0.45);
}

@media (max-width: 980px) {
    .single-product__layout {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .single-product__gallery {
        padding-top: 0;
    }

    .single-product__media {
        min-height: clamp(18rem, 70vw, 34rem);
    }
}

@media (max-width: 560px) {
    .single-product__panel {
        padding: 1.15rem;
        border-radius: 10px;
    }

    .single-product__spec-row {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }
}

/* Exhibitions: large image/text cards and photo-backed fair cards. */
#meet-2026 .expo-spotlight {
    --expo-spotlight-image: linear-gradient(135deg, #475569 0%, #94a3b8 100%);
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    grid-template-rows: auto auto auto;
    gap: 0 clamp(1.5rem, 5vw, 4.5rem);
    align-items: stretch;
    max-width: none;
    min-height: clamp(19rem, 36vw, 28rem);
    margin-top: clamp(1.5rem, 3vw, 2rem);
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    position: relative;
}

#meet-2026 .expo-spotlight::before,
#meet-2026 .expo-spotlight::after {
    content: "";
    border-radius: 8px;
    border: 1px solid rgba(224, 221, 212, 0.75);
}

#meet-2026 .expo-spotlight::before {
    grid-column: 1;
    grid-row: 1 / 4;
    background: #eef2ef;
}

#meet-2026 .expo-spotlight::after {
    grid-column: 2;
    grid-row: 1 / 4;
    min-height: clamp(17rem, 34vw, 27rem);
    background-image: var(--expo-spotlight-image);
    background-size: cover;
    background-position: center;
}

#meet-2026 .expo-spotlight > * {
    grid-column: 1;
    position: relative;
    z-index: 1;
    max-width: 100%;
    min-width: 0;
}

#meet-2026 .expo-spotlight__title {
    grid-row: 1;
    align-self: end;
    margin: 0;
    padding: clamp(1.5rem, 4vw, 3rem) clamp(1.35rem, 3vw, 2.5rem) 0;
    font-size: clamp(1.65rem, 3vw, 2.25rem);
}

#meet-2026 .expo-spotlight__text {
    grid-row: auto;
    margin: 0;
    padding: 0 clamp(1.35rem, 3vw, 2.5rem);
}

#meet-2026 .expo-spotlight__title + .expo-spotlight__text {
    padding-top: 1rem;
}

#meet-2026 .expo-spotlight__cta {
    grid-row: 3;
    margin: 0;
    padding: 1.25rem clamp(1.35rem, 3vw, 2.5rem) clamp(1.5rem, 4vw, 3rem);
}

#footprint {
    --info-text-bg: #eef2ef;
    --info-image: linear-gradient(135deg, #475569 0%, #94a3b8 100%);
}

#footprint .section__header::after {
    background-position: center;
}

#footprint .expo-footprint {
    gap: clamp(2.5rem, 5vw, 4rem);
}

#footprint .expo-footprint__region-title {
    border-bottom: 0;
    margin-bottom: 1rem;
    padding-bottom: 0;
    font-family: var(--font-sans);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    color: var(--color-accent-hover);
}

#footprint .expo-footprint__fairs {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr));
    gap: clamp(0.85rem, 2vw, 1.25rem);
}

#footprint .expo-fair {
    --expo-card-image: none;
    position: relative;
    justify-content: center;
    min-height: clamp(22rem, 34vw, 26rem);
    overflow: hidden;
    padding: clamp(1.5rem, 3vw, 2rem);
    border: 0;
    border-radius: 0;
    color: #fff;
    box-shadow: none;
}

#footprint .expo-fair--has-image {
    background-image:
        linear-gradient(90deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.48) 52%, rgba(0, 0, 0, 0.22) 100%),
        var(--expo-card-image);
    background-size: cover;
    background-position: center;
}

#footprint .expo-fair--no-image {
    background: linear-gradient(160deg, #334155 0%, #475569 100%);
}

#footprint .expo-fair::before {
    content: none;
    display: none;
}

#footprint .expo-fair__name {
    margin: 0 0 0.8rem;
    color: #fff;
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 800;
    line-height: 1.15;
}

#footprint .expo-fair__body {
    max-width: 18rem;
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.45;
}

@media (max-width: 900px) {
    #meet-2026 .expo-spotlight {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto auto;
        min-height: 0;
        gap: 0;
    }

    #meet-2026 .expo-spotlight::after {
        grid-column: 1;
        grid-row: 1;
        min-height: clamp(14rem, 58vw, 22rem);
        margin-bottom: 1rem;
    }

    #meet-2026 .expo-spotlight::before {
        grid-column: 1;
        grid-row: 2 / 5;
    }

    #meet-2026 .expo-spotlight > * {
        grid-column: 1;
    }

    #meet-2026 .expo-spotlight__title {
        grid-row: 2;
    }

    #meet-2026 .expo-spotlight__text {
        grid-row: auto;
    }

    #meet-2026 .expo-spotlight__cta {
        grid-row: 4;
    }

    #footprint .expo-fair {
        min-height: 18rem;
    }
}

#meet-2026 .expo-spotlight {
    grid-template-rows: auto;
}

#meet-2026 .expo-spotlight::before,
#meet-2026 .expo-spotlight::after {
    content: none;
    display: none;
}

#meet-2026 .expo-spotlight__copy,
#meet-2026 .expo-spotlight__media {
    position: relative;
    min-width: 0;
    border-radius: 8px;
    border: 1px solid rgba(224, 221, 212, 0.75);
    overflow: hidden;
}

#meet-2026 .expo-spotlight__copy {
    grid-column: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1.5rem, 4vw, 3rem);
    background: #eef2ef;
}

#meet-2026 .expo-spotlight__media {
    grid-column: 2;
    min-height: clamp(17rem, 34vw, 27rem);
}

#meet-2026 .expo-spotlight__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#meet-2026 .expo-spotlight__media-empty {
    width: 100%;
    height: 100%;
    min-height: clamp(17rem, 34vw, 27rem);
    background: linear-gradient(145deg, #cbd5e1 0%, #f1f5f9 100%);
}

#meet-2026 .expo-spotlight__copy .expo-spotlight__title,
#meet-2026 .expo-spotlight__copy .expo-spotlight__text,
#meet-2026 .expo-spotlight__copy .expo-spotlight__cta {
    padding: 0;
}

#meet-2026 .expo-spotlight__copy .expo-spotlight__title {
    margin-bottom: 1rem;
}

#meet-2026 .expo-spotlight__copy .expo-spotlight__text {
    margin-bottom: 0.85rem;
}

#meet-2026 .expo-spotlight__copy .expo-spotlight__cta {
    margin-top: 0.4rem;
}

#footprint .expo-footprint__fairs {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 15rem), 1fr));
}

@media (max-width: 900px) {
    #meet-2026 .expo-spotlight__copy,
    #meet-2026 .expo-spotlight__media {
        grid-column: 1;
    }

    #meet-2026 .expo-spotlight__media {
        grid-row: 1;
        min-height: clamp(14rem, 58vw, 22rem);
        margin-bottom: 1rem;
    }

    #meet-2026 .expo-spotlight__copy {
        grid-row: 2;
    }
}

/* Certifications: large image/text blocks and photo-backed standard cards. */
#certs-regions {
    --info-text-bg: #eef2ef;
    --info-image: url("../images/certifications/certifications-mega-menu.jpg");
}

#certs-regions > .container > .section__header::before {
    grid-column: 1;
}

#certs-regions > .container > .section__header::after {
    grid-column: 2;
    background-position: center;
}

#certs-regions > .container > .section__header > .section__title,
#certs-regions > .container > .section__header > .section__desc {
    grid-column: 1;
}

#certs-regions .certs-region {
    margin-top: clamp(2.25rem, 4vw, 3.5rem);
}

#certs-regions .certs-region__title {
    margin: 0 0 1rem;
    padding: 0;
    border-bottom: 0;
    font-family: var(--font-sans);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: var(--tracking-nav);
    line-height: 1.35;
    text-transform: uppercase;
    color: var(--color-accent-hover);
}

#certs-regions .card-grid--3 {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 15rem), 1fr));
    gap: clamp(0.85rem, 2vw, 1.25rem);
}

.certs-page #certs-regions .certs-card {
    position: relative;
    justify-content: center;
    min-height: clamp(22rem, 34vw, 26rem);
    overflow: hidden;
    padding: clamp(1.5rem, 3vw, 2rem);
    border: 0;
    border-radius: 0;
    color: #fff;
    box-shadow: none;
}

.certs-page #certs-regions .certs-card--has-image {
    background-image:
        linear-gradient(90deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.48) 52%, rgba(0, 0, 0, 0.22) 100%),
        var(--cert-card-image);
    background-size: cover;
    background-position: center;
}

.certs-page #certs-regions .certs-card--no-image {
    background: linear-gradient(160deg, #334155 0%, #475569 100%);
}

.certs-page #certs-regions .certs-card::before {
    content: none;
    display: none;
}

.certs-page #certs-regions .certs-card__title {
    margin: 0 0 0.8rem;
    color: #fff;
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 800;
    line-height: 1.15;
}

.certs-page #certs-regions .certs-card__text {
    max-width: 18rem;
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.45;
}

.certs-feature {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: clamp(1.5rem, 5vw, 4.5rem);
    align-items: stretch;
    min-height: clamp(19rem, 36vw, 28rem);
}

.certs-feature__copy,
.certs-feature__media {
    min-width: 0;
    border: 1px solid rgba(224, 221, 212, 0.75);
    border-radius: 8px;
    overflow: hidden;
}

.certs-feature__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1.5rem, 4vw, 3rem);
    background: #f4f0e7;
}

#certs-trace .certs-feature__copy {
    grid-column: 2;
    grid-row: 1;
    background: #eef2ef;
}

#certs-trace .certs-feature__media {
    grid-column: 1;
    grid-row: 1;
}

.certs-feature__copy .section__title {
    margin: 0 0 1rem;
}

.certs-feature__copy .certs-list {
    margin: 0;
}

.certs-feature__media {
    min-height: clamp(17rem, 34vw, 27rem);
    background: #e9e5dc;
}

.certs-feature__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.certs-feature__media-empty {
    width: 100%;
    height: 100%;
    min-height: clamp(17rem, 34vw, 27rem);
    background: linear-gradient(145deg, #cbd5e1 0%, #f1f5f9 100%);
}

#certs-advantage {
    --info-text-bg: #ebe8e1;
    --info-image: linear-gradient(135deg, #64748b 0%, #94a3b8 100%);
}

#certs-advantage .section__header {
    margin-bottom: clamp(1.5rem, 3vw, 2rem);
}

@media (max-width: 900px) {
    #certs-regions > .container > .section__header::before {
        grid-column: 1 !important;
        grid-row: 2 / 4;
    }

    #certs-regions > .container > .section__header::after {
        grid-column: 1 !important;
        grid-row: 1;
    }

    #certs-regions > .container > .section__header > .section__title {
        grid-row: 2;
    }

    #certs-regions > .container > .section__header > .section__desc {
        grid-row: 3;
    }

    .certs-page #certs-regions .certs-card {
        min-height: 18rem;
    }

    .certs-feature {
        grid-template-columns: 1fr;
        min-height: 0;
        gap: 1rem;
    }

    .certs-feature__copy,
    .certs-feature__media,
    #certs-trace .certs-feature__copy,
    #certs-trace .certs-feature__media {
        grid-column: 1;
    }

    .certs-feature__media,
    #certs-trace .certs-feature__media {
        grid-row: 1;
        min-height: clamp(14rem, 58vw, 22rem);
    }

    .certs-feature__copy,
    #certs-trace .certs-feature__copy {
        grid-row: 2;
    }
}

/* Shared image/text treatment for non-home descriptive blocks. */
.about-page,
.factory-page,
.contact-page,
.catalog-page {
    --subpage-info-bg: #ebe8e1;
    --subpage-info-image: linear-gradient(160deg, #cbd5e1 0%, #f1f5f9 100%);
    overflow-x: hidden;
}

.catalog-page {
    --subpage-info-bg: #eef2ef;
    --subpage-info-image: linear-gradient(145deg, #e2e8f0 0%, #e8e4dc 50%, #f8fafc 100%);
}

#about-story {
    --subpage-info-image: linear-gradient(160deg, #cbd5e1 0%, #f1f5f9 100%);
}

#about-rd,
#oem-partner,
#production-process,
#odm-label {
    --subpage-info-image: linear-gradient(145deg, #94a3b8 0%, #cbd5e1 55%, #e2e8f0 100%);
}

#about-certifications,
#certified,
#lab-tests {
    --subpage-info-image: linear-gradient(135deg, #64748b 0%, #94a3b8 100%);
}

#about-exhibitions,
#testimonials {
    --subpage-info-image: linear-gradient(135deg, #475569 0%, #94a3b8 100%);
}

.about-page__body > .about-section:nth-of-type(3n + 1),
.factory-ref__section:nth-of-type(3n + 1) {
    --subpage-info-bg: #ebe8e1;
}

.about-page__body > .about-section:nth-of-type(3n + 2),
.factory-ref__section:nth-of-type(3n + 2) {
    --subpage-info-bg: #f4f0e7;
}

.about-page__body > .about-section:nth-of-type(3n),
.factory-ref__section:nth-of-type(3n) {
    --subpage-info-bg: #eef2ef;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions),
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow,
.contact-page__header,
.catalog-hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    grid-template-rows: auto auto auto;
    gap: 0 clamp(1.5rem, 5vw, 4.5rem);
    align-items: stretch;
    max-width: none;
    min-height: clamp(19rem, 36vw, 28rem);
    min-width: 0;
    position: relative;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) {
    margin: 0 0 clamp(2.5rem, 5vw, 4rem);
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
}

.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow {
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.contact-page__inner {
    max-width: var(--container);
}

.contact-page__header {
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.about-hero .btn--ghost {
    color: #0f172a;
    border-color: rgba(184, 149, 74, 0.45);
    background: rgba(255, 255, 255, 0.55);
}

.about-hero .btn--ghost:hover {
    color: var(--color-accent-hover);
    border-color: var(--color-accent);
}

.catalog-hero__inner {
    grid-template-rows: auto auto auto auto;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::before,
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::before,
.contact-page__header::before,
.catalog-hero__inner::before {
    content: "";
    grid-column: 1;
    grid-row: 1 / 4;
    border-radius: 8px;
    background: var(--subpage-info-bg);
    border: 1px solid rgba(224, 221, 212, 0.75);
}

.catalog-hero__inner::before {
    grid-row: 2 / 5;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::after,
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::after,
.contact-page__header::after,
.catalog-hero__inner::after {
    content: "";
    grid-column: 2;
    grid-row: 1 / 4;
    border-radius: 8px;
    background-image: var(--subpage-info-image);
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(224, 221, 212, 0.8);
    min-height: clamp(17rem, 34vw, 27rem);
}

.catalog-hero__inner::after {
    grid-row: 2 / 5;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > .about-section__title,
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > .factory-ref__h2,
.contact-page__header > .contact-page__title,
.catalog-hero__inner > .catalog-hero__title {
    grid-column: 1;
    grid-row: 1;
    align-self: end;
    position: relative;
    z-index: 1;
    margin: 0;
    padding: clamp(1.5rem, 4vw, 3rem) clamp(1.35rem, 3vw, 2.5rem) 0;
    text-align: left;
}

.catalog-hero__inner > .catalog-hero__title {
    grid-row: 2;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > :is(.about-prose, .about-section__lead),
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > .factory-ref__p,
.contact-page__header > .contact-page__lead,
.catalog-hero__inner > :is(.catalog-hero__lead, .catalog-hero__desc) {
    grid-column: 1;
    grid-row: 2;
    position: relative;
    z-index: 1;
    max-width: none;
    margin: 0;
    padding: 1rem clamp(1.35rem, 3vw, 2.5rem) 0;
    color: var(--color-muted);
    text-align: left;
}

.catalog-hero__inner > :is(.catalog-hero__lead, .catalog-hero__desc) {
    grid-row: 3;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > :is(.about-bullets, .about-cert-list),
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > :is(.factory-ref__center-btns, .factory-ref__inline-cta),
.contact-page__header > .contact-page__note,
.catalog-hero__inner > .catalog-subnav {
    grid-column: 1;
    grid-row: 3;
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 1rem clamp(1.35rem, 3vw, 2.5rem) clamp(1.5rem, 4vw, 3rem);
    text-align: left;
}

.catalog-hero__inner > .catalog-subnav {
    grid-row: 4;
}

.catalog-hero__inner > .catalog-breadcrumb {
    grid-column: 1 / -1;
    grid-row: 1;
}

.about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > *,
.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > *,
.contact-page__header > *,
.catalog-hero__inner > * {
    box-sizing: border-box;
    max-width: 100%;
    min-width: 0;
    overflow-wrap: break-word;
}

.about-hero__actions .btn {
    max-width: 100%;
    white-space: normal;
    text-align: center;
}

.about-page__body > .about-section:nth-of-type(even):is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::before,
.factory-ref__section:nth-of-type(even):not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::before {
    grid-column: 2;
}

.about-page__body > .about-section:nth-of-type(even):is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::after,
.factory-ref__section:nth-of-type(even):not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::after {
    grid-column: 1;
}

.about-page__body > .about-section:nth-of-type(even):is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > *,
.factory-ref__section:nth-of-type(even):not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > * {
    grid-column: 2;
}

.factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > .factory-ref__p--center {
    text-align: left;
}

@media (max-width: 900px) {
    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions),
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow,
    .contact-page__header,
    .catalog-hero__inner {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto auto;
        min-height: 0;
        gap: 0;
    }

    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::before,
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::before,
    .contact-page__header::before,
    .catalog-hero__inner::before {
        grid-column: 1 !important;
        grid-row: 2 / 5;
    }

    .catalog-hero__inner::before {
        grid-row: 3 / 6;
    }

    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions)::after,
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow::after,
    .contact-page__header::after,
    .catalog-hero__inner::after {
        grid-column: 1 !important;
        grid-row: 1;
        min-height: clamp(14rem, 58vw, 22rem);
        margin-bottom: 1rem;
    }

    .catalog-hero__inner::after {
        grid-row: 2;
    }

    .about-page__body > .about-section:nth-of-type(even):is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > *,
    .factory-ref__section:nth-of-type(even):not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > *,
    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > *,
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > *,
    .contact-page__header > *,
    .catalog-hero__inner > * {
        grid-column: 1 !important;
    }

    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > .about-section__title,
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > .factory-ref__h2,
    .contact-page__header > .contact-page__title {
        grid-row: 2;
    }

    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > :is(.about-prose, .about-section__lead),
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > .factory-ref__p,
    .contact-page__header > .contact-page__lead {
        grid-row: 3;
    }

    .about-page__body > .about-section:is(#about-story, #about-rd, #about-certifications, #about-exhibitions) > :is(.about-bullets, .about-cert-list),
    .factory-ref__section:not(.factory-ref__section--dark):not(.factory-ref__section--contact) > .container.factory-ref__narrow > :is(.factory-ref__center-btns, .factory-ref__inline-cta),
    .contact-page__header > .contact-page__note {
        grid-row: 4;
    }

    .catalog-hero__inner > .catalog-breadcrumb {
        grid-row: 1;
    }

    .catalog-hero__inner > .catalog-hero__title {
        grid-row: 3;
    }

    .catalog-hero__inner > :is(.catalog-hero__lead, .catalog-hero__desc) {
        grid-row: 4;
    }

    .catalog-hero__inner > .catalog-subnav {
        grid-row: 5;
    }
}

/* Catalog pages use a compact ecommerce category strip instead of image/text cards. */
.catalog-page .catalog-hero {
    padding: clamp(1.25rem, 2.6vw, 2rem) 0 clamp(1.5rem, 3vw, 2.35rem);
    background: #f8fafc;
}

.catalog-page .catalog-hero__inner {
    display: block;
    max-width: var(--container);
    min-height: 0;
}

.catalog-page .catalog-hero__inner::before,
.catalog-page .catalog-hero__inner::after {
    content: none;
}

.catalog-page .catalog-hero__inner > .catalog-breadcrumb,
.catalog-page .catalog-hero__inner > .catalog-hero__title,
.catalog-page .catalog-hero__inner > :is(.catalog-hero__lead, .catalog-hero__desc),
.catalog-page .catalog-hero__inner > .catalog-subnav {
    margin-inline: 0;
    padding: 0;
    max-width: 54rem;
}

.catalog-page .catalog-hero__title {
    margin-top: clamp(1.1rem, 2vw, 1.4rem);
    margin-bottom: 0.55rem;
}

.catalog-page .catalog-hero__lead,
.catalog-page .catalog-hero__desc {
    font-size: 0.98rem;
    line-height: 1.65;
}

.catalog-subnav {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    width: fit-content;
    max-width: 100%;
    margin-top: clamp(1rem, 2vw, 1.25rem) !important;
    padding: 0.55rem !important;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
}

.catalog-subnav__label {
    flex: 0 0 auto;
    padding: 0 0.25rem 0 0.45rem;
    color: #64748b;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
    white-space: nowrap;
}

.catalog-subnav__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.catalog-subnav__item {
    margin: 0;
}

.catalog-subnav__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.25rem;
    padding: 0.45rem 0.72rem;
    color: #111827;
    text-decoration: none;
    border: 1px solid #e5e7eb;
    border-radius: var(--radius-pill);
    background: #f9fafb;
    transition: color 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}

.catalog-subnav__link:hover {
    color: #7c5f22;
    border-color: rgba(184, 149, 74, 0.45);
    background: #fffaf0;
}

.catalog-subnav__name {
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.2;
}

.catalog-subnav__count {
    color: #64748b;
    font-size: 0.75rem;
    line-height: 1.2;
    white-space: nowrap;
}

@media (max-width: 720px) {
    .catalog-subnav {
        display: block;
        width: 100%;
    }

    .catalog-subnav__label {
        display: block;
        margin: 0 0 0.45rem;
    }
}

/* -------------------------------------------------------------------------- */
/* Theme catalog & quote form                                                 */
/* -------------------------------------------------------------------------- */

.b2b-catalog-quote {
    --b2b-cq-bg: #f1f5f9;
    --b2b-cq-line: #cbd5e1;
    --b2b-cq-text: #0f172a;
    --b2b-cq-muted: #64748b;
    --b2b-cq-btn: #f2b84b;
    --b2b-cq-btn-hover: #e0a73d;
    background: var(--b2b-cq-bg);
    color: var(--b2b-cq-text);
    padding: clamp(1.5rem, 3vw, 2.25rem);
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-sizing: border-box;
}

.b2b-catalog-quote--embed {
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
}

.b2b-catalog-quote--factory-card {
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
}

.b2b-catalog-quote--boxed {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18);
    max-width: 640px;
    margin-inline: auto;
    text-align: left;
}

.b2b-catalog-quote--modal {
    padding: clamp(1.35rem, 3vw, 2rem);
    border: 0;
    border-radius: 16px;
    background: #fff;
}

.b2b-catalog-quote__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1.75rem;
}

.b2b-catalog-quote__title {
    margin: 0 0 0.75rem;
    font-size: clamp(1.35rem, 2.8vw, 1.85rem);
    font-weight: 700;
    color: var(--b2b-cq-text);
    line-height: 1.25;
}

.b2b-catalog-quote__subtitle {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.6;
    color: var(--b2b-cq-muted);
}

.b2b-catalog-quote--compact .b2b-catalog-quote__title {
    font-size: clamp(1.1rem, 2.2vw, 1.35rem);
}

.b2b-catalog-quote--compact .b2b-catalog-quote__subtitle {
    font-size: 0.88rem;
}

.b2b-catalog-quote__product {
    display: grid;
    gap: 0.25rem;
    margin: 0 0 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #f8fafc;
}

.b2b-catalog-quote__product-label {
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.b2b-catalog-quote__product-title {
    color: #0f172a;
    font-size: 0.95rem;
    line-height: 1.35;
}

.b2b-catalog-quote__product-model {
    color: #64748b;
    font-size: 0.82rem;
}

.b2b-catalog-quote__notice {
    margin: 0 0 1rem;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.95rem;
}

.b2b-catalog-quote__notice--success {
    background: #ecfdf5;
    border: 1px solid #6ee7b7;
    color: #065f46;
}

.b2b-catalog-quote__notice--error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
}

.b2b-catalog-quote__form {
    margin: 0;
}

.b2b-catalog-quote__hp {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.b2b-catalog-quote__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem 1.25rem;
}

@media (max-width: 640px) {
    .b2b-catalog-quote__grid {
        grid-template-columns: 1fr;
    }
}

.b2b-catalog-quote__field {
    margin: 0;
}

.b2b-catalog-quote__field--full {
    margin-top: 1rem;
}

.b2b-catalog-quote__label {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
    color: var(--b2b-cq-text);
}

.b2b-catalog-quote__req {
    color: #b45309;
    font-weight: 700;
}

.b2b-catalog-quote__control {
    display: flex;
    align-items: center;
    gap: 0;
    background: #fff;
    border: 1px solid var(--b2b-cq-line);
    border-radius: 8px;
    overflow: hidden;
}

.b2b-catalog-quote__control:focus-within {
    border-color: #94a3b8;
    box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.35);
}

.b2b-catalog-quote__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 2.75rem;
    color: #475569;
    background: #f8fafc;
    border-right: 1px solid var(--b2b-cq-line);
}

.b2b-catalog-quote__svg {
    display: block;
}

.b2b-catalog-quote__input {
    flex: 1 1 auto;
    min-width: 0;
    border: none;
    padding: 0.65rem 0.85rem;
    font: inherit;
    font-size: 0.95rem;
    background: transparent;
    color: var(--b2b-cq-text);
}

.b2b-catalog-quote__input:focus {
    outline: none;
}

.b2b-catalog-quote__textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--b2b-cq-line);
    border-radius: 8px;
    padding: 0.75rem 0.85rem;
    font: inherit;
    font-size: 0.95rem;
    min-height: 8rem;
    resize: vertical;
    background: #fff;
    color: var(--b2b-cq-text);
}

.b2b-catalog-quote__textarea:focus {
    outline: none;
    border-color: #94a3b8;
    box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.35);
}

.b2b-catalog-quote__recaptcha {
    margin-top: 1rem;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.b2b-catalog-quote__recaptcha-note {
    margin: 1rem 0 0;
    font-size: 0.78rem;
    color: var(--b2b-cq-muted);
}

.b2b-catalog-quote__submit-wrap {
    margin-top: 1.25rem;
}

.b2b-catalog-quote__submit {
    display: block;
    width: 100%;
    box-sizing: border-box;
    border: none;
    border-radius: 10px;
    padding: 0.95rem 1.25rem;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #fff;
    background: var(--b2b-cq-btn);
    cursor: pointer;
    transition: background 0.15s ease, transform 0.1s ease;
}

.b2b-catalog-quote__submit:hover {
    background: var(--b2b-cq-btn-hover);
}

.b2b-catalog-quote__submit:active {
    transform: translateY(1px);
}

.b2b-catalog-quote__legal {
    margin: 1.25rem 0 0;
    text-align: center;
}

.b2b-catalog-quote__legal-line {
    margin: 0.35rem 0 0;
    font-size: 0.78rem;
    line-height: 1.5;
    color: var(--b2b-cq-muted);
}

.b2b-catalog-quote__legal-link {
    color: var(--b2b-cq-muted);
    text-decoration: underline;
}

.b2b-catalog-quote__legal-link:hover {
    color: var(--b2b-cq-text);
}

.b2b-catalog-quote__legal-muted {
    color: var(--b2b-cq-muted);
}

.lead-form .b2b-catalog-quote {
    max-width: 48rem;
    margin-inline: auto;
}
