/* ═══════════════════════════════════════════════════════════════════
   Xinjibiotech - Pet Products B2B Website Stylesheet
   Brand: ·· (White Base · Blue Focus · Orange Accent)
   Font: Inter + Outfit
   ═══════════════════════════════════════════════════════════════════ */

/* ── CSS Variables ───────────────────────────────────────────────── */
:root {
    --primary-dark:    #003d80;
    --primary-color:   #004a99;
    --primary-light:   #3391ff;
    --secondary-color: #1a8be8;
    --accent-color:    #ff9800;
    --accent-dark:     #e68900;
    --bg-white:        #ffffff;
    --bg-light:        #f5f9ff;
    --bg-section:      #f8fbff;
    --blue-soft:       #eaf4ff;
    --text-dark:       #2f3b4f;
    --text-body:       #334155;
    --text-light:      #64748b;
    --border-color:    #e2e8f0;
    --shadow-sm:       0 1px 4px rgba(13,71,161,.05);
    --shadow-md:       0 8px 24px rgba(13,71,161,.10);
    --shadow-lg:       0 20px 48px rgba(13,71,161,.14);
    --radius-sm:       8px;
    --radius-md:       14px;
    --radius-lg:       22px;
    --container-max:   1280px;
    --header-h:        72px;
}

/* ── Reset ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; overflow-x: hidden; }
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--text-body);
    background: var(--bg-white);
    max-width: 100vw;
    line-height: 1.65;
}
body.menu-open { overflow: hidden; }
body.modal-open { overflow: hidden; }

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

/* ── Container ───────────────────────────────────────────────────── */
.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 24px;
}

/* ── Typography ──────────────────────────────────────────────────── */
h1,h2,h3,h4,h5 {
    font-family: 'Outfit', 'Inter', sans-serif;
    color: var(--text-dark);
    line-height: 1.2;
}
h1 { font-size: clamp(30px, 4.5vw, 50px); font-weight: 800; }
h2 { font-size: clamp(26px, 3.5vw, 40px); font-weight: 700; }
h3 { font-size: clamp(20px, 2.5vw, 26px); font-weight: 600; }
h4 { font-size: 17px; font-weight: 600; }
p { color: var(--text-body); }
.text-center { text-align: center; }
.mt-40 { margin-top: 40px; }

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 28px;
    background: var(--accent-color);
    color: #fff;
    font-weight: 600;
    font-size: 15px;
    border-radius: var(--radius-sm);
    border: 2px solid var(--accent-color);
    transition: background .22s, color .22s, border-color .22s, transform .15s, box-shadow .22s;
    text-decoration: none;
    white-space: nowrap;
}
.btn:hover {
    background: var(--accent-dark);
    border-color: var(--accent-dark);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(245,166,35,.35);
}
.btn-primary {
    background: var(--primary-color);
    border-color: var(--primary-color);
}
.btn-primary:hover { background: var(--primary-light); border-color: var(--primary-light); box-shadow: 0 6px 20px rgba(0,86,179,.3); }
.btn:active {
    transform: scale(0.96);
}

.btn-secondary {
    background: transparent;
    color: var(--primary-color);
    border: 2px solid var(--primary-color);
}
.btn-secondary:hover { background: var(--primary-color); color: #fff; }
.btn-full { width: 100%; justify-content: center; }
.btn-outline-white {
    background: transparent;
    color: var(--primary-dark);
    border: 2px solid rgba(0,58,122,.35);
}
.btn-outline-white:hover { background: var(--bg-light); border-color: var(--primary-color); transform: translateY(-2px); }
.btn-outline-sm {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 600;
    color: var(--primary-color);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-sm);
    transition: all .2s;
}
.btn-outline-sm:hover { border-color: var(--primary-color); background: var(--bg-light); }
.btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    background: #fff;
    color: var(--primary-dark);
    border: 2px solid rgba(0,74,153,.28);
    border-radius: var(--radius-sm);
    font-weight: 700;
    text-decoration: none;
    transition: background .22s, color .22s, border-color .22s, transform .15s, box-shadow .22s;
}
.btn-outline:hover {
    background: var(--primary-color);
    color: #fff;
    border-color: var(--primary-color);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(0,86,179,.18);
}

/* ── Site Header ─────────────────────────────────────────────────── */
.site-header {
    position: relative;
    top: auto;
    z-index: 900;
    background: rgba(255,255,255,.97);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border-color);
    height: var(--header-h);
    display: flex;
    align-items: center;
    transition: box-shadow .25s;
}
.site-header.scrolled { box-shadow: var(--shadow-md); }

.header-inner {
    display: flex;
    align-items: center;
    gap: 32px;
    height: 100%;
}

/* Logo */
.logo a {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 22px;
    color: var(--primary-color);
    text-decoration: none;
    white-space: nowrap;
}
.logo-icon { font-size: 26px; line-height: 1; }
.logo-text { color: var(--primary-color); }

/* Main Nav */
.main-nav { margin-left: auto; }
.main-nav ul { display: flex; align-items: center; gap: 4px; }
.main-nav ul > li > a {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 13px;
    font-size: 14.5px;
    font-weight: 500;
    color: var(--text-dark);
    border-radius: var(--radius-sm);
    transition: color .2s, background .2s;
    white-space: nowrap;
}
.main-nav ul > li > a:hover { color: var(--primary-color); background: var(--bg-light); }

.nav-arrow {
    display: inline-block;
    width: 16px;
    height: 16px;
    line-height: 1;
    font-size: 10px;
    color: var(--text-light);
    transition: transform .22s, color .2s;
    flex-shrink: 0;
    margin-left: 1px;
}
.has-dropdown:hover > a .nav-arrow,
.has-dropdown.open > a .nav-arrow {
    transform: rotate(180deg);
    color: var(--primary-color);
}

/* Dropdown */
.has-dropdown { position: relative; }
.dropdown {
    display: none;
    position: absolute;
    left: 0;
    z-index: 800;
    min-width: 220px;
}
.dropdown-inner {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: 10px 0;
}

@media (min-width: 1181px) {
    .has-dropdown:hover > .dropdown { display: block; }
    .has-dropdown:hover > .mega-menu { display: grid; }
}

.dropdown-inner ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.dropdown-inner li { display: block; }
.dropdown-inner li a,
.dropdown li a {
    display: block;
    padding: 10px 22px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-dark);
    white-space: nowrap;
    transition: background .15s, color .15s;
}
.dropdown-inner li a:hover,
.dropdown li a:hover { background: var(--bg-light); color: var(--primary-color); }


/* Mega Menu */
.mega-menu {
    display: none;
    position: absolute;
    top: 100%;
    padding-top: 8px;
    background: transparent;
    z-index: 800;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}
.mega-menu-inner {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: 24px 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    align-items: start;
}
.mega-col {
    padding: 0 24px;
    border-right: 1px solid var(--border-color);
}
.mega-col:last-child { border-right: none; }
.mega-menu h4 {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.4px;
    color: var(--primary-color);
    margin: 0 0 10px;
    padding: 0 0 8px;
    border-bottom: 1px solid var(--border-color);
}
.mega-menu a {
    display: flex;
    align-items: center;
    padding: 8px 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-dark);
    border-radius: 5px;
    transition: background .15s, color .15s;
    line-height: 1.3;
}
.mega-menu a:hover { background: var(--bg-light); color: var(--primary-color); }
.mega-menu-inner ul { display: block; list-style: none; padding: 0; margin: 0; }
.mega-menu-inner ul > li { padding: 0 20px; border-right: 1px solid var(--border-color); }
.mega-menu-inner ul > li:last-child { border-right: none; }

/* Nav CTA */
.btn-nav {
    display: inline-flex;
    align-items: center;
    padding: 9px 22px;
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--radius-sm);
    transition: all .2s;
    white-space: nowrap;
}
.btn-inquiry {
    background: var(--accent-color);
    color: #fff;
    border: 2px solid var(--accent-color);
}
.btn-inquiry:hover { background: var(--accent-dark); border-color: var(--accent-dark); transform: translateY(-1px); }

/* Hamburger */
.menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 6px;
    border-radius: 6px;
    transition: background .2s;
    flex-shrink: 0;
}
.menu-toggle:hover { background: var(--bg-light); }
.menu-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text-dark);
    border-radius: 2px;
    transition: all .25s;
}
.menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle.active span:nth-child(2) { opacity: 0; }
.menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }



/* ── Hero Banner ─────────────────────────────────────────────────── */
.hero-banner {
    position: relative;
    min-height: 520px;
    background: linear-gradient(135deg, #ffffff 0%, #eef5ff 100%);
    display: flex;
    flex-direction: column; 
    justify-content: center;
    overflow: hidden;
    padding: 80px 0 60px;
    color: var(--text-dark);
    border-bottom: 1px solid var(--border-color);
}
@media (max-width: 768px) {
    .hero-banner { padding: 40px 0 40px; min-height: auto; }
}

/* Molecular/Network Background Pattern */
.hero-pattern {
    position: absolute;
    inset: 0;
    opacity: 0.08;
    background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 30L15 15M30 30L45 15M30 30L30 5M30 30L55 35M30 30L5 35' stroke='white' stroke-width='1' fill='none'/%3E%3Ccircle cx='30' cy='30' r='2' fill='white'/%3E%3Ccircle cx='15' cy='15' r='1.5' fill='white'/%3E%3Ccircle cx='45' cy='15' r='1.5' fill='white'/%3E%3Ccircle cx='30' cy='5' r='1.5' fill='white'/%3E%3C/svg%3E");
    background-size: 150px 150px;
    pointer-events: none;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 60px;
    align-items: center;
}

/* Left: Typography */
.hero-kicker {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--accent-color);
    margin-bottom: 20px;
    animation: fadeInUp 0.8s ease-out;
}
.hero-kicker .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--border-color); flex-shrink: 0; }

.hero-title {
    color: var(--primary-dark);
    font-size: clamp(34px, 4vw, 54px);
    line-height: 1.1;
    margin-bottom: 24px;
    font-weight: 850;
    overflow-wrap: break-word;
    word-break: break-word;
    animation: fadeInUp 0.8s ease-out 0.1s both;
}
.hero-title .highlight { color: var(--accent-color); position: relative; }

.hero-desc {
    font-size: 17px;
    line-height: 1.7;
    color: var(--text-body) !important;
    margin-bottom: 36px;
    max-width: 620px;
    animation: fadeInUp 0.8s ease-out 0.2s both;
    text-shadow: none;
}

.hero-btns {
    display: flex;
    gap: 16px;
    margin-bottom: 36px;
    animation: fadeInUp 0.8s ease-out 0.3s both;
}

/* Right: Visual */
.hero-visual-side {
    position: relative;
    animation: fadeInUp 1s ease-out;
}
.visual-frame {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 24px 56px rgba(13,71,161,0.18);
    transform: perspective(1000px) rotateY(-4deg);
    transition: transform 0.5s ease;
}
.visual-frame:hover { transform: perspective(1000px) rotateY(0deg); }
.hero-img { width: 100%; border-radius: var(--radius-lg); }

.visual-glow {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 80%;
    height: 80%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(245,166,35,0.12) 0%, transparent 70%);
    z-index: -1;
    pointer-events: none;
    opacity: 0.6;
}

/* Floating Stats (Glassmorphism) */
.hero-stats-row {
    position: relative;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    z-index: 10;
    width: 100%;
    margin-top: 28px;
}
@media (max-width: 1024px) {
    .hero-stats-row { margin-top: 40px; grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .hero-stats-row { grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 24px; }
}

.glass-stat {
    background: #ffffff;
    border: 1.5px solid var(--border-blue);
    padding: 24px;
    border-radius: var(--radius-md);
    text-align: center;
    color: var(--text-dark);
    box-shadow: var(--shadow-md);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    animation: fadeInUp 0.8s ease-out 0.5s both;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 110px;
}
.glass-stat:hover { 
    transform: translateY(-6px); 
    border-color: var(--accent-color);
    box-shadow: 0 16px 40px rgba(13,71,161,.14);
}
.glass-stat strong {
    display: block;
    font-size: 30px;
    font-weight: 800;
    margin-bottom: 4px;
    color: var(--primary-color);
    font-family: 'Outfit', sans-serif;
    line-height: 1.1;
}
.glass-stat span {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 1px;
    display: block;
}

/* Animations */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

.btn-glow:hover {
    box-shadow: 0 0 20px rgba(245,166,35,0.6);
}

.strip-banner {
    position: relative;
    background-color: var(--primary-dark);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
    color: #fff;
}
.strip-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(13, 71, 161, 0.95) 0%, rgba(25, 118, 210, 0.8) 100%);
    z-index: 1;
}
.strip-banner.has-bg::before {
    background:
        linear-gradient(90deg, rgba(0,45,96,.88) 0%, rgba(0,74,153,.76) 52%, rgba(0,74,153,.58) 100%),
        linear-gradient(135deg, rgba(13,71,161,.58), rgba(25,118,210,.28));
}
.strip-banner-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}
.strip-banner-bg[data-focus="top"] { object-position: center top; }
.strip-banner-bg[data-focus="bottom"] { object-position: center bottom; }
.strip-banner.is-list { padding: 80px 0; }
.strip-banner.is-detail { padding: 60px 0; }

.banner-container { position: relative; z-index: 2; }
.banner-content { max-width: 800px; }

.banner-kicker {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent-color);
    margin-bottom: 16px;
    display: block;
}
.banner-content h1 { 
    color: #fff; 
    margin-bottom: 16px; 
    font-size: clamp(28px, 4vw, 44px); 
    font-weight: 800;
    line-height: 1.2;
}
.banner-desc { 
    color: rgba(255,255,255,0.9); 
    font-size: 17px; 
    max-width: 700px; 
    line-height: 1.6;
}
.banner-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,0.6);
    margin-bottom: 20px;
    white-space: nowrap;
}
.banner-breadcrumb a { color: rgba(255,255,255,0.8); transition: color .2s; }
.banner-breadcrumb a:hover { color: var(--accent-color); }
.banner-breadcrumb .sep { opacity: 0.5; }
.banner-breadcrumb span { color: #fff; font-weight: 500; }

.banner-meta-line { 
    margin-top: 20px; 
    font-size: 14px; 
    display: flex;
    align-items: center;
    gap: 15px;
}

@media (max-width: 768px) {
    .strip-banner.is-list { padding: 60px 0; }
    .strip-banner.is-detail { padding: 40px 0; }
    .banner-content { text-align: left; }
    .banner-desc { font-size: 15px; }
}


/* ── Section Headings ────────────────────────────────────────────── */
.section-heading { text-align: center; margin-bottom: 52px; }
.section-heading h2 { color: var(--text-dark); margin-bottom: 14px; }
.section-heading p { color: var(--text-light); font-size: 17px; max-width: 620px; margin: 0 auto; }
.section-label {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent-color);
    margin-bottom: 10px;
}

.service-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

/* ── Product Grid ────────────────────────────────────────────────── */
.product-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.product-card {
    background: #fff;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    overflow: hidden;
    transition: box-shadow .25s, transform .25s, border-color .25s;
}
.product-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); border-color: var(--border-blue); }

.product-card > a { display: block; overflow: hidden; aspect-ratio: 16/10; background: var(--bg-light); }
.product-card > a img { width: 100%; height: 100%; object-fit: contain; background: #fff; padding: 10px; transition: transform .4s; }
.product-card:hover > a img { transform: scale(1.02); }

.product-placeholder, .blog-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: var(--text-light);
    background: linear-gradient(135deg, #dbeafe, #eff6ff);
}
.product-placeholder svg, .blog-placeholder svg { opacity: .4; }
.product-placeholder span { font-size: 13px; font-weight: 600; color: var(--primary-color); }

.product-card-content { padding: 20px; }
.product-card-content .category-tag {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--primary-color);
    background: var(--blue-soft);
    padding: 2px 8px;
    border-radius: 4px;
    margin-bottom: 10px;
}
.product-card-content h3 { font-size: 16px; font-weight: 600; margin-bottom: 8px; line-height: 1.4; }
.product-card-content .meta { font-size: 13px; color: var(--text-light); margin-bottom: 14px; }
.product-card-actions { display: flex; gap: 10px; align-items: center; }

/* ── Features Grid ───────────────────────────────────────────────── */
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 28px;
    margin-top: 16px;
}
.feature-item {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 32px 24px;
    text-align: center;
    transition: box-shadow .25s, transform .25s, border-color .25s;
}
.feature-item:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); border-color: var(--border-blue); }
.feature-icon { font-size: 40px; margin-bottom: 16px; }
.feature-item h3 { font-size: 17px; color: var(--primary-color); margin-bottom: 10px; }
.feature-item p { font-size: 14px; color: var(--text-light); line-height: 1.65; }

/* ── Blog Grid ───────────────────────────────────────────────────── */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.blog-card {
    background: #fff;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    overflow: hidden;
    transition: box-shadow .25s, transform .25s;
}
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.blog-card > a { display: block; overflow: hidden; aspect-ratio: 16/10; background: var(--bg-light); position: relative; }
.blog-card > a img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.blog-card:hover > a img { transform: scale(1.04); }
.blog-card.is-video-portrait > a {
    background: linear-gradient(135deg, #eef5fb, #f8fafc);
}
.blog-card.is-video-portrait > a img {
    object-fit: contain;
    padding: 10px;
}
.blog-card.is-video-portrait:hover > a img { transform: none; }
.blog-video-badge {
    position: absolute;
    left: 12px;
    bottom: 12px;
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(15, 23, 42, .82);
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .02em;
    text-transform: uppercase;
    pointer-events: none;
}
.blog-card-content { padding: 20px; }
.blog-card-content .meta { font-size: 12px; color: var(--text-light); margin-bottom: 10px; }
.blog-card-content h3 { font-size: 16px; font-weight: 600; margin-bottom: 8px; line-height: 1.45; }
.blog-card-content h3 a:hover { color: var(--primary-color); }
.blog-card-content p { font-size: 14px; color: var(--text-light); }

/* ── Blog List Layout (blog.php) ─────────────────────────────────── */
.blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.blog-list-item {
    display: flex;
    gap: 24px;
    padding: 24px 0;
    border-bottom: 1px solid var(--border-color);
}
.blog-list-item:last-child { border-bottom: none; }
.blog-list-thumb {
    flex-shrink: 0;
    width: 200px;
    height: 126px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--bg-light);
    position: relative;
}
.blog-list-thumb img { width: 100%; height: 100%; object-fit: cover; }
.blog-list-item.is-video-portrait .blog-list-thumb {
    background: linear-gradient(135deg, #eef5fb, #f8fafc);
}
.blog-list-item.is-video-portrait .blog-list-thumb img {
    object-fit: contain;
    padding: 7px;
}
.blog-list-content h3 { font-size: 18px; margin-bottom: 8px; }
.blog-list-content h3 a:hover { color: var(--primary-color); }
.blog-list-content .meta { font-size: 13px; color: var(--text-light); margin-bottom: 8px; }
.blog-list-content p { font-size: 14.5px; color: var(--text-light); }

/* Blog sidebar */
.blog-sidebar { position: sticky; top: calc(var(--header-h) + 24px); }
.sidebar-card {
    background: var(--bg-light);
    border-radius: var(--radius-md);
    padding: 24px;
    margin-bottom: 24px;
}
.sidebar-card h4 { font-size: 15px; color: var(--primary-color); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid var(--border-color); }
.sidebar-card ul li { padding: 7px 0; border-bottom: 1px solid var(--border-color); font-size: 14px; }
.sidebar-card ul li:last-child { border-bottom: none; }
.sidebar-card ul li a { color: var(--text-dark); }
.sidebar-card ul li a:hover { color: var(--primary-color); }
.tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-cloud a {
    padding: 5px 12px;
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: 100px;
    font-size: 13px;
    color: var(--text-dark);
    transition: all .2s;
}
.tag-cloud a:hover { background: var(--primary-color); color: #fff; border-color: var(--primary-color); }

/* ── Product Detail ──────────────────────────────────────────────── */
.product-detail-layout { display: grid; grid-template-columns: 1fr 440px; gap: 48px; align-items: start; margin-top: 48px; }
.product-images { position: sticky; top: calc(var(--header-h) + 24px); }
.main-image {
    aspect-ratio: 4/3;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--bg-light);
    cursor: pointer;
    border: 1px solid var(--border-color);
}
.main-image img { width: 100%; height: 100%; object-fit: cover; }
.product-images .main-image img {
    object-fit: contain !important;
    transform: scale(1.06);
    transform-origin: center;
}
.thumb-strip { display: flex; gap: 10px; margin-top: 12px; }
.thumb-item {
    flex: 1;
    aspect-ratio: 1;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--bg-light);
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color .2s;
}
.thumb-item.active, .thumb-item:hover { border-color: var(--accent-color); }
.thumb-item img { width: 100%; height: 100%; object-fit: contain; background: #fff; }

.product-info h2 { font-size: clamp(24px, 3vw, 34px); color: var(--primary-dark); margin-bottom: 12px; }
.product-model { font-size: 13px; color: var(--text-light); font-weight: 600; margin-bottom: 16px; }
.product-summary { font-size: 16px; color: var(--text-body); line-height: 1.75; margin-bottom: 24px; }
.product-badges { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 24px; }
.badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 600;
}
.badge-green { background: rgba(26,111,212,.10); color: var(--primary-color); border: 1px solid rgba(26,111,212,.20); }
.badge-orange { background: rgba(245,166,35,.12); color: var(--accent-dark); border: 1px solid rgba(245,166,35,.25); }

.specs-table { width: 100%; border-collapse: collapse; margin-bottom: 24px; font-size: 14.5px; }
.specs-table tr { border-bottom: 1px solid var(--border-color); }
.specs-table tr:last-child { border-bottom: none; }
.specs-table td { padding: 10px 4px; }
.specs-table td:first-child { color: var(--text-light); font-weight: 500; width: 44%; }
.specs-table td:last-child { color: var(--text-dark); font-weight: 600; }

.inquiry-card {
    background: linear-gradient(135deg, #eff6ff, #f8fbff);
    border: 1.5px solid var(--border-blue);
    border-radius: var(--radius-md);
    padding: 28px;
    margin-bottom: 20px;
}
.inquiry-card h4 { color: var(--primary-dark); font-size: 18px; margin-bottom: 8px; }
.inquiry-card p { color: var(--text-body); font-size: 14px; margin-bottom: 20px; }
.inquiry-card .btn { width: 100%; justify-content: center; font-size: 15px; padding: 13px; }

.features-list { list-style: none; margin-bottom: 24px; }
.features-list li {
    padding: 7px 0;
    padding-left: 22px;
    position: relative;
    font-size: 14.5px;
    color: var(--text-body);
    border-bottom: 1px solid var(--border-color);
}
.features-list li:last-child { border-bottom: none; }
.features-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--primary-color);
    font-weight: 700;
}

/* ── Article Detail ──────────────────────────────────────────────── */
.article-layout { display: grid; grid-template-columns: 1fr 320px; gap: 48px; align-items: start; }
.article-body { font-size: 16.5px; color: var(--text-body); line-height: 1.85; }
.article-body h2 { margin: 36px 0 14px; color: var(--primary-color); font-size: 24px; }
.article-body h3 { margin: 28px 0 12px; color: var(--primary-dark); font-size: 20px; }
.article-body p { margin-bottom: 18px; }
.article-body ul, .article-body ol { margin: 0 0 18px 24px; }
.article-body li { margin-bottom: 8px; }
.article-body strong { color: var(--text-dark); }
.article-body a { color: var(--primary-color); text-decoration: underline; }
.article-body img { border-radius: var(--radius-md); margin: 24px 0; }

.article-meta { display: flex; gap: 20px; flex-wrap: wrap; align-items: center; margin: 20px 0 32px; font-size: 14px; color: var(--text-light); }
.article-meta .author { font-weight: 600; color: var(--text-dark); }
.article-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 36px; }
.article-tag {
    padding: 4px 14px;
    background: var(--bg-light);
    border-radius: 100px;
    font-size: 13px;
    color: var(--text-dark);
    border: 1px solid var(--border-color);
}

/* ── CTA Section ─────────────────────────────────────────────────── */
.cta-section {
    background: linear-gradient(135deg, #1976d2 0%, #42a5f5 100%);
    padding: 60px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.08), transparent 60%);
}
.cta-section .container { position: relative; z-index: 1; }
.cta-section h2 { color: #fff; margin-bottom: 16px; }
.cta-section p { color: rgba(255,255,255,.85); font-size: 18px; margin-bottom: 32px; max-width: 580px; margin-left: auto; margin-right: auto; }

/* ── About Page Sections ─────────────────────────────────────────── */
.two-col-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
@media (max-width: 1180px) {
    .two-col-grid.mobile-img-first > :last-child { order: 2; }
    .two-col-grid.mobile-img-first > :first-child { order: 1; }
    .two-col-grid.mobile-img-first .about-image-wrap,
    .two-col-grid.mobile-img-first .oem-feature-img-box {
        order: -1;
    }
}
.two-col-grid.reverse { direction: rtl; }
.two-col-grid.reverse > * { direction: ltr; }

.about-image-wrap {
    border-radius: var(--radius-lg);
    overflow: hidden;
    aspect-ratio: 4/3;
    background: linear-gradient(135deg, #dbeafe, #eff6ff);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.about-image-wrap img { width: 100%; height: 100%; object-fit: cover; }
.about-image-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    color: var(--secondary-color);
    font-size: 60px;
    opacity: .7;
}
.about-image-placeholder span { font-size: 14px; font-weight: 600; }

/* Quality Standards Grid */
.cert-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.cert-card {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 32px;
    transition: all .3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.cert-card:hover {
    border-color: var(--primary-color);
    box-shadow: var(--shadow-md);
    transform: translateY(-5px);
}
.cert-icon-wrap {
    margin-bottom: 24px;
    height: 64px;
    width: 64px;
    background: var(--bg-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.cert-icon-wrap img {
    max-width: 36px;
    height: auto;
    object-fit: contain;
}
.cert-card h4 {
    font-size: 18px;
    color: var(--primary-dark);
    margin-bottom: 6px;
}
.cert-body-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--accent-color);
    letter-spacing: 1.2px;
    margin-bottom: 12px;
}
.cert-desc {
    font-size: 14.5px;
    line-height: 1.65;
    color: var(--text-body);
}

@media (max-width: 992px) {
    .cert-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .cert-grid { grid-template-columns: 1fr; }
}

/* ── Timeline ────────────────────────────────────────────────────── */
.timeline { position: relative; padding-left: 32px; }
.timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--accent-color), var(--primary-color));
}
.timeline-item { position: relative; margin-bottom: 32px; }
.timeline-item::before {
    content: '';
    position: absolute;
    left: -28px;
    top: 6px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--accent-color);
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px var(--accent-color);
}
.timeline-year { font-weight: 700; color: var(--accent-color); font-size: 14px; margin-bottom: 4px; }
.timeline-item h4 { font-size: 16px; color: var(--primary-dark); margin-bottom: 4px; }
.timeline-item p { font-size: 14px; color: var(--text-light); }

/* ── Contact ─────────────────────────────────────────────────────── */
.contact-layout { display: grid; grid-template-columns: 1fr 400px; gap: 60px; align-items: start; }
.contact-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 32px; }
.contact-info-card {
    background: var(--bg-light);
    border-radius: var(--radius-md);
    padding: 24px;
    text-align: center;
    border: 1px solid var(--border-color);
}
.contact-info-card .icon { font-size: 32px; margin-bottom: 12px; }
.contact-info-card h4 { font-size: 15px; color: var(--primary-color); margin-bottom: 6px; }
.contact-info-card p, .contact-info-card a { font-size: 14px; color: var(--text-body); }
.contact-info-card a:hover { color: var(--primary-color); }

/* Contact Form */
.contact-form-wrap {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    padding: 36px;
    box-shadow: var(--shadow-sm);
}
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-size: 13.5px; font-weight: 600; color: var(--text-dark); margin-bottom: 6px; }
.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 11px 14px;
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-size: 14.5px;
    font-family: inherit;
    color: var(--text-dark);
    background: var(--bg-white);
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(26,74,58,.1);
}
.form-group textarea { resize: vertical; min-height: 120px; }
.form-row { display: grid; gap: 16px; }
.form-row-2 { grid-template-columns: 1fr; gap: 0; }
.required { color: var(--accent-color); }
.feature-icon-box { margin-bottom: 20px; }
.img-icon-small { width: 48px; height: 48px; object-fit: contain; }

/* ── OEM/ODM Page ────────────────────────────────────────────────── */
.oem-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; }
.oem-step {
    text-align: center;
    padding: 28px 20px;
    position: relative;
}
.oem-step::after {
    content: '→';
    position: absolute;
    right: -14px;
    top: 36px;
    font-size: 20px;
    color: var(--border-color);
}
.oem-step:last-child::after { display: none; }
.step-num {
    width: 56px;
    height: 56px;
    background: var(--primary-color);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-weight: 800;
    margin: 0 auto 14px;
    font-family: 'Outfit', sans-serif;
}
.oem-step h4 { font-size: 15px; color: var(--primary-dark); margin-bottom: 6px; }
.oem-step p { font-size: 13px; color: var(--text-light); }

/* ── Applications Page ───────────────────────────────────────────── */
.app-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.app-card {
    position: relative;
    background: linear-gradient(135deg, var(--primary-dark), var(--primary-color));
    border-radius: var(--radius-lg);
    padding: 40px 32px;
    color: #fff;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
}
.app-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.app-card::before {
    content: attr(data-emoji);
    position: absolute;
    right: 20px;
    bottom: 16px;
    font-size: 80px;
    opacity: .12;
    line-height: 1;
}
.app-card h3 { font-size: 22px; margin-bottom: 12px; color: #fff; }
.app-card p { font-size: 14.5px; color: rgba(255,255,255,.8); margin-bottom: 20px; line-height: 1.65; }
.app-card a { color: var(--accent-color); font-weight: 600; font-size: 14px; }
.app-card a:hover { text-decoration: underline; }

/* ── Factory / Quality / Cases Pages ────────────────────────────── */
.content-section { padding: 80px 0; }
.content-section:nth-child(even) { background: var(--bg-light); }

.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.stat-item {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 32px 20px;
    text-align: center;
    box-shadow: var(--shadow-sm);
}
.stat-num { font-size: 40px; font-weight: 800; color: var(--primary-color); font-family: 'Outfit', sans-serif; display: block; }
.stat-label { font-size: 14px; color: var(--text-light); margin-top: 4px; }

/* ── Pagination ──────────────────────────────────────────────────── */
.pager { margin-top: 48px; }
.pager-inner { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.pager-btn, .pager-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    border: 1.5px solid var(--border-color);
    color: var(--text-dark);
    background: #fff;
    transition: all .2s;
    text-decoration: none;
}
.pager-btn:hover, .pager-num:hover { border-color: var(--primary-color); color: var(--primary-color); background: var(--bg-light); }
.pager-num.is-active { background: var(--primary-color); color: #fff; border-color: var(--primary-color); }
.pager-btn.is-disabled { opacity: .35; pointer-events: none; }
.pager-ellipsis { display: inline-flex; align-items: center; color: var(--text-light); padding: 0 8px; }

/* ── FAQ ─────────────────────────────────────────────────────────── */
.faq-list { margin-top: 28px; }
.faq-item {
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    margin-bottom: 12px;
    overflow: hidden;
}
.faq-q {
    padding: 16px 20px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-light);
    transition: background .2s;
    user-select: none;
}
.faq-q:hover { background: #f0f7ff; }
.faq-q::after { content: '+'; font-size: 20px; color: var(--primary-color); flex-shrink: 0; transition: transform .25s; }
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { display: none; padding: 16px 20px; font-size: 14.5px; color: var(--text-body); background: #fff; line-height: 1.72; }
.faq-item.open .faq-a { display: block; }

/* ── Related Products ────────────────────────────────────────────── */
.related-products-section {
    margin-top: 64px;
    padding: 48px;
    border-top: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 10% 10%, rgba(26,111,212,.10), transparent 30%),
        radial-gradient(circle at 90% 15%, rgba(255,152,0,.10), transparent 28%),
        linear-gradient(180deg, #f8fbff 0%, #ffffff 58%);
}
.related-heading { margin-bottom: 28px; max-width: 760px; }
.related-heading h2 { color: var(--primary-color); margin-bottom: 8px; }
.related-heading p { color: var(--text-light); font-size: 16px; }
.related-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; }
.related-card {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 16px 38px rgba(13,71,161,.08);
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.related-card:hover {
    transform: translateY(-4px);
    border-color: var(--border-blue);
    box-shadow: 0 22px 48px rgba(13,71,161,.14);
}
.related-card-media {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 210px;
    padding: 18px;
    background:
        linear-gradient(135deg, rgba(219,234,254,.72), rgba(255,255,255,.96)),
        radial-gradient(circle at 78% 12%, rgba(255,152,0,.16), transparent 28%);
}
.related-card-media img {
    width: 100%;
    height: 180px;
    object-fit: contain;
    padding: 0;
    transform: scale(1.12);
    transform-origin: center;
}
.related-card-fallback {
    display: flex;
    width: 100%;
    height: 180px;
    align-items: center;
    justify-content: center;
    font-size: 44px;
}
.related-card-body { padding: 20px; }
.related-card-body h3 {
    margin: 8px 0 14px;
    font-size: 16px;
    line-height: 1.35;
}
.related-card-body h3 a:hover { color: var(--primary-color); }
.related-card-link {
    display: inline-flex;
    align-items: center;
    color: var(--primary-color);
    font-weight: 800;
    font-size: 14px;
}

/* ── Inquiry Modal ───────────────────────────────────────────────── */
.inquiry-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15,23,42,.4);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .25s;
}
.inquiry-overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
}
.inquiry-modal {
    background: #fff;
    border-radius: var(--radius-lg);
    max-width: 620px;
    width: 100%;
    max-height: 92vh;
    overflow-y: auto;
    padding: 36px;
    position: relative;
    box-shadow: 0 32px 80px rgba(0,0,0,.25);
    transform: translateY(20px);
    transition: transform .3s;
}
.inquiry-overlay.active .inquiry-modal { transform: translateY(0); }
.inquiry-close {
    position: absolute;
    top: 16px;
    right: 20px;
    background: var(--bg-light);
    border: none;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-light);
    transition: all .2s;
}
.inquiry-close:hover { background: var(--accent-color); color: #fff; }
.inquiry-header { margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--border-color); }
.inquiry-header h3 { font-size: 22px; color: var(--primary-dark); margin-bottom: 4px; }
.inquiry-product-name { font-size: 14px; color: var(--secondary-color); font-weight: 500; }
.inquiry-privacy { font-size: 12px; color: var(--text-light); text-align: center; margin-top: 8px; }
.inquiry-modal.success-state {
    overflow: hidden;
}
.inquiry-modal.success-state .inquiry-header {
    display: none;
}
.inquiry-success {
    text-align: center;
    padding: 28px 0;
    min-height: 300px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    outline: none;
}
.inquiry-success[hidden] {
    display: none !important;
}
.inquiry-success h4 {
    color: var(--primary-dark);
    font-size: clamp(24px, 4vw, 34px);
    margin-bottom: 10px;
}
.inquiry-success p {
    color: var(--text-body);
    font-size: 17px;
    line-height: 1.55;
    margin-bottom: 24px;
}
.success-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--secondary-color);
    color: #fff;
    font-size: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

/* ── Site Footer ─────────────────────────────────────────────────── */
.site-footer {
    margin-top: 64px;
    background: var(--bg-light);
    color: var(--text-body);
    border-top: 4px solid var(--primary-color);
}
.footer-cta-wrap { padding: 0 0 28px; }
.footer-cta-inner {
    background: linear-gradient(135deg, #ffffff 0%, #f1f8ff 100%);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
    padding: 48px;
    display: grid;
    grid-template-columns: 1.4fr auto;
    gap: 32px;
    align-items: center;
}
.footer-cta-text h2 { font-size: clamp(22px, 3vw, 38px); color: var(--primary-dark); margin-bottom: 12px; }
.footer-cta-text p { font-size: 16px; color: var(--text-body); }
.footer-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

.footer-main-section { padding: 40px 0 28px; border-top: 1px solid rgba(0,0,0,.04); }
.footer-main-grid {
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr .9fr;
    gap: 36px;
}
.footer-brand.logo a { display: flex; align-items: center; gap: 16px; text-decoration: none; }
.logo-img { height: 38px; width: auto; display: block; filter: grayscale(5%) contrast(1.1); }
.logo-text { font-size: 21px; font-weight: 800; color: var(--primary-color); letter-spacing: -0.2px; font-family: 'Inter', sans-serif; }
.site-header.sticky .logo-text { color: var(--primary-color); }
.footer-tagline { font-size: 13px; color: var(--text-light); margin-bottom: 18px; line-height: 1.6; }
.footer-col h4 { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-dark); margin-bottom: 14px; }
.footer-col ul li { padding: 5px 0; }
.footer-col ul li a { font-size: 14px; color: var(--text-body); transition: color .2s; }
.footer-col ul li a:hover { color: var(--accent-color); }
.contact-info li { font-size: 13.5px; color: var(--text-body); padding: 4px 0; }
.contact-info li strong { color: var(--text-dark); font-weight: 500; margin-right: 4px; }
.contact-info li a { color: var(--text-body); }
.contact-info li a:hover { color: var(--accent-color); }

.footer-social-strip {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 18px 0;
    border-top: 1px solid rgba(0,0,0,.04);
    border-bottom: 1px solid rgba(0,0,0,.04);
    margin-bottom: 20px;
}
.footer-social-strip-title { font-size: 13px; font-weight: 600; color: var(--text-light); text-transform: uppercase; letter-spacing: 1px; }
.footer-social-icons { display: flex; gap: 10px; }
.footer-social-icons a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(0,0,0,.04);
    color: var(--text-body);
    font-size: 14px;
    font-weight: 700;
    transition: all .2s;
}
.footer-social-icons a:hover { background: var(--accent-color); color: #fff; }

.footer-bottom {
    padding: 16px 0 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.footer-bottom p { font-size: 13px; color: var(--text-light); }
.footer-bottom a { color: var(--text-body); }
.footer-bottom a:hover { color: var(--accent-color); }

/* ── Product Placeholder SVG Icons ──────────────────────────────── */
.placeholder-icon {
    width: 120px;
    height: 120px;
    opacity: .55;
}

/* ── Utility ─────────────────────────────────────────────────────── */
.bg-light { background: var(--bg-light); }
.bg-section { background: var(--bg-section); }
.section-pad { padding: 80px 0; }
.section-pad-sm { padding: 56px 0; }
.highlight-text { color: var(--accent-color); }
.green-text { color: var(--primary-color); }

.table-responsive {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    margin-bottom: 1rem;
}
.table-responsive::-webkit-scrollbar { height: 6px; }
.table-responsive::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; }

.mobile-nav-header { display: none; }
.mobile-nav-close {
    display: none;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-dark);
    flex-shrink: 0;
}
.mobile-lang-item, .mobile-inquiry-item { display: none; }
.menu-toggle { display: none; }

/* ── Tablet / Mobile (≤1180px) ────────────────────────────────────── */
@media (max-width: 1180px) {
    .site-header .container { width: 100%; max-width: 100%; padding: 0 16px; }
    .header-inner { 
        display: flex;
        justify-content: space-between; 
        align-items: center;
        width: 100%;
        gap: 0; 
    }
    .logo { margin: 0; flex-shrink: 0; } 
    .menu-toggle { 
        display: flex; 
        order: 10; 
        margin: 0; 
    }

    .nav-cta { display: none; }

    .main-nav {
        display: block; 
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        height: 100vh;
        background: #fff;
        overflow-y: auto;
        overflow-x: hidden;
        padding: 0;
        transform: translateX(100%);
        transition: transform .3s cubic-bezier(.4,0,.2,1);
        z-index: 1000; 
        pointer-events: none;
        opacity: 0;
    }
    .main-nav.active {
        transform: translateX(0);
        pointer-events: all;
        opacity: 1;
        visibility: visible;
    }

    .mobile-nav-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 20px;
        height: var(--header-h);
        border-bottom: 1px solid var(--border-color);
        position: sticky;
        top: 0;
        background: #fff;
        z-index: 2;
    }
    .mobile-nav-logo {
        display: flex;
        align-items: center;
        gap: 8px;
        font-family: 'Outfit', sans-serif;
        font-size: 20px;
        font-weight: 700;
        color: var(--primary-color);
        text-decoration: none;
    }
    .mobile-nav-close { display: flex; }

    .main-nav ul { display: block; padding: 0 0 60px; }
    .main-nav ul > li > a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 15px 24px;
        font-size: 16px;
        font-weight: 500;
        border-radius: 0;
        border-bottom: 1px solid var(--border-color);
        white-space: normal;
    }
    .main-nav ul > li:last-child > a { border-bottom: none; }

    .mega-menu, .dropdown {
        position: static;
        box-shadow: none;
        border: none;
        border-radius: 0;
        background: var(--bg-light);
        padding: 0;
        width: auto;
        min-width: auto;
        display: none;
    }
    .mega-menu-inner, .dropdown-inner {
        display: block !important;
        background: transparent;
        border: none;
        box-shadow: none;
        border-radius: 0;
        padding: 0;
    }
    .mega-col { padding: 0; border-right: none; }
    .has-dropdown.open > .mega-menu,
    .has-dropdown.open > .dropdown { display: block; }
    .mega-menu h4 {
        padding: 10px 40px 6px;
        margin: 0;
        font-size: 10px;
        letter-spacing: 1.2px;
        color: var(--accent-color);
        border-bottom: none;
    }
    .mega-menu a {
        padding: 12px 48px;
        font-size: 15px;
        font-weight: 400;
        border-radius: 0;
        border-bottom: 1px solid var(--border-color);
    }
    .dropdown-inner li a {
        padding: 13px 40px;
        font-size: 15px;
        border-bottom: 1px solid var(--border-color);
    }

    .mega-col:nth-child(3) { display: none; }

    .mega-menu-inner .mega-col { background: transparent; }

    .mobile-lang-item { display: list-item !important; }
    .mobile-lang-switch {
        display: flex;
        gap: 8px;
        padding: 14px 24px;
        border-bottom: 1px solid var(--border-color);
    }
    .mobile-lang-switch a {
        padding: 5px 14px;
        border: 1.5px solid var(--border-color);
        border-radius: 20px;
        font-size: 13px;
        font-weight: 600;
        color: var(--text-dark);
        text-decoration: none;
        transition: all .15s;
    }
    .mobile-lang-switch a.active { background: var(--primary-color); color: #fff; border-color: var(--primary-color); }

    .mobile-inquiry-item { display: list-item !important; padding: 16px 24px; }
    .mobile-inquiry-item a { display: block; text-align: center; }

    .product-grid { grid-template-columns: repeat(2, 1fr); }
    .blog-grid { grid-template-columns: repeat(2, 1fr); }
    .service-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-main-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
    .footer-cta-inner { grid-template-columns: 1fr; gap: 24px; }
    .footer-cta-actions { justify-content: flex-start; }
    .two-col-grid { grid-template-columns: 1fr; gap: 36px; }
    .two-col-grid.reverse { direction: ltr; }
    .product-detail-layout { grid-template-columns: 1fr; }
    .product-images { position: static; }
    .article-layout { grid-template-columns: 1fr; }
    .contact-layout { grid-template-columns: 1fr; }
    .oem-steps { grid-template-columns: 1fr 1fr; }
    .oem-step::after { display: none; }
    .usp-bar .container { grid-template-columns: repeat(2,1fr); }
    .related-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── Tablet (≤1024px) ────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .hero-grid { grid-template-columns: 1fr; gap: 30px; text-align: center; }
    .hero-text-side { display: flex; flex-direction: column; align-items: center; }
    .hero-kicker { justify-content: center; }
    .hero-desc { margin-left: auto; margin-right: auto; text-align: center; }
    .hero-btns { justify-content: center; width: 100%; }
    .hero-visual-side { order: 1; max-width: 340px; margin: 0 auto; opacity: 0.95; }
    .hero-visual-side .hero-img { border-radius: 20px; box-shadow: 0 10px 30px rgba(13,71,161,0.12); }
}

/* ── Mobile (≤768px) ─────────────────────────────────────────────── */
@media (max-width: 768px) {
    .category-tabs-row {
        display: flex !important;
        gap: 10px !important;
        flex-wrap: wrap !important;
        overflow-x: visible !important;
        padding-bottom: 8px;
    }
    .category-tabs-row .btn,
    .category-tabs-row .btn-secondary {
        flex: 0 0 auto;
        white-space: nowrap;
        font-size: 13px !important;
        padding: 8px 14px !important;
    }

    .hero-stats-row { 
        display: grid !important; 
        grid-template-columns: repeat(2, 1fr) !important; 
        gap: 10px !important;
        margin-top: 24px !important;
    }
    .glass-stat { padding: 18px 10px; min-height: 100px; }
    .glass-stat strong { font-size: 20px; }
    .glass-stat span { font-size: 11px; }

    .trust-grid { grid-template-columns: 1fr !important; }
    
    .product-grid { grid-template-columns: 1fr; width: 100%; }
    .product-card { width: 100%; max-width: none; margin: 0; }
    .blog-grid { grid-template-columns: 1fr; }
    .service-grid { grid-template-columns: 1fr; }
    .app-cards { grid-template-columns: 1fr; }
    .cert-grid { grid-template-columns: 1fr 1fr; }
    .stats-row { grid-template-columns: repeat(2, 1fr); }
    .footer-main-grid { grid-template-columns: 1fr; }
    .contact-info-grid { grid-template-columns: 1fr; }
    .form-row-2 { grid-template-columns: 1fr; gap: 0; }
    .form-group { margin-bottom: 20px; }
    .blog-layout { grid-template-columns: 1fr; }
    .blog-list-item { flex-direction: column; }
    .blog-list-thumb { width: 100%; height: 180px; }
    .inquiry-modal { padding: 24px 20px; }
    .footer-cta-inner { padding: 32px 24px; }
    .footer-bottom { flex-direction: column; text-align: center; }
    .section-pad { padding: 48px 0; }
    .two-col-grid { gap: 24px; }
    .oem-steps { grid-template-columns: 1fr; }
    .related-products-section { padding: 34px 22px; margin-left: -4px; margin-right: -4px; }
    .related-grid { grid-template-columns: 1fr; gap: 18px; }
    .related-card-media { min-height: 320px; padding: 24px; }
    .related-card-media img { height: 270px; transform: scale(1.18); }
    .related-card-body { padding: 22px 24px 26px; }
    .related-card-body h3 { font-size: 20px; line-height: 1.28; }
    .related-card-link { font-size: 15px; }

    .hero-grid { text-align: center; }
    .hero-kicker { justify-content: center; text-align: center; }
    .hero-btns { justify-content: center !important; width: 100%; }
    .hero-title { word-break: break-word; overflow-wrap: break-word; }
}

/* ── Production Areas (Factory Tour) ───────────────────────────── */
.production-areas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.production-card {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all .3s ease;
}
.production-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--primary-color);
}
.production-image {
    aspect-ratio: 16/10;
    overflow: hidden;
    background: var(--bg-light);
}
.production-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.production-card:hover .production-image img {
    transform: scale(1.05);
}
.production-info {
    padding: 24px;
}
.production-info h3 {
    font-size: 18px;
    margin-bottom: 10px;
    color: var(--primary-dark);
}
.production-info p {
    font-size: 14px;
    line-height: 1.6;
    color: var(--text-body);
}

.virtual-audit-banner {
    background: linear-gradient(135deg, var(--primary-dark), var(--primary-color));
    padding: 48px;
    border-radius: var(--radius-lg);
    color: #fff;
}
.virtual-audit-banner h3 { color: #fff; font-size: 24px; margin-bottom: 12px; }
.virtual-audit-banner p { color: rgba(255,255,255,.9); margin-bottom: 24px; font-size: 16px; max-width: 600px; margin-left: auto; margin-right: auto; }

@media (max-width: 992px) {
    .production-areas-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .production-areas-grid { grid-template-columns: 1fr; }
    .virtual-audit-banner { padding: 32px 20px; }
}

/* ── QC Process Stages ─────────────────────────────────────────── */
.qc-process-container {
    max-width: 900px;
    margin: 0 auto;
}
.qc-step {
    display: flex;
    gap: 32px;
    margin-bottom: 32px;
    position: relative;
    padding-bottom: 32px;
}
.qc-step::before {
    content: '';
    position: absolute;
    left: 28px;
    top: 56px;
    bottom: 0;
    width: 2px;
    background: var(--border-color);
}
.qc-step:last-child { margin-bottom: 0; padding-bottom: 0; }
.qc-step:last-child::before { display: none; }

.qc-step-num {
    width: 56px;
    height: 56px;
    background: #fff;
    border: 2px solid var(--primary-color);
    color: var(--primary-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-family: 'Outfit', sans-serif;
    flex-shrink: 0;
    z-index: 1;
}
.qc-step-info h4 {
    font-size: 18px;
    margin-bottom: 8px;
    color: var(--primary-dark);
}
.qc-step-info p {
    font-size: 15px;
    line-height: 1.7;
    color: var(--text-body);
}

@media (max-width: 600px) {
    .qc-step { gap: 16px; }
    .qc-step-num { width: 44px; height: 44px; font-size: 14px; }
    .qc-step::before { left: 22px; }
}

/* ── Partner Cases ─────────────────────────────────────────────── */
.case-study-card {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 48px;
    margin-bottom: 32px;
    box-shadow: var(--shadow-sm);
    display: flex;
    gap: 40px;
    align-items: flex-start;
    transition: all .3s ease;
}
.case-study-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px);
}
.case-card-icon {
    width: 80px;
    height: 80px;
    background: var(--bg-light);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid var(--border-blue);
    overflow: hidden;
}
.case-card-icon img {
    max-width: 44px;
    height: auto;
    object-fit: contain;
}
.case-card-content { flex: 1; }
.case-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.case-market { font-size: 13px; color: var(--text-light); }
.case-market strong { color: var(--text-dark); }
.case-result-title {
    font-size: 20px;
    color: var(--primary-dark);
    margin-bottom: 16px;
}
.case-detail-text {
    font-size: 15.5px;
    line-height: 1.8;
    color: var(--text-body);
    margin-bottom: 24px;
}
.case-moq-label {
    font-size: 13px;
    color: var(--text-light);
}
.case-moq-label strong { color: var(--primary-color); }

.cta-mini {
    background: var(--bg-section);
    border: 1px solid var(--border-blue);
    padding: 40px;
    border-radius: var(--radius-lg);
    display: inline-block;
    max-width: 600px;
}

@media (max-width: 800px) {
    .case-study-card {
        flex-direction: column;
        padding: 32px 24px;
        gap: 24px;
    }
}


/* ── Global Animation Utilities ────────────────────────────────── */
.animate-on-scroll {
    opacity: 1;
    transform: none;
    transition: opacity .8s ease-out, transform .8s ease-out;
}

.js-enabled .animate-on-scroll:not(.is-visible) {
    opacity: 0;
    transform: translateY(30px);
}

.animate-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (min-width: 1181px) {
    .main-nav { display: block !important; visibility: visible !important; opacity: 1 !important; }
    .main-nav ul { display: flex !important; opacity: 1 !important; visibility: visible !important; }
    .main-nav ul > li > a { color: #1a1a1a !important; }
}

/* Static QA fixes: ensure simple generated banners sit above the overlay. */
.strip-banner > .container {
    position: relative;
    z-index: 2;
    padding: 64px 24px;
}
.strip-banner > .container h1,
.strip-banner > .container p { color: #fff; }

@media (max-width: 1180px) {
    .header-inner { position: relative; }
    .menu-toggle {
        position: absolute;
        right: 16px;
        top: 50%;
        transform: translateY(-50%);
        z-index: 1101;
        background: rgba(255,255,255,.92);
        border: 1px solid var(--border-color);
        padding: 8px;
    }
    .logo a { padding-right: 52px; }
}
@media (max-width: 1180px) {
    #menuToggle.menu-toggle {
        display: flex !important;
        width: 42px;
        height: 38px;
        align-items: center;
        justify-content: center;
        box-shadow: 0 6px 18px rgba(0,74,153,.14);
    }
    #menuToggle.menu-toggle span { background: #004a99 !important; }
}
@media (max-width: 1180px) {
    body { overflow-x: hidden; }
    #menuToggle.menu-toggle {
        position: fixed !important;
        right: 16px !important;
        top: 16px !important;
        transform: none !important;
    }
}

/* Launch fixes: compact single-column dropdowns, no language switch, no horizontal overflow. */
html, body { max-width: 100%; overflow-x: hidden; }
*, *::before, *::after { box-sizing: border-box; }
img, video, iframe { max-width: 100%; }
.mobile-lang-item { display: none !important; }

@media (min-width: 1181px) {
    .dropdown { left: 0; transform: none; width: max-content; min-width: 260px; max-width: min(360px, calc(100vw - 48px)); }
    .dropdown-inner.dropdown-row { padding: 10px; }
    .dropdown-inner.dropdown-row ul { display: block !important; white-space: normal; }
    .dropdown-inner.dropdown-row li { padding: 0; border: 0; }
    .dropdown-inner.dropdown-row a { display: block; padding: 13px 16px; border-radius: 12px; font-weight: 700; line-height: 1.25; }
}

.category-tabs-row { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:40px; }
.product-img-wrap { width:100%; height:240px; overflow:hidden; border-radius:12px 12px 0 0; position:relative; background:#fff; }
.product-img-wrap img { width:100%; height:100%; object-fit:contain; display:block; padding:10px; transition:transform .4s ease; }
.product-img-fallback { display:flex; width:100%; height:100%; align-items:center; justify-content:center; font-size:52px; background:linear-gradient(135deg,#dbeafe,#eff6ff); }
.product-cat-badge { position:absolute; top:12px; left:12px; background:rgba(26,111,212,.88); color:#fff; font-size:11px; font-weight:700; padding:4px 10px; border-radius:20px; }
.product-card-content .meta { font-size:13px; color:var(--text-light); margin-bottom:14px; }
.category-tag a { color: inherit; text-decoration:none; }
.mobile-stack { min-width: 0; }
.mobile-stack > * { min-width: 0; }
.empty-state { text-align:center; padding:80px 0; color:var(--text-light); }
.empty-state a { color:var(--primary-color); }
.banner-breadcrumb { position:relative; z-index:2; display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:22px; color:rgba(255,255,255,.88); }
.banner-breadcrumb a { color:#fff; text-decoration:none; font-weight:700; }
.banner-breadcrumb span { color:rgba(255,255,255,.86); }
.crumb-sep { opacity:.72; }
.article-tag { display:inline-flex; }
.article-tag a { color:inherit; text-decoration:none; }
.article-body a { color:var(--primary-color); font-weight:700; text-decoration:none; border-bottom:1px solid rgba(0,74,153,.25); }

@media (max-width: 1180px) {
    .dropdown-inner.dropdown-row ul { display:block; }
    .category-tabs-row { gap:10px; margin-bottom:32px; }
    .category-tabs-row .btn, .category-tabs-row .btn-secondary { flex: 0 1 auto; max-width: 100%; }
    .strip-banner > .container { padding: 56px 18px; }
    .strip-banner > .container h1 { font-size: clamp(32px, 10vw, 52px); line-height: 1.15; overflow-wrap: anywhere; }
    .strip-banner > .container p { font-size: 17px; overflow-wrap: anywhere; }
    .product-detail-layout, .article-layout, .blog-layout { grid-template-columns: 1fr !important; }
    .product-info h2, .article-body, .product-summary { overflow-wrap: anywhere; }
    .product-grid, .related-grid { grid-template-columns: 1fr !important; }
    .mobile-stack { display: grid !important; grid-template-columns: 1fr !important; gap: 28px !important; }
    .mobile-stack h3 { font-size: clamp(26px, 8vw, 38px) !important; line-height: 1.18 !important; }
    .mobile-stack p { font-size: 16px !important; line-height: 1.75 !important; }
    .mobile-stack .btn { width: 100%; justify-content: center; }
    .mobile-stack img { width: 100%; height: auto; }
}
.hp-field { display: none !important; }
.contact-success { text-align: center; padding: 40px 20px; }
.img-cover { width: 100%; height: 100%; object-fit: cover; display: block; }
.rounded-sm { border-radius: 10px; }
#backToTop { position: fixed; bottom: 28px; right: 28px; z-index: 999; width: 44px; height: 44px; border-radius: 50%; background: var(--primary-color); color: #fff; font-size: 18px; border: 0; cursor: pointer; opacity: 0; pointer-events: none; transition: opacity .3s; box-shadow: 0 4px 16px rgba(0,0,0,.2); font-weight: 700; }
#backToTop.is-visible { opacity: 1; pointer-events: auto; }
.product-card h3 a, .blog-card h3 a { color: inherit; text-decoration: none; }
.product-card h3 a:hover, .blog-card h3 a:hover { color: var(--primary-color); }
.product-conversion-badges { position: absolute; left: 12px; bottom: 12px; display: flex; gap: 6px; flex-wrap: wrap; z-index: 2; }
.product-conversion-badges span { background: rgba(0,74,153,.88); color: #fff; border-radius: 999px; padding: 5px 9px; font-size: 11px; font-weight: 700; backdrop-filter: blur(8px); }

/* Stable visual fallbacks */
.js-enabled .animate-on-scroll:not(.is-visible),
.animate-on-scroll,
.animate-on-scroll.is-visible,
.feature-item,
.product-card,
.blog-card,
.stat-item,
.cert-item,
.production-card,
.case-study-card {
    opacity: 1 !important;
    transform: none !important;
    visibility: visible !important;
}
.oem-steps {
    gap: 18px !important;
    align-items: stretch;
}
.oem-step {
    background: #fff;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    min-height: 190px;
    box-shadow: var(--shadow-sm);
}
.oem-step::after { color: #cbd5e1; right: -22px; top: 50%; transform: translateY(-50%); }
.oem-step .step-num,
.step-num {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: #fff !important;
    box-shadow: 0 10px 24px rgba(0, 74, 153, .18);
}
.app-card {
    min-height: 280px;
    background: radial-gradient(circle at 88% 88%, rgba(255,255,255,.14), transparent 34%), linear-gradient(135deg, #003b7a, #0b6fd3) !important;
    box-shadow: 0 18px 45px rgba(0, 74, 153, .16);
}
.app-card > * { position: relative; z-index: 2; }
.app-card h3,
.app-card p { color: #fff !important; }
.app-card a { color: #ff9800 !important; }
.app-card::before { opacity: .22 !important; filter: none !important; }
.product-placeholder, .blog-placeholder {
    background: linear-gradient(135deg, #e6f2ff 0%, #b8d7f4 58%, #fff 58%) !important;
    color: #0b3d78 !important;
}
.product-placeholder svg, .blog-placeholder svg { opacity: .85 !important; }
.cta-section,
.footer-cta-inner,
.cta-mini {
    background: linear-gradient(135deg, #004a99, #1a8be8) !important;
    color: #fff !important;
    border: 0 !important;
    box-shadow: 0 20px 60px rgba(0, 74, 153, .18);
}
.cta-section h2,
.cta-section p,
.footer-cta-inner h2,
.footer-cta-inner p,
.cta-mini h3,
.cta-mini p { color: #fff !important; }
.cta-mini .btn, .cta-section .btn { background: var(--accent-color); color: #fff !important; }
@media (max-width: 900px) {
    .oem-steps { grid-template-columns: 1fr !important; }
    .oem-step::after { display: none !important; }
    .app-card { min-height: 220px; }
}
.step-num {
    background-color: #004a99 !important;
    background-image: linear-gradient(135deg, #004a99, #ff9800) !important;
}
.oem-step,
.product-card,
.blog-card,
.case-study-card,
.production-card,
.cert-card {
    background-color: #fff !important;
}

/* Mobile and CTA stability fixes */
html, body { max-width: 100%; overflow-x: clip; }
* { box-sizing: border-box; }
img, video, iframe { max-width: 100%; }
.hero-kicker { flex-wrap: wrap; justify-content: flex-start; max-width: 100%; }
.hero-kicker span { max-width: 100%; }
.hero-btns { flex-wrap: wrap; max-width: 100%; }
.hero-btns .btn { min-width: 210px; }
.category-tabs-row { align-items: stretch; }
.category-tabs-row .btn,
.category-tabs-row .btn-secondary {
    border-radius: 14px !important;
    border: 2px solid var(--primary-color) !important;
    box-shadow: 0 8px 18px rgba(0, 74, 153, .08);
    text-decoration: none !important;
    font-weight: 800 !important;
}
.category-tabs-row .btn-secondary {
    background: #fff !important;
    color: var(--primary-color) !important;
}
.category-tabs-row .btn-secondary:hover,
.category-tabs-row .btn-secondary:focus {
    background: var(--blue-soft) !important;
    color: var(--primary-color) !important;
}
#backToTop {
    background: #004a99 !important;
    color: #fff !important;
    border: 2px solid rgba(255,255,255,.9) !important;
    box-shadow: 0 10px 28px rgba(0, 74, 153, .28) !important;
    line-height: 1 !important;
}
#backToTop.is-visible { opacity: 1 !important; }
.footer-cta-actions .btn,
.cta-section .btn,
.cta-mini .btn {
    min-height: 52px;
    color: #fff !important;
    border-color: rgba(255,255,255,.75) !important;
}
.footer-cta-actions .btn-outline-white,
.cta-section .btn-outline-white,
.cta-mini .btn-outline-white {
    background: rgba(255,255,255,.14) !important;
    color: #fff !important;
}
#contactSubmitBtn,
.contact-form-wrap button[type="submit"],
.inquiry-form button[type="submit"] {
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    width: 100%;
    opacity: 1 !important;
    visibility: visible !important;
    margin-top: 8px;
}
.stats-row,
.hero-stats-row,
.features-grid,
.app-cards,
.product-grid,
.blog-grid,
.related-grid,
.cert-grid { min-width: 0; }
.stat-item,
.glass-stat,
.feature-item,
.app-card,
.product-card,
.blog-card { min-width: 0; }
.stat-num,
.glass-stat strong {
    overflow-wrap: anywhere;
    line-height: 1.05;
}
@media (max-width: 768px) {
    body { overflow-x: hidden; }
    .container { width: 100%; max-width: 100%; padding-left: 24px; padding-right: 24px; }
    .hero-banner { overflow: hidden; }
    .hero-kicker { gap: 8px 12px; justify-content: center; font-size: 10px; letter-spacing: 1.2px; }
    .hero-kicker .dot { display: none; }
    .hero-title { font-size: clamp(34px, 10.5vw, 48px); line-height: 1.1; max-width: 100%; }
    .hero-desc { font-size: 17px; max-width: 100%; }
    .hero-btns { display: grid; grid-template-columns: 1fr; gap: 12px; }
    .hero-btns .btn { width: 100%; min-width: 0; }
    .visual-frame { transform: none !important; }
    .category-tabs-row { display: grid !important; grid-template-columns: 1fr !important; gap: 12px !important; }
    .category-tabs-row .btn,
    .category-tabs-row .btn-secondary { width: 100%; justify-content: center; padding: 13px 16px !important; font-size: 15px !important; }
    .product-img-wrap { height: auto; aspect-ratio: 16 / 10; }
    .product-card > a { aspect-ratio: 16 / 10; }
    .product-images, .blog-sidebar { position: static !important; top: auto !important; }
    .stats-row { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px !important; }
    .stat-item { padding: 28px 12px !important; min-height: 150px; }
    .stat-num { font-size: clamp(32px, 10vw, 44px) !important; }
    .stat-label { font-size: 14px !important; }
    .glass-stat { padding: 18px 8px !important; }
    .glass-stat strong { font-size: clamp(22px, 7vw, 30px) !important; }
    .glass-stat span { font-size: 12px !important; }
    .footer-cta-actions, .cta-section .container, .cta-mini { width: 100%; }
    .footer-cta-actions .btn, .cta-section .btn, .cta-mini .btn { width: 100%; justify-content: center; }
    .contact-layout { grid-template-columns: 1fr !important; gap: 28px !important; }
    .contact-form-wrap { padding: 26px 18px !important; }
    .form-group input, .form-group textarea, .form-group select { font-size: 16px; }
    #backToTop { right: 18px !important; bottom: 18px !important; width: 48px !important; height: 48px !important; }
}
@media (max-width: 430px) {
    .container { padding-left: 18px; padding-right: 18px; }
    .site-header .container { padding-left: 20px; padding-right: 20px; }
    .logo-text { font-size: 24px !important; }
    .logo-img { width: 38px; height: 38px; }
    .hero-title { font-size: clamp(32px, 11vw, 44px); }
    .stats-row { grid-template-columns: 1fr !important; }
    .hero-stats-row { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

/* Final mobile interaction visibility fixes */
.category-tabs-row a.btn,
.category-tabs-row a.btn-secondary,
.category-tabs-row .btn,
.category-tabs-row .btn-secondary {
    border: 2px solid #004a99 !important;
    background-clip: padding-box !important;
}
.category-tabs-row a.btn:not(.btn-secondary) {
    border-color: #ff9800 !important;
}
#backToTop.is-visible,
#backToTop[style] {
    opacity: 1 !important;
    background-color: #004a99 !important;
    background-image: linear-gradient(135deg, #004a99, #0b75d1) !important;
}
@media (max-width: 768px) {
    .category-tabs-row a.btn,
    .category-tabs-row a.btn-secondary,
    .category-tabs-row .btn,
    .category-tabs-row .btn-secondary {
        border-width: 2px !important;
        box-shadow: 0 10px 24px rgba(0, 74, 153, .12) !important;
    }
}
#backToTop { transition: none !important; opacity: 0 !important; }
#backToTop.is-visible { opacity: 1 !important; }

/* Page-specific button fixes */
.cta-section .btn.btn-secondary {
    background: #ff9800 !important;
    color: #fff !important;
    border: 2px solid rgba(255,255,255,.8) !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.12);
}
.cta-section .btn.btn-secondary:hover {
    background: #e28700 !important;
    color: #fff !important;
}
#contactForm .form-group:has(#contactSubmitBtn) {
    display: block !important;
    margin-top: 22px !important;
    margin-bottom: 16px !important;
}
#contactSubmitBtn {
    position: static !important;
    z-index: 2 !important;
    background: #ff9800 !important;
    border: 2px solid #ff9800 !important;
    color: #fff !important;
    border-radius: 12px !important;
}
#contactSubmitBtn .btn-text,
#contactSubmitBtn .btn-loading {
    color: #fff !important;
}
.contact-form-wrap .inquiry-privacy,
.contact-form-wrap form > p {
    margin-top: 14px !important;
}
@media (max-width: 768px) {
    .cta-section .container > div[style*="display:flex"] {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
        width: 100%;
    }
    .cta-section .container > div[style*="display:flex"] .btn {
        width: 100% !important;
        min-height: 56px !important;
    }
    #contactForm .form-group:has(#contactSubmitBtn) {
        margin-top: 24px !important;
    }
    #contactSubmitBtn {
        min-height: 58px !important;
        font-size: 17px !important;
    }
}

/* Inquiry modal submit button fix */
.inquiry-form {
    display: block !important;
    padding-bottom: 8px;
}
.inquiry-form .form-group:has(#inquirySubmitBtn),
#inquirySubmitBtn {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
}
.inquiry-form .form-group:has(#inquirySubmitBtn) {
    margin-top: 22px !important;
    margin-bottom: 12px !important;
    min-height: 58px;
}
#inquirySubmitBtn {
    position: static !important;
    z-index: 5 !important;
    width: 100% !important;
    min-height: 56px !important;
    align-items: center !important;
    justify-content: center !important;
    background: #ff9800 !important;
    background-image: linear-gradient(135deg, #ff9800, #f08a00) !important;
    border: 2px solid #ff9800 !important;
    border-radius: 12px !important;
    color: #fff !important;
    box-shadow: 0 14px 30px rgba(255, 152, 0, .22) !important;
}
#inquirySubmitBtn .btn-text,
#inquirySubmitBtn .btn-loading {
    color: #fff !important;
    font-weight: 800;
}
.inquiry-privacy {
    margin-top: 14px !important;
    position: relative;
    z-index: 1;
}
@media (max-width: 768px) {
    .inquiry-modal { padding: 24px 18px !important; }
    #inquirySubmitBtn { min-height: 58px !important; font-size: 17px !important; }
    .inquiry-modal.success-state {
        max-height: calc(100vh - 28px) !important;
        padding: 22px 18px !important;
    }
    .inquiry-success {
        min-height: min(62vh, 460px);
        padding: 34px 12px 24px;
    }
    .inquiry-success .btn {
        width: 100%;
        max-width: 260px;
        justify-content: center;
    }
}

/* Mobile modal form compact layout */
@media (max-width: 768px) {
  .inquiry-modal {
    max-height: calc(100vh - 18px) !important;
    overflow-y: auto !important;
  }

  .inquiry-header {
    margin-bottom: 14px !important;
    padding-bottom: 10px !important;
  }

  .inquiry-form .form-group {
    margin-bottom: 12px !important;
  }

  .inquiry-form label {
    margin-bottom: 5px !important;
  }

  .inquiry-form input,
  .inquiry-form textarea,
  .inquiry-form select {
    padding: 10px 12px !important;
    font-size: 15px !important;
    border-radius: 10px !important;
  }

  .inquiry-form textarea {
    min-height: 104px !important;
    max-height: 120px !important;
  }

  .inquiry-form .form-group:has(#inquirySubmitBtn) {
    position: sticky !important;
    bottom: -1px !important;
    background: #fff !important;
    padding-top: 10px !important;
    padding-bottom: 8px !important;
    margin-top: 14px !important;
    z-index: 20 !important;
    box-shadow: 0 -8px 18px rgba(255, 255, 255, .92);
  }

  .inquiry-privacy {
    font-size: 12px !important;
    margin-top: 10px !important;
    padding-bottom: 2px;
  }
}

.product-content-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
    margin-top: 32px;
}
.product-content-gallery figure {
    margin: 0;
    border: 1px solid var(--border-color);
    border-radius: 24px;
    background: linear-gradient(135deg, #f8fbff, #ffffff);
    padding: 18px;
    min-height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}
.product-content-gallery img {
    width: 100%;
    max-height: 460px;
    object-fit: contain;
    display: block;
}
@media (max-width: 768px) {
    .product-content-gallery {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    .product-content-gallery figure {
        min-height: 220px;
        padding: 14px;
    }
}

.product-detail-section {
    padding-top: 38px;
}
.product-detail-section .product-detail-layout {
    margin-top: 0;
}
@media (max-width: 768px) {
    .product-detail-section {
        padding-top: 28px;
    }
}

/* Final button/link rendering guard */
a.btn,
button.btn {
    text-decoration: none !important;
    opacity: 1 !important;
    visibility: visible !important;
}
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white) {
    color: #fff !important;
}
a.btn-outline,
button.btn-outline {
    background: #fff !important;
    color: var(--primary-dark) !important;
    border-color: rgba(0,74,153,.28) !important;
}
a.btn-outline:hover,
button.btn-outline:hover,
a.btn-outline:focus-visible,
button.btn-outline:focus-visible {
    background: var(--primary-color) !important;
    color: #fff !important;
    border-color: var(--primary-color) !important;
}
a.btn-secondary,
button.btn-secondary {
    background: #fff !important;
    color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}
a.btn-secondary:hover,
button.btn-secondary:hover,
a.btn-secondary:focus-visible,
button.btn-secondary:focus-visible {
    background: var(--primary-color) !important;
    color: #fff !important;
}
a.btn-outline-white,
button.btn-outline-white {
    color: var(--primary-dark) !important;
    background: rgba(255,255,255,.94) !important;
    border-color: rgba(0,74,153,.32) !important;
}
a.btn-outline-white:hover,
button.btn-outline-white:hover,
a.btn-outline-white:focus-visible,
button.btn-outline-white:focus-visible {
    color: #fff !important;
    background: var(--primary-color) !important;
}
.cta-section a.btn-outline-white,
.footer-cta-actions a.btn-outline-white,
.cta-mini a.btn-outline-white {
    color: #fff !important;
    background: rgba(255,255,255,.16) !important;
    border-color: rgba(255,255,255,.72) !important;
}
.cta-section a.btn-outline-white:hover,
.footer-cta-actions a.btn-outline-white:hover,
.cta-mini a.btn-outline-white:hover {
    color: var(--primary-dark) !important;
    background: #fff !important;
}
.feature-item .btn-secondary,
.app-card .btn-secondary,
.product-card .btn-secondary {
    min-height: 46px;
    color: #fff !important;
    background: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    box-shadow: 0 10px 24px rgba(255,152,0,.18);
}
.feature-item .btn-secondary:hover,
.app-card .btn-secondary:hover,
.product-card .btn-secondary:hover {
    color: #fff !important;
    background: var(--accent-dark) !important;
    border-color: var(--accent-dark) !important;
}
.product-tag-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 4px 0 28px;
}
.product-tag-links-bottom {
    margin: 48px 0 0;
    padding-top: 24px;
    border-top: 1px solid var(--border-color);
}
.product-tag-links-bottom span {
    display: inline-flex;
    align-items: center;
    color: var(--text-light);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-right: 4px;
}
.product-tag-links a {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    background: #f4f8ff;
    border: 1px solid #d7e6f7;
    color: var(--primary-color);
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}
.product-tag-links a:hover {
    background: var(--primary-color);
    color: #fff;
}
.product-topic-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin: 4px 0 28px;
    padding: 18px 20px;
    border: 1px solid var(--border-color);
    border-radius: 18px;
    background: linear-gradient(135deg, #f8fbff, #fff);
}
.product-topic-strip-bottom {
    margin: 44px 0 0;
    padding: 16px 18px;
    background: #fff;
}
.product-topic-intro {
    max-width: 980px;
    margin: 0 0 34px;
    padding: 24px 28px;
    border: 1px solid var(--border-color);
    border-radius: 22px;
    background: linear-gradient(135deg, #f8fbff, #fff);
}
.product-topic-strip span {
    color: var(--text-light);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-right: 4px;
}
.product-topic-strip a {
    display: inline-flex;
    padding: 8px 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #d7e6f7;
    color: var(--primary-color);
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}
.product-topic-strip a:hover {
    background: var(--primary-color);
    color: #fff;
}
.footer-legal-links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-top: 8px;
    font-size: 12px;
}
.footer-legal-links a {
    color: var(--text-light);
    text-decoration: none;
}
.footer-legal-links a:hover {
    color: var(--primary-color);
    text-decoration: underline;
}
.legal-container {
    max-width: 920px;
    text-align: left;
}
.legal-updated {
    color: var(--text-light);
    font-size: 14px;
    margin-bottom: 16px;
}
.legal-intro {
    font-size: 18px;
    line-height: 1.8;
    margin-bottom: 30px;
}
.legal-section {
    border: 1px solid var(--border-color);
    border-radius: 22px;
    background: #fff;
    padding: 28px;
    margin-bottom: 20px;
    box-shadow: 0 16px 42px rgba(15,23,42,.05);
    text-align: left;
}
.legal-section h2 {
    color: var(--primary-color);
    font-size: 24px;
    margin-bottom: 14px;
}
.legal-section ul {
    margin: 0;
    padding-left: 20px;
}
.legal-section li {
    color: var(--text-body);
    line-height: 1.8;
    margin-bottom: 10px;
}
.legal-contact-box {
    background: linear-gradient(135deg, #f4f8ff, #fff8ef);
    border: 1px solid #dbe7f5;
    border-radius: 20px;
    padding: 24px;
    color: var(--text-body);
}

/* Launch QA hardening: compact spacing, stable banners, and visible buttons. */
.section-pad { padding: 64px 0 !important; }
.section-pad-sm { padding: 44px 0 !important; }
.section-heading { margin-bottom: 36px !important; }
.section-heading h2 { margin-bottom: 10px !important; }
.mt-40 { margin-top: 28px !important; }
.mt-60 { margin-top: 36px !important; }
.section-pad + .section-pad { padding-top: 54px !important; }

.strip-banner.is-list { padding: 42px 0 !important; }
.strip-banner.is-detail { padding: 38px 0 !important; }
.strip-banner > .container { padding-top: 0 !important; padding-bottom: 0 !important; }
.strip-banner .banner-breadcrumb { margin-bottom: 14px !important; }
.strip-banner h1 { font-size: clamp(30px, 4vw, 48px) !important; line-height: 1.12 !important; margin-bottom: 10px !important; }
.strip-banner p,
.strip-banner .banner-desc { font-size: 17px !important; line-height: 1.55 !important; max-width: 920px !important; }

.btn,
a.btn,
button.btn,
.btn-nav,
button[type="submit"].btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 46px !important;
    text-decoration: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    white-space: nowrap !important;
    border-style: solid !important;
}
.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
.btn-primary,
a.btn-primary,
button.btn-primary {
    background: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #fff !important;
    box-shadow: 0 12px 28px rgba(255, 152, 0, .18) !important;
}
.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
.btn-primary:hover,
a.btn-primary:hover,
button.btn-primary:hover {
    background: var(--accent-dark) !important;
    border-color: var(--accent-dark) !important;
    color: #fff !important;
    box-shadow: 0 14px 32px rgba(255, 152, 0, .26) !important;
}
.btn-secondary,
a.btn-secondary,
button.btn-secondary,
.btn-outline-white,
a.btn-outline-white,
button.btn-outline-white {
    background: #fff !important;
    border-color: rgba(0, 74, 153, .38) !important;
    color: var(--primary-dark) !important;
    box-shadow: 0 8px 20px rgba(0, 74, 153, .06) !important;
}
.btn-secondary:hover,
a.btn-secondary:hover,
button.btn-secondary:hover,
.btn-secondary:focus-visible,
a.btn-secondary:focus-visible,
button.btn-secondary:focus-visible,
.btn-outline-white:hover,
a.btn-outline-white:hover,
button.btn-outline-white:hover,
.btn-outline-white:focus-visible,
a.btn-outline-white:focus-visible,
button.btn-outline-white:focus-visible {
    background: var(--blue-soft) !important;
    border-color: var(--primary-color) !important;
    color: var(--primary-dark) !important;
    box-shadow: 0 12px 26px rgba(0, 74, 153, .12) !important;
}
.btn-outline,
a.btn-outline,
button.btn-outline,
.btn-outline-sm,
a.btn-outline-sm,
button.btn-outline-sm {
    background: #fff !important;
    border-color: rgba(0, 74, 153, .28) !important;
    color: var(--primary-dark) !important;
}
.btn-outline:hover,
a.btn-outline:hover,
button.btn-outline:hover,
.btn-outline-sm:hover,
a.btn-outline-sm:hover,
button.btn-outline-sm:hover {
    background: var(--blue-soft) !important;
    border-color: var(--primary-color) !important;
    color: var(--primary-dark) !important;
}
.cta-section .btn-outline-white,
.footer-cta-actions .btn-outline-white,
.cta-mini .btn-outline-white {
    background: rgba(255,255,255,.16) !important;
    border-color: rgba(255,255,255,.72) !important;
    color: #fff !important;
}
.cta-section .btn-outline-white:hover,
.footer-cta-actions .btn-outline-white:hover,
.cta-mini .btn-outline-white:hover {
    background: #fff !important;
    color: var(--primary-dark) !important;
}
.feature-item .btn-secondary {
    background: #fff !important;
    color: var(--primary-dark) !important;
    border-color: rgba(0, 74, 153, .22) !important;
    box-shadow: none !important;
}
.feature-item .btn-secondary:hover {
    background: var(--blue-soft) !important;
    color: var(--primary-dark) !important;
    border-color: var(--primary-color) !important;
}
a.btn:empty::after,
button.btn:empty::after { content: 'Learn More'; color: inherit; }

@media (min-width: 901px) {
    .oem-steps {
        display: grid !important;
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 20px !important;
        overflow: visible !important;
    }
    .oem-step {
        min-width: 0 !important;
        min-height: 230px !important;
        padding: 30px 18px 26px !important;
    }
    .oem-step::after {
        right: -18px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        z-index: 2 !important;
    }
    .features-grid .feature-item {
        min-height: 300px !important;
        padding: 34px 22px !important;
    }
}

@media (max-width: 900px) {
    .section-pad { padding: 46px 0 !important; }
    .section-pad-sm { padding: 34px 0 !important; }
    .section-heading { margin-bottom: 28px !important; }
    .strip-banner.is-list { padding: 36px 0 !important; }
    .strip-banner.is-detail { padding: 32px 0 !important; }
    .strip-banner h1 { font-size: clamp(30px, 9vw, 42px) !important; }
    .strip-banner p,
    .strip-banner .banner-desc { font-size: 16px !important; }
    .oem-steps {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
        overflow: visible !important;
    }
    .oem-step {
        min-height: 0 !important;
        padding: 22px 18px !important;
    }
    .oem-step::after { display: none !important; }
    .hero-btns .btn,
    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .footer-cta-actions .btn,
    .cta-section .btn {
        white-space: normal !important;
        width: 100% !important;
    }
}

/* Footer CTA buttons use solid contrast to avoid pale-on-pale hover states. */
.footer-cta-actions .btn-outline-white,
.footer-cta-actions a.btn-outline-white {
    background: #fff !important;
    color: var(--primary-dark) !important;
    border-color: #fff !important;
    box-shadow: 0 12px 26px rgba(0, 0, 0, .12) !important;
}
.footer-cta-actions .btn-outline-white:hover,
.footer-cta-actions a.btn-outline-white:hover {
    background: var(--blue-soft) !important;
    color: var(--primary-dark) !important;
    border-color: #fff !important;
}

/* Keep the closed mobile drawer out of visual and QA flow. */
@media (max-width: 1180px) {
    .main-nav:not(.active) {
        visibility: hidden !important;
    }
    .main-nav.active {
        visibility: visible !important;
    }
}

@media (max-width: 1180px) {
    .main-nav:not(.active) {
        display: none !important;
    }
    .main-nav.active {
        display: block !important;
    }
}

/* Mobile overflow cleanup for header CTA, breadcrumbs, and narrow cards. */
@media (max-width: 1180px) {
    .nav-cta { display: none !important; }
}
@media (max-width: 768px) {
    .banner-breadcrumb {
        white-space: normal !important;
        line-height: 1.5 !important;
    }
    .banner-breadcrumb span,
    .banner-breadcrumb a {
        min-width: 0 !important;
        max-width: 100% !important;
        overflow-wrap: anywhere !important;
        word-break: normal !important;
    }
    .cert-grid,
    .case-grid,
    .production-grid {
        grid-template-columns: 1fr !important;
    }
    .cert-card,
    .case-study-card,
    .production-card {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Page-specific layout polish for launch QA. */
#oem-manufacturing .oem-capability-layout {
    overflow: hidden;
}
#oem-manufacturing .oem-capability-stats {
    align-items: stretch !important;
}
#oem-manufacturing .oem-mini-stat {
    min-height: 0 !important;
    height: auto !important;
    padding: 20px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 18px !important;
}
#oem-manufacturing .oem-mini-stat h3 {
    font-size: 20px !important;
    line-height: 1.2 !important;
    margin: 0 0 8px !important;
}
#oem-manufacturing .oem-mini-stat p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}
#oem-manufacturing .oem-hero-visual {
    max-width: 100%;
}
#oem-manufacturing .oem-hero-badge {
    max-width: calc(100% - 48px);
}

@media (max-width: 991px) {
    #oem-manufacturing .oem-capability-layout {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 28px !important;
        text-align: center !important;
    }
    #oem-manufacturing .oem-capability-stats {
        max-width: 520px;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

@media (max-width: 768px) {
    #oem-manufacturing .oem-capability-stats {
        grid-template-columns: 1fr !important;
    }
    #oem-manufacturing .oem-hero-badge {
        left: 18px !important;
        right: 18px !important;
        bottom: 18px !important;
        max-width: none !important;
    }
    .cert-grid {
        gap: 18px !important;
    }
    .cert-item,
    .trust-card {
        min-height: 0 !important;
        height: auto !important;
        padding: 24px 20px !important;
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }
    .cert-item img,
    .trust-card img {
        margin: 0 auto 14px !important;
    }
    .cert-item h3,
    .cert-item h4,
    .cert-item p,
    .trust-card h3,
    .trust-card h4,
    .trust-card p {
        text-align: center !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .trust-card-link {
        display: block !important;
        width: 100% !important;
    }
}

/* Final launch overrides: keep critical CTA states readable across all templates. */
.hero-btns .btn,
.text-center > .btn,
.product-card-actions .btn,
.product-card-actions .btn-outline-sm,
.category-card .btn,
.feature-item .btn,
.cta-section .btn,
.footer-cta-actions .btn,
.inquiry-card .btn,
.contact-form-wrap .btn,
.inquiry-form .btn {
    opacity: 1 !important;
    visibility: visible !important;
    text-indent: 0 !important;
    background-clip: padding-box !important;
}

.hero-btns .btn:not(.btn-outline-white):not(.btn-secondary):not(.btn-outline),
.text-center > .btn.btn-primary,
.cta-section .btn:not(.btn-outline-white),
.footer-cta-actions .btn:not(.btn-outline-white),
.inquiry-card .btn,
.contact-form-wrap .btn,
.inquiry-form .btn {
    background: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #fff !important;
    box-shadow: 0 12px 28px rgba(255, 152, 0, .18) !important;
}

.hero-btns .btn:not(.btn-outline-white):not(.btn-secondary):not(.btn-outline):hover,
.text-center > .btn.btn-primary:hover,
.cta-section .btn:not(.btn-outline-white):hover,
.footer-cta-actions .btn:not(.btn-outline-white):hover,
.inquiry-card .btn:hover,
.contact-form-wrap .btn:hover,
.inquiry-form .btn:hover {
    background: var(--accent-dark) !important;
    border-color: var(--accent-dark) !important;
    color: #fff !important;
}

.hero-btns .btn-outline-white,
.hero-btns .btn-secondary,
.hero-btns .btn-outline,
.product-card-actions .btn-outline-sm,
.category-card .btn-secondary,
.feature-item .btn-secondary {
    background: #fff !important;
    border-color: rgba(0, 74, 153, .38) !important;
    color: var(--primary-dark) !important;
    box-shadow: 0 8px 20px rgba(0, 74, 153, .06) !important;
}

.hero-btns .btn-outline-white:hover,
.hero-btns .btn-secondary:hover,
.hero-btns .btn-outline:hover,
.hero-btns .btn-outline-white:focus-visible,
.hero-btns .btn-secondary:focus-visible,
.hero-btns .btn-outline:focus-visible,
.product-card-actions .btn-outline-sm:hover,
.category-card .btn-secondary:hover,
.feature-item .btn-secondary:hover {
    background: var(--blue-soft) !important;
    border-color: var(--primary-color) !important;
    color: var(--primary-dark) !important;
}

.cta-section .btn-outline-white,
.footer-cta-actions .btn-outline-white,
.cta-mini .btn-outline-white {
    background: #fff !important;
    border-color: #fff !important;
    color: var(--primary-dark) !important;
}

.cta-section .btn-outline-white:hover,
.footer-cta-actions .btn-outline-white:hover,
.cta-mini .btn-outline-white:hover {
    background: var(--blue-soft) !important;
    border-color: #fff !important;
    color: var(--primary-dark) !important;
}

@media (max-width: 768px) {
    .hero-banner {
        padding: 30px 0 34px !important;
        min-height: 0 !important;
    }
    .hero-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 22px !important;
        align-items: start !important;
    }
    .hero-text-side {
        order: 0 !important;
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
    }
    .hero-kicker {
        margin: 0 auto 14px !important;
        max-width: 100% !important;
        color: var(--accent-color) !important;
    }
    .hero-title {
        margin: 0 auto 18px !important;
        font-size: clamp(31px, 10vw, 42px) !important;
        line-height: 1.12 !important;
        max-width: 100% !important;
    }
    .hero-desc {
        margin: 0 auto 22px !important;
        font-size: 16px !important;
        line-height: 1.62 !important;
        max-width: 100% !important;
    }
    .hero-btns {
        margin: 0 auto 22px !important;
        width: 100% !important;
    }
    .hero-visual-side {
        order: 1 !important;
        max-width: 100% !important;
        width: 100% !important;
        margin: 0 auto !important;
    }
    .hero-visual-side .visual-frame {
        max-width: 420px !important;
        margin: 0 auto !important;
    }
    .hero-stats-row {
        margin-top: 20px !important;
    }
}

@media (max-width: 430px) {
    .hero-banner {
        padding-top: 24px !important;
    }
    .hero-title {
        font-size: clamp(29px, 9.6vw, 38px) !important;
    }
    .hero-desc {
        font-size: 15px !important;
    }
}

/* Warm pet-food launch theme overrides. */
:root {
    --primary-dark: #274936;
    --primary-color: #4f7b55;
    --primary-light: #7fa66b;
    --secondary-color: #8a6a35;
    --accent-color: #f39a20;
    --accent-dark: #d87908;
    --bg-light: #fff8ed;
    --bg-section: #fffaf3;
    --blue-soft: #f7ead2;
    --border-color: #eadfcd;
    --shadow-sm: 0 1px 4px rgba(77, 67, 45, .05);
    --shadow-md: 0 8px 24px rgba(77, 67, 45, .10);
    --shadow-lg: 0 20px 48px rgba(77, 67, 45, .14);
}

.section-pad { padding: 60px 0 !important; }
.section-pad-sm { padding: 44px 0 !important; }
.section-heading { margin-bottom: 34px !important; }

.hero-banner {
    background: radial-gradient(circle at 82% 20%, rgba(243,154,32,.14), transparent 34%), linear-gradient(135deg, #fffaf1 0%, #f7ead2 100%) !important;
}
.strip-banner {
    background: linear-gradient(135deg, #315f45 0%, #6f8f4e 58%, #bd8a32 100%) !important;
}
.strip-banner.is-list { padding: 58px 0 !important; }
.strip-banner.is-detail { padding: 48px 0 !important; }
.strip-banner.has-bg::before { background: linear-gradient(90deg, rgba(20,38,28,.78), rgba(20,38,28,.52)) !important; }
.strip-banner > .container { padding-top: 0 !important; padding-bottom: 0 !important; }

.btn,
button.btn,
a.btn,
.btn-primary,
.hero-btns .btn,
.text-center > .btn,
.cta-section .btn,
.footer-cta-actions .btn,
.inquiry-card .btn,
.contact-form-wrap .btn,
.inquiry-form .btn {
    background: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #fff !important;
    box-shadow: 0 12px 24px rgba(243,154,32,.20) !important;
    opacity: 1 !important;
    visibility: visible !important;
    text-shadow: none !important;
}
.btn:hover,
button.btn:hover,
a.btn:hover,
.btn-primary:hover,
.hero-btns .btn:hover,
.text-center > .btn:hover,
.cta-section .btn:hover,
.footer-cta-actions .btn:hover,
.inquiry-card .btn:hover,
.contact-form-wrap .btn:hover,
.inquiry-form .btn:hover,
.btn:focus-visible,
button.btn:focus-visible,
a.btn:focus-visible {
    background: var(--accent-dark) !important;
    border-color: var(--accent-dark) !important;
    color: #fff !important;
    box-shadow: 0 14px 30px rgba(216,121,8,.26) !important;
    outline: 3px solid rgba(243,154,32,.22) !important;
    outline-offset: 2px !important;
}

.btn-secondary,
.btn-outline,
.btn-outline-white,
.btn-outline-sm,
.hero-btns .btn-secondary,
.hero-btns .btn-outline,
.hero-btns .btn-outline-white,
.product-card-actions .btn-outline-sm,
.category-card .btn-secondary,
.feature-item .btn-secondary,
.cta-section .btn-outline-white,
.footer-cta-actions .btn-outline-white,
.cta-mini .btn-outline-white {
    background: #fffdf8 !important;
    border-color: rgba(79,123,85,.42) !important;
    color: var(--primary-dark) !important;
    box-shadow: 0 8px 18px rgba(79,123,85,.08) !important;
}
.btn-secondary:hover,
.btn-outline:hover,
.btn-outline-white:hover,
.btn-outline-sm:hover,
.hero-btns .btn-secondary:hover,
.hero-btns .btn-outline:hover,
.hero-btns .btn-outline-white:hover,
.product-card-actions .btn-outline-sm:hover,
.category-card .btn-secondary:hover,
.feature-item .btn-secondary:hover,
.cta-section .btn-outline-white:hover,
.footer-cta-actions .btn-outline-white:hover,
.cta-mini .btn-outline-white:hover,
.btn-secondary:focus-visible,
.btn-outline:focus-visible,
.btn-outline-white:focus-visible,
.btn-outline-sm:focus-visible {
    background: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
    color: #fff !important;
    box-shadow: 0 12px 26px rgba(39,73,54,.22) !important;
}

.category-tabs-row .btn:not(.btn-secondary) {
    background: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
    color: #fff !important;
}
.product-cat-badge,
.badge-green { background: #5f8f54 !important; color: #fff !important; }
.cta-section,
.footer-cta-inner,
.cta-mini {
    background: linear-gradient(135deg, #315f45 0%, #6f8f4e 62%, #bd8a32 100%) !important;
}
.app-card {
    background: linear-gradient(145deg, #5f8f54 0%, #8a9f55 50%, #bd8a32 100%) !important;
}
.app-card::before { opacity: .12 !important; }
#backToTop { background: var(--primary-color) !important; color: #fff !important; }
.process-card,
.feature-item,
.product-card,
.category-card,
.trust-card,
.cert-item { background: #fffdf8 !important; }

@media (max-width: 768px) {
    .section-pad { padding: 42px 0 !important; }
    .section-pad-sm { padding: 34px 0 !important; }
    .section-heading { margin-bottom: 24px !important; }
    .strip-banner.is-list { padding: 38px 0 !important; }
    .strip-banner.is-detail { padding: 34px 0 !important; }
    .strip-banner > .container h1 { font-size: clamp(30px, 9vw, 44px) !important; }
    .strip-banner > .container p { font-size: 16px !important; }
    .hero-btns .btn,
    .hero-btns .btn-outline-white,
    .hero-btns .btn-secondary,
    .hero-btns .btn-outline { width: 100% !important; justify-content: center !important; }
}

/* Success states must override earlier submit-button visibility fixes. */
.inquiry-modal.success-state .inquiry-form,
.inquiry-form[hidden],
#inquiryForm[hidden],
#contactForm[hidden],
.contact-success[hidden],
.inquiry-success[hidden] {
    display: none !important;
}

.inquiry-modal.success-state {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    min-height: min(620px, calc(100vh - 48px));
}

.inquiry-modal.success-state .inquiry-success {
    display: flex !important;
    width: 100%;
    min-height: min(460px, calc(100vh - 140px));
    padding: 36px 12px;
}

.inquiry-form .field-error,
.contact-form-wrap .field-error {
    border-color: #dc2626 !important;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.14) !important;
}

.site-notice-overlay {
    position: fixed;
    inset: 0;
    z-index: 10050;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(15, 23, 42, 0.54);
    backdrop-filter: blur(4px);
}

.site-notice-overlay.active {
    display: flex;
}

.site-notice-box {
    width: min(92vw, 460px);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.28);
    padding: 30px 28px 26px;
    text-align: center;
    color: var(--text-dark);
}

.site-notice-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 38px;
    font-weight: 800;
    color: #fff;
}

.site-notice-overlay.is-success .site-notice-icon {
    background: linear-gradient(135deg, #16a34a, #22c55e);
}

.site-notice-overlay.is-error .site-notice-icon {
    background: linear-gradient(135deg, #dc2626, #f97316);
}

.site-notice-title {
    font-size: 24px;
    line-height: 1.2;
    margin: 0 0 10px;
    color: var(--text-dark);
}

.site-notice-message {
    margin: 0 0 22px;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-body);
}

.site-notice-btn {
    min-width: 148px;
    min-height: 50px;
    border: 0;
    border-radius: 14px;
    background: var(--accent-color);
    color: #fff;
    font-weight: 800;
    font-size: 16px;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(245, 158, 11, 0.25);
}

.site-notice-btn:focus-visible {
    outline: 3px solid rgba(245, 158, 11, 0.35);
    outline-offset: 3px;
}

/* Mobile inquiry modal stability: avoid sticky submit issues in iOS/embedded browsers. */
.inquiry-overlay.active {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.inquiry-modal {
    scrollbar-gutter: stable;
}

@media (max-width: 768px) {
    .inquiry-overlay {
        align-items: flex-start !important;
        justify-content: center !important;
        padding: max(10px, env(safe-area-inset-top)) 12px max(18px, env(safe-area-inset-bottom)) !important;
    }

    .inquiry-modal {
        width: min(100%, 560px) !important;
        max-height: none !important;
        min-height: 0 !important;
        margin: 0 auto calc(18px + env(safe-area-inset-bottom)) !important;
        padding: 20px 16px 18px !important;
        overflow: visible !important;
        border-radius: 18px !important;
    }

    .inquiry-header {
        padding-right: 42px !important;
    }

    .inquiry-form {
        display: block !important;
        padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;
    }

    .inquiry-form .form-group:has(#inquirySubmitBtn) {
        position: static !important;
        bottom: auto !important;
        margin: 18px 0 12px !important;
        padding: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        min-height: 58px !important;
    }

    #inquirySubmitBtn {
        min-height: 58px !important;
        width: 100% !important;
        touch-action: manipulation;
    }

    .inquiry-privacy {
        padding-bottom: calc(8px + env(safe-area-inset-bottom)) !important;
    }

    .site-notice-overlay {
        align-items: center;
        padding: max(16px, env(safe-area-inset-top)) 14px max(22px, env(safe-area-inset-bottom));
    }

    .site-notice-box {
        border-radius: 20px;
        padding: 26px 20px 22px;
    }

    .site-notice-title {
        font-size: 21px;
    }

    .site-notice-message {
        font-size: 15px;
    }
}

/* R2 video media blocks */
.main-video-block {
    margin: 24px 0;
    border: 1px solid var(--border-color);
    border-radius: 18px;
    overflow: hidden;
    background: #0f172a;
    box-shadow: 0 18px 36px rgba(15, 23, 42, .10);
    position: relative;
}
.main-video-block video {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    background: #0f172a;
}
.main-video-block.is-portrait {
    width: min(100%, 430px);
    margin-left: auto;
    margin-right: auto;
    border-radius: 22px;
    background: #050b16;
}
.main-video-block.is-portrait video {
    aspect-ratio: 9 / 16;
    max-height: min(78vh, 760px);
    object-fit: contain;
}
.article-main-video.is-portrait {
    margin-top: 0;
    margin-bottom: 34px;
}
.main-video-block.is-square video {
    aspect-ratio: 1 / 1;
    object-fit: contain;
}
.product-video-first {
    margin-bottom: 18px;
}
.product-video-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 10px;
    padding: 5px 12px;
    border-radius: 999px;
    background: rgba(26, 111, 212, .10);
    color: var(--primary-color);
    border: 1px solid rgba(26, 111, 212, .18);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.product-main-video { margin: 0 0 18px; }
.product-hero-video {
    border-radius: var(--radius-md);
    box-shadow: 0 18px 40px rgba(15, 23, 42, .12);
}
.product-hero-video video {
    object-fit: contain;
}
.article-main-video { margin-bottom: 34px; }
@media (max-width: 768px) {
    .main-video-block { margin: 18px 0 24px; border-radius: 14px; }
    .main-video-block.is-portrait {
        width: min(100%, 430px);
        border-radius: 18px;
    }
    .main-video-block.is-portrait video {
        max-height: calc(100vh - 170px);
    }
    .product-video-first { margin-bottom: 14px; }
}

/* Final launch button QA fixes: stable readable states across cards, CTAs, and embedded browsers. */
.btn,
a.btn,
button.btn,
.btn-outline,
a.btn-outline,
button.btn-outline,
.btn-outline-sm,
a.btn-outline-sm,
button.btn-outline-sm,
.btn-secondary,
a.btn-secondary,
button.btn-secondary,
.btn-outline-white,
a.btn-outline-white,
button.btn-outline-white,
.btn-nav,
.site-notice-btn {
    text-decoration: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: rgba(245, 158, 11, .18);
}

.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white),
.btn-primary,
a.btn-primary,
button.btn-primary,
.btn-nav.btn-inquiry,
.site-notice-btn {
    background: linear-gradient(135deg, var(--accent-color), var(--accent-dark)) !important;
    border-color: var(--accent-color) !important;
    color: #fff !important;
    text-shadow: none !important;
    box-shadow: 0 12px 28px rgba(245, 158, 11, .24) !important;
}

.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):hover,
.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):focus-visible,
a.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):focus-visible,
button.btn:not(.btn-secondary):not(.btn-outline):not(.btn-outline-white):focus-visible,
.btn-primary:hover,
a.btn-primary:hover,
button.btn-primary:hover,
.btn-primary:focus-visible,
a.btn-primary:focus-visible,
button.btn-primary:focus-visible,
.btn-nav.btn-inquiry:hover,
.btn-nav.btn-inquiry:focus-visible,
.site-notice-btn:hover,
.site-notice-btn:focus-visible {
    background: linear-gradient(135deg, var(--accent-dark), #d97706) !important;
    border-color: var(--accent-dark) !important;
    color: #fff !important;
    box-shadow: 0 14px 32px rgba(245, 158, 11, .32) !important;
}

.btn-secondary,
a.btn-secondary,
button.btn-secondary,
.btn-outline,
a.btn-outline,
button.btn-outline,
.btn-outline-sm,
a.btn-outline-sm,
button.btn-outline-sm,
.btn-outline-white,
a.btn-outline-white,
button.btn-outline-white {
    background: #fff !important;
    color: var(--primary-dark) !important;
    border-color: rgba(0, 74, 153, .34) !important;
    text-shadow: none !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .05) !important;
}

.btn-secondary:hover,
a.btn-secondary:hover,
button.btn-secondary:hover,
.btn-secondary:focus-visible,
a.btn-secondary:focus-visible,
button.btn-secondary:focus-visible,
.btn-outline:hover,
a.btn-outline:hover,
button.btn-outline:hover,
.btn-outline:focus-visible,
a.btn-outline:focus-visible,
button.btn-outline:focus-visible,
.btn-outline-sm:hover,
a.btn-outline-sm:hover,
button.btn-outline-sm:hover,
.btn-outline-sm:focus-visible,
a.btn-outline-sm:focus-visible,
button.btn-outline-sm:focus-visible,
.btn-outline-white:hover,
a.btn-outline-white:hover,
button.btn-outline-white:hover,
.btn-outline-white:focus-visible,
a.btn-outline-white:focus-visible,
button.btn-outline-white:focus-visible {
    background: #fff7ed !important;
    color: var(--primary-dark) !important;
    border-color: var(--accent-color) !important;
    box-shadow: 0 12px 26px rgba(245, 158, 11, .18) !important;
}

.cta-section .btn-outline-white,
.footer-cta-actions .btn-outline-white,
.cta-mini .btn-outline-white {
    background: rgba(255, 255, 255, .96) !important;
    color: var(--primary-dark) !important;
    border-color: rgba(255, 255, 255, .96) !important;
}

.product-card-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1.04fr) minmax(0, .96fr);
    gap: 12px !important;
    align-items: stretch !important;
    margin-top: 14px !important;
}

.product-card-actions .btn,
.product-card-actions .btn-outline-sm,
.product-card-actions button,
.product-card-actions a {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 48px !important;
    padding: 11px 14px !important;
    border-radius: 13px !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
}

.product-card-actions .btn-outline-sm {
    border-width: 2px !important;
    color: #214532 !important;
    border-color: rgba(33, 69, 50, .36) !important;
    background: #fffdf7 !important;
}

.product-card-actions .btn-outline-sm:hover,
.product-card-actions .btn-outline-sm:focus-visible {
    color: #fff !important;
    border-color: #214532 !important;
    background: #214532 !important;
    box-shadow: 0 12px 26px rgba(33, 69, 50, .18) !important;
}

.product-card-content .meta {
    min-height: 42px;
}

@media (max-width: 680px) {
    .product-card-actions {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }
    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .product-card-actions button,
    .product-card-actions a {
        min-height: 50px !important;
        padding: 11px 10px !important;
        font-size: 14px !important;
    }
}

@media (max-width: 380px) {
    .product-card-actions {
        grid-template-columns: 1fr !important;
    }
}

/* Final mobile product card action fix: stack actions to prevent overflow in narrow in-app browsers. */
@media (max-width: 680px) {
    .product-card-actions {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        width: 100% !important;
    }
    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .product-card-actions button,
    .product-card-actions a {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        display: inline-flex !important;
    }
}

/* Mobile overflow guard for product grids and CTA controls. */
html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

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

@media (max-width: 680px) {
    .container,
    .site-header .container,
    .product-listing-section .container,
    .section-pad .container {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 18px !important;
        padding-right: 18px !important;
        overflow-x: hidden !important;
    }

    .product-grid,
    .related-grid,
    .blog-grid {
        grid-template-columns: minmax(0, 1fr) !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    .product-card,
    .blog-card,
    .related-card {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow: hidden !important;
    }

    .product-card-content,
    .blog-card-content,
    .product-img-wrap,
    .blog-img-wrap {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .product-card-actions,
    .hero-btns,
    .cta-actions,
    .footer-cta-actions,
    .category-card-actions {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .hero-btns .btn,
    .cta-actions .btn,
    .footer-cta-actions .btn,
    .category-card-actions .btn {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .category-tabs-row {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 10px !important;
        width: 100% !important;
    }
}

/* Hard viewport clamp for narrow product-card actions in mobile webviews. */
@media (max-width: 680px) {
    .product-card-content {
        padding-left: 14px !important;
        padding-right: 14px !important;
        overflow: hidden !important;
    }

    .product-card-actions {
        width: min(100%, calc(100vw - 76px)) !important;
        max-width: calc(100vw - 76px) !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .product-card-actions button,
    .product-card-actions a {
        width: 100% !important;
        max-width: calc(100vw - 76px) !important;
    }

    .category-tabs-row .btn,
    .category-tabs-row .btn-secondary,
    .hero-btns .btn,
    .cta-actions .btn,
    .footer-cta-actions .btn {
        max-width: calc(100vw - 48px) !important;
    }
}

/* Exact mobile card width clamp: keep visible right gutter in Chrome/TikTok webviews. */
@media (max-width: 680px) {
    .product-grid,
    .related-grid,
    .blog-grid {
        justify-items: center !important;
    }

    .product-card,
    .blog-card,
    .related-card {
        width: calc(100vw - 36px) !important;
        max-width: calc(100vw - 36px) !important;
    }

    .product-card-content .meta,
    .blog-card-content p,
    .product-card-content h3 {
        overflow-wrap: anywhere !important;
        word-break: normal !important;
    }

    .product-card-actions {
        width: 100% !important;
        max-width: 100% !important;
    }

    .product-card-actions .btn,
    .product-card-actions .btn-outline-sm,
    .product-card-actions button,
    .product-card-actions a {
        max-width: 100% !important;
    }
}
