/*
Theme Name: Plastopia
Theme URI: https://www.plastopialtd.com/
Author: Plastopia Dev
Author URI: https://www.plastopialtd.com/
Description: A professional WordPress theme for Plastopia - China Injection Molding & Manufacturing company. Features custom post types for Products and News, industrial design aesthetics, and responsive layout.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: plastopia
Tags: manufacturing, industrial, business, custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/



:root {
    --color-primary: #0d2b4e;
    --color-accent: #2a7de1;
    --color-cta: #f5762a;
    --color-white: #ffffff;
    --color-bg-light: #f5f7fa;
    --color-text-dark: #1e293b;
    --color-text-light: #64748b;
    --color-border: #e2e8f0;
    --radius: 6px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', system-ui, sans-serif; color: var(--color-text-dark); -webkit-font-smoothing: antialiased; }
a { color: var(--color-accent); text-decoration: none; }
img { max-width: 100%; height: auto; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* Header */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: #fff; border-bottom: 1px solid var(--color-border); height: 80px; display: flex; align-items: center; }
.header-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.site-logo { font-size: 22px; font-weight: 700; color: var(--color-primary); display: flex; align-items: center; gap: 8px; }
.site-logo .logo-icon { width: 36px; height: 36px; background: var(--color-primary); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; font-weight: 700; }
.main-nav { display: flex; gap: 0; align-items: center; }
.main-nav a { padding: 8px 16px; font-size: 15px; font-weight: 500; color: var(--color-text-dark); border-radius: var(--radius); transition: all 200ms; }
.main-nav a:hover { color: var(--color-accent); background: rgba(42,125,225,0.06); }

/* Mega Menu */
.menu-item-mega { position: relative; }
.menu-item-mega > a { cursor: pointer; }
.menu-item-mega > a .arrow { font-size: 10px; margin-left: 4px; transition: transform 200ms; }
.menu-item-mega:hover > a .arrow { transform: rotate(180deg); }
.mega-menu { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); min-width: 780px; background: #fff; border-radius: 0 0 6px 6px; box-shadow: 0 8px 30px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06); z-index: 1000; padding: 0; overflow: hidden; animation: megaFadeIn 300ms ease-out; }
@keyframes megaFadeIn { from { opacity: 0; transform: translateX(-50%) translateY(8px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }
.menu-item-mega:hover > .mega-menu { display: flex; }
.mega-menu__image { width: 240px; min-width: 240px; background: #0d2b4e; position: relative; overflow: hidden; flex-shrink: 0; }
.mega-menu__image img { width: 100%; height: 100%; object-fit: cover; opacity: 0.7; }
.mega-menu__columns { display: flex; flex: 1; gap: 0; padding: 24px 28px; }
.mega-menu__columns--4 { min-width: 540px; }
.mega-menu__column { flex: 1; min-width: 140px; padding-right: 20px; }
.mega-menu__column:last-child { padding-right: 0; }
.mega-menu__heading { font-size: 15px; font-weight: 700; color: #0d2b4e; margin: 0 0 12px 0; padding-bottom: 8px; border-bottom: 2px solid #2a7de1; }
.mega-menu__heading a { color: #0d2b4e; text-decoration: none; }
.mega-menu__heading a:hover { color: #2a7de1; }
.mega-menu__list { list-style: none; padding: 0; margin: 0; }
.mega-menu__list li a { display: flex; align-items: center; padding: 6px 0; font-size: 13px; font-weight: 400; color: #1e293b; text-decoration: none; transition: all 200ms; line-height: 1.4; }
.mega-menu__list li a:hover { color: #2a7de1; padding-left: 4px; }
.mega-arrow { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; font-size: 11px; color: #2a7de1; margin-right: 6px; flex-shrink: 0; transition: transform 200ms; }
.mega-menu__list li a:hover .mega-arrow { transform: translateX(2px); }
.btn-cta { display: inline-flex; align-items: center; padding: 10px 24px; background: var(--color-accent); color: #fff; border-radius: var(--radius); font-weight: 600; font-size: 14px; margin-left: 16px; transition: all 150ms; }
.btn-cta:hover { background: #1d6bc7; color: #fff; transform: scale(1.02); }

/* Hero - Fullscreen */
.hero { min-height: 100vh; display: flex; align-items: center; background: var(--color-primary); position: relative; overflow: hidden; }
.hero__bg { position: absolute; inset: -40px; background-size: cover; background-position: center; opacity: 0.35; animation: kenBurns 20s ease-in-out infinite alternate; }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.4; z-index: 0; }
.hero__video.hidden, .hero__bg.hidden { display: none; }
@keyframes kenBurns { 0% { transform: scale(1) translate(0,0); } 100% { transform: scale(1.15) translate(-20px, -10px); } }
.hero__particles { position: absolute; inset: 0; z-index: 1; overflow: hidden; pointer-events: none; }
.hero__particle { position: absolute; width: 3px; height: 3px; background: rgba(255,255,255,0.3); border-radius: 50%; animation: floatParticle linear infinite; }
.hero__particle:nth-child(1) { left: 10%; top: 20%; animation-duration: 12s; animation-delay: 0s; width: 2px; height: 2px; }
.hero__particle:nth-child(2) { left: 25%; top: 60%; animation-duration: 15s; animation-delay: 2s; width: 4px; height: 4px; background: rgba(255,255,255,0.2); }
.hero__particle:nth-child(3) { left: 45%; top: 30%; animation-duration: 10s; animation-delay: 4s; }
.hero__particle:nth-child(4) { left: 65%; top: 70%; animation-duration: 14s; animation-delay: 1s; width: 2px; height: 2px; }
.hero__particle:nth-child(5) { left: 80%; top: 40%; animation-duration: 16s; animation-delay: 3s; width: 5px; height: 5px; background: rgba(255,255,255,0.15); }
.hero__particle:nth-child(6) { left: 15%; top: 80%; animation-duration: 11s; animation-delay: 5s; }
.hero__particle:nth-child(7) { left: 55%; top: 15%; animation-duration: 13s; animation-delay: 2.5s; width: 2px; height: 2px; }
.hero__particle:nth-child(8) { left: 90%; top: 55%; animation-duration: 17s; animation-delay: 1.5s; width: 4px; height: 4px; background: rgba(255,255,255,0.2); }
.hero__particle:nth-child(9) { left: 35%; top: 45%; animation-duration: 9s; animation-delay: 6s; }
.hero__particle:nth-child(10) { left: 70%; top: 25%; animation-duration: 14s; animation-delay: 4.5s; width: 3px; height: 3px; background: rgba(42,125,225,0.3); }
@keyframes floatParticle { 0% { transform: translateY(0) translateX(0); opacity: 0; } 10% { opacity: 1; } 90% { opacity: 1; } 100% { transform: translateY(-100vh) translateX(30px); opacity: 0; } }
.hero__overlay { position: absolute; inset: 0; background: rgba(13,43,78,0.6); }

.hero__content { position: relative; z-index: 2; max-width: 520px; background: rgba(13,43,78,0.75); backdrop-filter: blur(4px); padding: 48px 40px; border-radius: var(--radius); }

.hero__divider { width: 60px; height: 2px; background: rgba(255,255,255,0.4); margin: 20px 0; }
.hero__content p { color: rgba(255,255,255,0.85); font-size: 16px; margin-bottom: 28px; line-height: 1.7; }
.hero__buttons { display: flex; gap: 14px; flex-wrap: wrap; }
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 12px 28px; font-family: inherit; font-size: 15px; font-weight: 600; border: 2px solid transparent; border-radius: var(--radius); cursor: pointer; transition: all 150ms; gap: 6px; }
.btn-blue { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.btn-blue:hover { background: #1d6bc7; border-color: #1d6bc7; transform: scale(1.02); }
.btn-outline-white { background: transparent; color: #fff; border-color: #fff; }
.btn-outline-white:hover { background: rgba(255,255,255,0.1); }
.btn-orange { background: var(--color-cta); color: #fff; border-color: var(--color-cta); }
.btn-orange:hover { background: #e0651a; border-color: #e0651a; transform: scale(1.02); }
.hero__scroll-arrow { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); z-index: 2; animation: bounceArrow 2s ease infinite; opacity: 0.7; }
@keyframes bounceArrow { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(10px); } }

/* Sections */
.section { padding: 80px 0; }
.section--gray { background: var(--color-bg-light); }
.section__header { text-align: center; margin-bottom: 48px; }
.section__header h2 { color: var(--color-primary); font-size: 36px; margin-bottom: 12px; }
.section__header p { color: var(--color-text-light); max-width: 640px; margin: 0 auto; }

/* Services Image Grid (3x2 with product images) */
.services-image-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.service-image-card { text-align: center; }
.service-image-card__image { margin-bottom: 16px; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4/3; }
.service-image-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 300ms; }
.service-image-card:hover .service-image-card__image img { transform: scale(1.05); }
.service-image-card__title { font-size: 18px; font-weight: 600; color: var(--color-text-dark); margin-bottom: 8px; }
.service-image-card__title a { color: var(--color-text-dark); text-decoration: none; }
.service-image-card__title a:hover { color: var(--color-accent); }
.service-image-card__line { width: 40px; height: 3px; margin: 0 auto; border-radius: 2px; }

/* Why Choose Section */
.section--why-choose { position: relative; padding: 80px 0; overflow: hidden; }
.section--why-choose__bg { position: absolute; inset: 0; background-image: url('/plastopia-theme/assets/images/about-factory.jpg'); background-size: cover; background-position: center; }
.section--why-choose__overlay { position: absolute; inset: 0; background: rgba(13,43,78,0.88); }
.section--why-choose .container { position: relative; z-index: 2; }
.section--why-choose .section__header h2 { color: #fff; }
.section__header-line { width: 60px; height: 2px; background: rgba(255,255,255,0.4); margin: 16px auto 0; }
.advantages-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 48px; }
.advantage-card { text-align: center; padding: 24px; }
.advantage-card__icon { margin-bottom: 16px; display: flex; justify-content: center; }
.advantage-card__title { font-size: 18px; font-weight: 600; color: #fff; margin-bottom: 4px; }
.advantage-card__title-cn { display: block; font-size: 13px; font-weight: 400; color: rgba(255,255,255,0.6); margin-top: 4px; }
.advantage-card__desc { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.7); margin-top: 12px; }

/* Products */
.product-category-group__header { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.product-category-group__header h3 { font-size: 20px; font-weight: 600; color: var(--color-primary); margin: 0; white-space: nowrap; }
.product-category-group__line { flex: 1; height: 1px; background: var(--color-border); }
.product-category-group__viewall { font-size: 13px; color: var(--color-accent); white-space: nowrap; }
.product-category-group__viewall:hover { text-decoration: underline; }

.product-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; transition: all 200ms; }
.product-card:hover { transform: translateY(-4px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); border-color: transparent; }
.product-card__image { aspect-ratio: 4/3; background: var(--color-bg-light); overflow: hidden; }
.product-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 300ms; }
.product-card:hover .product-card__image img { transform: scale(1.05); }
.product-card__body { padding: 18px; }
.product-card__category { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-accent); margin-bottom: 6px; }
.product-card h3 { font-size: 15px; color: var(--color-primary); margin-bottom: 6px; }
.product-card p { font-size: 13px; color: var(--color-text-light); }

/* Blog */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; transition: all 200ms; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); border-color: transparent; }
.blog-card__image { aspect-ratio: 16/10; background: var(--color-bg-light); overflow: hidden; }
.blog-card__image img { width: 100%; height: 100%; object-fit: cover; }
.blog-card__body { padding: 20px; }
.blog-card__date { font-size: 13px; color: var(--color-text-light); margin-bottom: 8px; }
.blog-card h3 { font-size: 17px; color: var(--color-primary); margin-bottom: 8px; line-height: 1.4; }
.blog-card p { font-size: 14px; color: var(--color-text-light); }

/* CTA */
.cta-banner { background: var(--color-primary); padding: 56px 0; text-align: center; }
.cta-banner h2 { color: #fff; font-size: 34px; margin-bottom: 12px; }
.cta-banner p { color: rgba(255,255,255,0.8); font-size: 17px; max-width: 520px; margin: 0 auto 28px; }

/* Footer */
.site-footer { background: #0a1f38; color: rgba(255,255,255,0.7); padding: 56px 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 36px; padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-col h4 { color: #fff; font-size: 15px; margin-bottom: 18px; }
.footer-col p { font-size: 14px; line-height: 1.7; margin-bottom: 12px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 8px; }
.footer-col li a { font-size: 14px; color: rgba(255,255,255,0.7); transition: all 200ms; }
.footer-col li a:hover { color: #fff; padding-left: 4px; }
.footer-bottom { padding: 18px 0; display: flex; justify-content: space-between; font-size: 13px; }
.social-links { display: flex; gap: 10px; margin-top: 16px; }
.social-links a { width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius); color: rgba(255,255,255,0.7); font-size: 12px; transition: all 200ms; }
.social-links a:hover { background: var(--color-accent); border-color: var(--color-accent); color: #fff; }

/* Download Section */

.file-list { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 24px; }
.file-item { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius); padding: 10px 18px; font-size: 13px; color: rgba(255,255,255,0.8); }

/* Responsive */
@media (max-width: 992px) {
    .services-image-grid, .advantages-grid, .blog-grid { grid-template-columns: repeat(2, 1fr); }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .hero__content h1 { font-size: 28px; }
    .hero .container { justify-content: center; }
    .hero__content { text-align: center; }
    .service-hero__grid { grid-template-columns: 1fr; }
    .service-hero__image { order: -1; }
    .service-hero__actions { justify-content: center; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 576px) {
    .services-image-grid, .advantages-grid, .blog-grid, .products-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; }
}

/* ============================================
Page-specific: injection-molding
============================================ */
.site-logo .logo-icon span { width: 8px; height: 8px; background: var(--color-accent); border-radius: 2px; }
.btn-outline-blue { display: inline-block; border: 2px solid var(--color-accent); color: var(--color-accent); padding: 10px 24px; border-radius: var(--radius); font-weight: 600; font-size: 14px; }
.btn-outline-blue:hover { background: var(--color-accent); color: #fff; }
.btn-lg { padding: 16px 40px; font-size: 18px; }
.breadcrumb-bar { padding-top: 100px; padding-bottom: 16px; background: var(--color-bg-light); font-size: 14px; color: var(--color-text-light); }
.breadcrumb-bar a { color: var(--color-text-light); }
.breadcrumb-bar a:hover { color: var(--color-accent); }
.breadcrumb-sep { margin: 0 8px; }
.breadcrumb-current { color: var(--color-text-dark); font-weight: 500; }
.service-hero { background: var(--color-bg-light); padding: 60px 0 80px; }
.service-hero__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.service-hero__title { font-size: 42px; font-weight: 700; color: var(--color-primary); line-height: 1.2; margin-bottom: 20px; }
.service-hero__desc { font-size: 17px; color: var(--color-text-light); line-height: 1.8; margin-bottom: 16px; }
.service-hero__price { display: flex; align-items: center; gap: 10px; font-size: 16px; font-weight: 600; color: var(--color-primary); margin-bottom: 30px; }
.service-hero__price svg { width: 24px; height: 24px; }
.service-hero__actions { display: flex; gap: 16px; flex-wrap: wrap; }
.service-hero__image img { border-radius: var(--radius); box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.service-advantages { background: var(--color-primary); padding: 40px 0; }
.advantage-item { text-align: center; color: #fff; }
.advantage-item__icon { margin-bottom: 12px; }
.advantage-item__icon svg { width: 32px; height: 32px; fill: var(--color-accent); }
.advantage-item__text { font-size: 16px; font-weight: 600; }
.section-header { margin-bottom: 48px; }
.section-header--left { text-align: left; }
.section-title { font-size: 32px; font-weight: 700; color: var(--color-primary); margin-bottom: 12px; }
.section-divider { width: 60px; height: 3px; background: var(--color-accent); margin-bottom: 16px; }
.section-header--left .section-divider { margin-left: 0; }
.section-subtitle { font-size: 16px; color: var(--color-text-light); line-height: 1.7; max-width: 700px; }
.service-industries { padding: 80px 0; }
.industries-grid { display: flex; flex-direction: column; gap: 60px; }
.industry-card { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.industry-card--odd { direction: rtl; }
.industry-card--odd > * { direction: ltr; }
.industry-card__title { font-size: 24px; font-weight: 700; color: var(--color-primary); margin-bottom: 12px; }
.industry-card__desc { color: var(--color-text-light); line-height: 1.7; margin-bottom: 16px; }
.industry-card__points { list-style: none; }
.industry-card__points li { display: flex; align-items: center; gap: 8px; padding: 4px 0; color: var(--color-text-dark); font-size: 15px; }
.industry-card__points li svg { width: 16px; height: 16px; flex-shrink: 0; fill: var(--color-accent); }
.industry-card__image img { border-radius: var(--radius); }
.service-materials { padding: 80px 0; background: var(--color-bg-light); }
.materials-grid { display: flex; flex-wrap: wrap; gap: 12px; }
.material-tag { background: #fff; border: 1px solid var(--color-border); padding: 10px 20px; border-radius: var(--radius); font-size: 15px; font-weight: 500; color: var(--color-text-dark); }
.material-tag:hover { border-color: var(--color-accent); color: var(--color-accent); }
.service-capabilities { padding: 80px 0; }
.capabilities-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }
.capability-card { border: 1px solid var(--color-border); border-radius: var(--radius); padding: 30px; }
.capability-card__title { font-size: 20px; font-weight: 700; color: var(--color-primary); margin-bottom: 12px; }
.capability-card__desc { color: var(--color-text-light); line-height: 1.7; margin-bottom: 16px; }
.pros-cons-block { margin-bottom: 8px; }
.pros-cons-block h4 { font-size: 14px; font-weight: 600; text-transform: uppercase; margin-bottom: 8px; }
.pros-cons-block--pros h4 { color: #16a34a; }
.pros-cons-block--cons h4 { color: #dc2626; }
.pros-cons-block ul { list-style: none; }
.pros-cons-block li { display: flex; align-items: center; gap: 8px; padding: 3px 0; font-size: 14px; }
.pros-cons-block li svg { width: 14px; height: 14px; flex-shrink: 0; }
.pros-cons-block--pros li svg { fill: #16a34a; }
.pros-cons-block--cons li svg { fill: #dc2626; }
.service-surface { padding: 80px 0; background: var(--color-bg-light); }
.surface-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.surface-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); padding: 24px; text-align: center; }
.surface-card__title { font-size: 16px; font-weight: 700; color: var(--color-primary); margin-bottom: 8px; }
.surface-card__desc { font-size: 14px; color: var(--color-text-light); }
.service-secondary { padding: 80px 0; }
.secondary-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.secondary-card { border: 1px solid var(--color-border); border-radius: var(--radius); padding: 24px; }
.secondary-card__title { font-size: 18px; font-weight: 700; color: var(--color-primary); margin-bottom: 8px; }
.secondary-card__desc { font-size: 14px; color: var(--color-text-light); line-height: 1.7; margin-bottom: 12px; }
.service-cta { background: var(--color-primary); padding: 80px 0; text-align: center; color: #fff; }
.service-cta__title { font-size: 32px; font-weight: 700; margin-bottom: 16px; }
.service-cta__desc { font-size: 18px; color: rgba(255,255,255,0.8); margin-bottom: 32px; }
.service-related { padding: 80px 0; }
.services-grid--3col { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.service-related-card { display: block; border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; transition: transform 0.2s, box-shadow 0.2s; text-decoration: none; color: var(--color-text-dark); }
.service-related-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.service-related-card__image { height: 200px; overflow: hidden; }
.service-related-card__image img { width: 100%; height: 100%; object-fit: cover; }
.service-related-card__title { padding: 16px; font-size: 16px; font-weight: 600; }
.mega-menu--resources { min-width: 440px; }
.menu-item-mega.mega-open .mega-menu,
.menu-item-mega:hover .mega-menu { display: flex; }
.mega-menu__columns--2 { gap: 32px; }
.mega-menu__columns--2 .mega-menu__column { min-width: 180px; }
.mega-menu__list li { margin-bottom: 8px; }
.mega-menu__list a { display: flex; align-items: center; gap: 8px; color: #1e293b; font-size: 14px; font-weight: 500; transition: color 0.2s; }
.mega-menu__list a:hover { color: #2a7de1; }
.arrow { font-size: 10px; margin-left: 4px; }

/* ============================================
Page-specific: faq
============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
.logo { display: flex; align-items: center; gap: 8px; font-size: 20px; font-weight: 700; color: var(--primary); }
.logo-icon { width: 32px; height: 32px; background: var(--accent); border-radius: 4px; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: 14px; }
.nav-links { display: flex; align-items: center; gap: 28px; font-size: 14px; font-weight: 500; }
.nav-links a { color: var(--text-dark); transition: color 0.2s; }
.nav-links a:hover { color: var(--accent); }
.menu-item-mega:hover .mega-menu { display: flex; }
.faq-hero { background: var(--primary); color: #fff; padding: 80px 24px 60px; text-align: center; }
.faq-hero h1 { font-size: 42px; font-weight: 700; margin-bottom: 16px; }
.faq-hero p { font-size: 18px; color: rgba(255,255,255,0.8); max-width: 600px; margin: 0 auto; }
.faq-hero-breadcrumb { margin-bottom: 20px; font-size: 14px; color: rgba(255,255,255,0.6); }
.faq-hero-breadcrumb a { color: rgba(255,255,255,0.7); }
.faq-hero-breadcrumb a:hover { color: #fff; }
.faq-tabs-wrap { background: var(--white); border-bottom: 1px solid var(--border); position: sticky; top: 70px; z-index: 100; }
.faq-tabs { max-width: 800px; margin: 0 auto; display: flex; gap: 0; padding: 0 24px; }
.faq-tab { flex: 1; padding: 18px 24px; text-align: center; font-size: 16px; font-weight: 600; color: var(--text-light); cursor: pointer; border-bottom: 3px solid transparent; transition: all 0.2s; }
.faq-tab:hover { color: var(--accent); }
.faq-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.faq-category-tags { max-width: 900px; margin: 32px auto 0; padding: 0 24px; display: flex; flex-wrap: wrap; gap: 8px; }
.faq-tag { padding: 6px 16px; border-radius: 20px; font-size: 13px; font-weight: 500; color: var(--text-light); background: var(--bg-light); border: 1px solid var(--border); cursor: pointer; transition: all 0.2s; }
.faq-tag:hover { border-color: var(--accent); color: var(--accent); }
.faq-tag.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.faq-section { max-width: 900px; margin: 0 auto; padding: 40px 24px 80px; }
.faq-group { margin-bottom: 48px; }
.faq-group-title { font-size: 20px; font-weight: 700; color: var(--primary); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--accent); }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 12px; overflow: hidden; transition: box-shadow 0.2s; }
.faq-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
.faq-question { padding: 18px 24px; display: flex; align-items: center; justify-content: space-between; cursor: pointer; font-weight: 600; font-size: 15px; color: var(--text-dark); background: var(--white); transition: background 0.2s; }
.faq-question:hover { background: var(--bg-light); }
.faq-question .icon { font-size: 20px; color: var(--accent); transition: transform 0.3s; flex-shrink: 0; margin-left: 16px; }
.faq-item.open .faq-question .icon { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s ease-out, padding 0.3s ease-out; padding: 0 24px; }
.faq-item.open .faq-answer { max-height: 600px; padding: 0 24px 20px; }
.faq-answer p { font-size: 14px; line-height: 1.8; color: var(--text-light); margin-bottom: 8px; }
.faq-answer ul { margin: 8px 0; padding-left: 20px; }
.faq-answer li { font-size: 14px; line-height: 1.8; color: var(--text-light); margin-bottom: 4px; }
.faq-answer strong { color: var(--text-dark); }
.faq-answer .remark { background: #fffbeb; border-left: 3px solid #f59e0b; padding: 10px 14px; margin-top: 8px; border-radius: 0 var(--radius) var(--radius) 0; font-size: 13px; color: #92400e; }
.footer-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }

/* ============================================
Page-specific: molding-glossary
============================================ */
.nav { display:flex;align-items:center;gap:24px;font-size:14px;font-weight:500 }
.nav a { color:#1e293b;transition:color .2s }
.nav a:hover { color:#2a7de1 }
.btn-outline { display:inline-flex;align-items:center;padding:8px 20px;border:2px solid #fff;color:#fff;border-radius:6px;font-size:14px;font-weight:600;transition:background .15s }
.btn-outline:hover { background:rgba(255,255,255,.15) }
.btn-accent { display:inline-flex;align-items:center;padding:10px 24px;background:#f5762a;color:#fff;border-radius:6px;font-size:14px;font-weight:600;transition:background .15s }
.btn-accent:hover { background:#e0661a }
.breadcrumb { padding:16px 32px;font-size:13px;color:#64748b;background:#f5f7fa }
.breadcrumb a { color:#2a7de1 }
.breadcrumb a:hover { text-decoration:underline }
.glossary-hero { background:linear-gradient(135deg,#0d2b4e 0%,#1a3f6f 100%);color:#fff;padding:64px 32px 48px;text-align:center }
.glossary-hero h1 { font-size:38px;font-weight:700;line-height:1.2;margin-bottom:12px }
.glossary-hero p { font-size:17px;max-width:680px;margin:0 auto 20px;opacity:.9 }
.glossary-hero__btns { display:flex;justify-content:center;gap:16px;flex-wrap:wrap }
.alpha-nav { position:sticky;top:64px;z-index:99;background:#fff;border-bottom:1px solid #e2e8f0;padding:0 32px;display:flex;justify-content:center;gap:6px;flex-wrap:wrap }
.alpha-nav a { display:flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:13px;font-weight:700;color:#64748b;border-radius:4px;transition:all .15s }
.alpha-nav a:hover { background:#2a7de1;color:#fff }
.alpha-nav a.active { background:#0d2b4e;color:#fff }
.glossary-section { padding:48px 32px;max-width:960px;margin:0 auto }
.glossary-section--alt { background:#f5f7fa }
.glossary-letter { font-size:28px;font-weight:700;color:#2a7de1;margin-bottom:24px;padding-bottom:8px;border-bottom:3px solid #2a7de1;display:inline-block }
.glossary-item { background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:20px;overflow:hidden;transition:box-shadow .2s }
.glossary-item:hover { box-shadow:0 4px 16px rgba(0,0,0,.08) }
.glossary-item__inner { display:flex;gap:0 }
.glossary-item__content { flex:1;padding:24px 28px }
.glossary-item__image { width:260px;min-height:180px;flex-shrink:0;background:#f5f7fa;display:flex;align-items:center;justify-content:center;overflow:hidden }
.glossary-item__image img { width:100%;height:100%;object-fit:cover }
.glossary-item__term { font-size:20px;font-weight:700;color:#0d2b4e;margin-bottom:8px }
.glossary-item__aka { font-size:13px;color:#64748b;font-style:italic;margin-bottom:8px }
.glossary-item__desc { font-size:14px;color:#1e293b;line-height:1.7 }
.glossary-item__link { display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:#2a7de1;margin-top:10px;transition:color .15s }
.glossary-item__link:hover { color:#1a6dd1 }
.glossary-item--no-image .glossary-item__inner { display:block }
.glossary-item--no-image .glossary-item__content { padding:20px 28px }

.footer-contact p { font-size:13px;color:rgba(255,255,255,.65);display:flex;align-items:flex-start;gap:8px;margin-bottom:8px }
@media(max-width:768px) { .glossary-hero h1{font-size:28px;} }

/* ============================================
Page-specific: custom-metal-parts
============================================ */
.service-hero h1 { font-size:42px;font-weight:700;line-height:1.2;margin-bottom:16px }
.service-hero p { font-size:18px;max-width:760px;margin:0 auto 24px;opacity:.9 }
.service-hero__btns { display:flex;justify-content:center;gap:16px;flex-wrap:wrap }
.section--alt { background:#f5f7fa }
.section--dark { background:#0d2b4e;color:#fff }
.section--dark .section__header h2 { color:#fff }
.section--dark .section__header p { color:rgba(255,255,255,.7) }
.section__divider { width:60px;height:3px;background:#2a7de1;margin:12px auto 0;border-radius:2px }
.tab-nav { display:flex;justify-content:center;gap:0;background:#fff;border-bottom:2px solid #e2e8f0;padding:0 32px;position:sticky;top:64px;z-index:99 }
.tab-nav__item { padding:18px 36px;font-size:15px;font-weight:600;color:#64748b;border-bottom:3px solid transparent;transition:all .2s;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none }
.tab-nav__item:hover { color:#2a7de1 }
.tab-nav__item.active { color:#2a7de1;border-bottom-color:#2a7de1 }
.tab-content { display:none }
.tab-content.active { display:block }
.two-col { display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1100px;margin:0 auto }
.two-col__image { border-radius:6px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08) }
.two-col__image img { width:100%;height:auto }
.two-col__content h3 { font-size:24px;font-weight:700;color:#0d2b4e;margin-bottom:16px }
.two-col__content p { font-size:15px;color:#64748b;margin-bottom:16px }
.feature-list { list-style:none;padding:0 }
.feature-list li { display:flex;align-items:flex-start;gap:12px;padding:8px 0;font-size:15px;color:#1e293b }
.feature-list li svg { flex-shrink:0;margin-top:2px }
.type-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px;margin:0 auto }
.type-card { background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:16px;text-align:center;transition:all .2s }
.type-card:hover { border-color:#2a7de1;box-shadow:0 4px 12px rgba(42,125,225,.1) }
.type-card__title { font-size:13px;font-weight:600;color:#0d2b4e }
.app-tags { display:flex;flex-wrap:wrap;gap:10px;max-width:1100px;margin:0 auto }
.app-tag { padding:8px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;font-size:13px;font-weight:600;color:#0d2b4e;transition:all .2s }
.app-tag:hover { border-color:#2a7de1;color:#2a7de1 }
.parts-gallery { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px;margin:0 auto }
.parts-gallery__item { border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06);aspect-ratio:1;background:#f5f7fa }
.parts-gallery__item img { width:100%;height:100%;object-fit:cover;transition:transform .3s }
.parts-gallery__item:hover img { transform:scale(1.05) }

/* ============================================
Page-specific: 3d-printing
============================================ */
a:hover { color: #1a5fb4; }
.mega-menu__columns--4 .mega-menu__column { min-width: 160px; }
.service-hero__inner { display: flex; align-items: center; gap: 48px; }
.service-hero__content { flex: 1; }
.service-hero__image { flex: 1; max-width: 480px; }
.why-section { padding: 80px 0; background: #fff; }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.why-card { padding: 28px 24px; border-radius: 6px; border: 1px solid #e2e8f0; transition: transform 0.2s, box-shadow 0.2s; }
.why-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.why-card__icon { width: 48px; height: 48px; background: rgba(42,125,225,0.1); border-radius: 6px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; color: #2a7de1; }
.why-card__title { font-size: 18px; font-weight: 700; color: #0d2b4e; margin-bottom: 10px; }
.why-card__desc { font-size: 15px; color: #64748b; line-height: 1.6; }
.two-col__inner { display: flex; align-items: flex-start; gap: 48px; }
.two-col__inner--reverse { flex-direction: row-reverse; }
.two-col__content { flex: 1; }
.two-col__label { font-size: 14px; font-weight: 600; color: #2a7de1; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.two-col__title { font-size: 28px; font-weight: 700; color: #0d2b4e; margin-bottom: 16px; }
.two-col__text { font-size: 16px; color: #64748b; margin-bottom: 20px; line-height: 1.7; }
.materials-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 16px; }
.materials-note { font-size: 14px; color: #64748b; font-style: italic; line-height: 1.6; }
.tech-section { padding: 80px 0; background: #f5f7fa; }
.tech-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.tech-card { background: #fff; border-radius: 6px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.06); transition: transform 0.2s, box-shadow 0.2s; }
.tech-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.tech-card__header { padding: 20px 24px; border-bottom: 3px solid #2a7de1; }
.tech-card__title { font-size: 18px; font-weight: 700; color: #0d2b4e; }
.tech-card__body { padding: 20px 24px; }
.tech-card__list { list-style: none; }
.tech-card__list li { padding: 8px 0; border-bottom: 1px solid #f0f0f0; font-size: 14px; color: #1e293b; display: flex; align-items: flex-start; gap: 8px; }
.tech-card__list li:last-child { border-bottom: none; }
.tech-card__list .check { color: #2a7de1; flex-shrink: 0; margin-top: 2px; }
.works-section { padding: 80px 0; }
.works-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.works-item { border-radius: 6px; overflow: hidden; position: relative; }
.works-item img { width: 100%; height: 220px; object-fit: cover; transition: transform 0.3s; }
.works-item:hover img { transform: scale(1.05); }
.works-item__label { padding: 12px 16px; background: #fff; font-size: 14px; font-weight: 500; color: #1e293b; border: 1px solid #e2e8f0; border-top: none; border-radius: 0 0 6px 6px; }
.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; padding: 60px 0; background: #0d2b4e; }
.stat-card { text-align: center; padding: 24px; }
.stat-card__number { font-size: 36px; font-weight: 700; color: #2a7de1; margin-bottom: 6px; }
.stat-card__label { font-size: 14px; color: rgba(255,255,255,0.7); }
.cta-banner__title { font-size: 32px; font-weight: 700; color: #fff; margin-bottom: 12px; }
.cta-banner__desc { font-size: 17px; color: rgba(255,255,255,0.7); margin-bottom: 28px; max-width: 600px; margin-left: auto; margin-right: auto; }
.footer-heading { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 16px; }
.footer-about p { font-size: 14px; line-height: 1.7; margin-bottom: 16px; }
.footer-links { list-style: none; }
.footer-links li { margin-bottom: 8px; }
.footer-links a { color: rgba(255,255,255,0.6); font-size: 14px; }
.footer-links a:hover { color: #fff; }
@media (max-width: 1024px) { .service-hero__inner { flex-direction: column; } }

/* ============================================
Page-specific: cnc-machining
============================================ */
.service-hero__tags { display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:24px }
.service-hero__tag { padding:6px 16px;background:rgba(255,255,255,.12);border-radius:20px;font-size:13px;font-weight:500 }
.stats-bar { display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:#f5f7fa }
.stat-card:nth-child(even) { background:#0d2b4e }
.quick-nav { position:sticky;top:64px;z-index:99;background:#fff;border-bottom:1px solid #e2e8f0;padding:0 32px;display:flex;justify-content:center;gap:32px }
.quick-nav a { padding:14px 0;font-size:14px;font-weight:600;color:#64748b;border-bottom:3px solid transparent;transition:all .2s }
.quick-nav a:hover,.quick-nav a.active { color:#2a7de1;border-bottom-color:#2a7de1 }
.card-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto }
.card { background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s }
.card:hover { transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1) }
.card__image { height:200px;overflow:hidden }
.card__image img { width:100%;height:100%;object-fit:cover }
.card__body { padding:20px }
.card__title { font-size:16px;font-weight:700;color:#0d2b4e;margin-bottom:8px }
.card__desc { font-size:14px;color:#64748b;line-height:1.6 }
.process-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto }
.process-card { background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:28px 24px;text-align:center }
.process-card__number { width:40px;height:40px;background:#2a7de1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;margin:0 auto 16px }
.process-card__title { font-size:16px;font-weight:700;color:#fff;margin-bottom:8px }
.process-card__desc { font-size:14px;color:rgba(255,255,255,.75);line-height:1.6 }
.material-tags { display:flex;flex-wrap:wrap;gap:10px;max-width:1100px;margin:0 auto }
.highlight-box { background:linear-gradient(135deg,#fef3e2,#fff7eb);border-left:4px solid #f5762a;border-radius:0 6px 6px 0;padding:24px 28px;max-width:800px;margin:32px auto }
.highlight-box h4 { font-size:16px;font-weight:700;color:#0d2b4e;margin-bottom:8px }
.highlight-box p { font-size:14px;color:#64748b;line-height:1.7 }
.workshop-gallery { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px;margin:0 auto }
.workshop-gallery__item { border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.08) }
.workshop-gallery__item img { width:100%;height:180px;object-fit:cover;transition:transform .3s }
.workshop-gallery__item:hover img { transform:scale(1.05) }

/* ============================================
Page-specific: zinc-die-casting
============================================ */
.menu-item-mega.mega-open .mega-menu,.menu-item-mega:hover .mega-menu { display:flex }
.service-hero .hero-btns { display:flex;gap:16px;justify-content:center;flex-wrap:wrap }
.parts-section { padding:80px 40px;background:#fff }
.parts-section .section-title { font-size:32px;font-weight:700;color:#0d2b4e;text-align:center;margin-bottom:12px }
.parts-section .section-subtitle { font-size:16px;color:#64748b;text-align:center;margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto }
.parts-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1200px;margin:0 auto }
.part-card { border-radius:6px;overflow:hidden;border:1px solid #e2e8f0;transition:transform .2s,box-shadow .2s;background:#fff }
.part-card:hover { transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1) }
.part-card img { width:100%;height:200px;object-fit:cover }
.part-card .part-name { padding:16px;font-weight:600;font-size:15px;color:#1e293b }
.stats-section { padding:60px 40px;background:#f5f7fa }
.stats-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1000px;margin:0 auto }
.stat-card .stat-value { font-size:36px;font-weight:700;color:#2a7de1;margin-bottom:8px }
.stat-card .stat-label { font-size:14px;color:#64748b;font-weight:500 }
.advantages-section { padding:80px 40px;background:#fff }
.advantages-section .section-title { font-size:32px;font-weight:700;color:#0d2b4e;text-align:center;margin-bottom:48px }
.advantage-card:hover { transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1) }
.advantage-card .adv-icon { width:48px;height:48px;background:rgba(42,125,225,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:24px }
.advantage-card h3 { font-size:18px;font-weight:700;color:#0d2b4e;margin-bottom:10px }
.advantage-card p { font-size:14px;color:#64748b;line-height:1.7 }
.mold-section { padding:80px 40px;background:#f5f7fa }
.mold-content { display:flex;gap:48px;max-width:1100px;margin:0 auto;align-items:center }
.mold-image { flex:0 0 45%;border-radius:6px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.1) }
.mold-image img { width:100%;height:auto }
.mold-text { flex:1 }
.mold-text h2 { font-size:28px;font-weight:700;color:#0d2b4e;margin-bottom:16px }
.mold-text p { font-size:15px;color:#64748b;margin-bottom:16px;line-height:1.7 }
.mold-text ul { list-style:none;padding:0 }
.mold-text ul li { padding:8px 0;font-size:15px;color:#1e293b;display:flex;align-items:flex-start;gap:10px }
.mold-text ul li::before { content:"✓";color:#2a7de1;font-weight:700;flex-shrink:0 }
.testimonials-section { padding:80px 40px;background:#0d2b4e;color:#fff }
.testimonials-section .section-title { font-size:32px;font-weight:700;text-align:center;margin-bottom:48px }
.testimonials-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:1000px;margin:0 auto }
.testimonial-card { background:rgba(255,255,255,.08);border-radius:6px;padding:32px;border:1px solid rgba(255,255,255,.1) }
.testimonial-card .quote { font-size:15px;line-height:1.8;color:rgba(255,255,255,.9);margin-bottom:20px;font-style:italic }
.testimonial-card .author { font-size:14px;font-weight:600;color:#2a7de1 }
.testimonial-card .company { font-size:13px;color:rgba(255,255,255,.6);margin-top:4px }
.cta-section { background:#0d2b4e;padding:64px 40px;text-align:center }
.cta-section h2 { font-size:32px;font-weight:700;color:#fff;margin-bottom:16px }
.cta-section p { font-size:16px;color:rgba(255,255,255,.8);margin-bottom:28px;max-width:600px;margin-left:auto;margin-right:auto }

@media(max-width:1024px) { .parts-grid{grid-template-columns:repeat(2,1fr);} }
.parts-section,.advantages-section,.mold-section,.testimonials-section { padding:48px 20px }

/* ============================================
Page-specific: product-design
============================================ */
.menu-item-mega.mega-open .mega-menu, .menu-item-mega:hover .mega-menu { display: flex; }
.page-hero { background: linear-gradient(135deg, #0d2b4e 0%, #1a4a7a 100%); color: #fff; padding: 80px 0 60px; }
.page-hero h1 { font-size: 42px; font-weight: 700; margin-bottom: 12px; line-height: 1.2; }
.page-hero p { font-size: 18px; opacity: 0.9; max-width: 600px; margin-bottom: 24px; }
.quick-nav-inner { display: flex; gap: 8px; padding: 12px 0; overflow-x: auto; }
.quick-nav-btn { padding: 8px 20px; border-radius: 20px; border: 1px solid #e2e8f0; background: #fff; color: #64748b; font-size: 14px; font-weight: 500; cursor: pointer; white-space: nowrap; transition: all 0.2s; }
.quick-nav-btn:hover, .quick-nav-btn.active { background: #2a7de1; color: #fff; border-color: #2a7de1; }
.section-gray { background: #f5f7fa; }
.section-blue { background: #0d2b4e; color: #fff; }
.section-blue .section-title { color: #fff; }
.section-blue .section-subtitle { color: rgba(255,255,255,0.7); }
.intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.intro-grid img { border-radius: 6px; width: 100%; }
.intro-text h2 { font-size: 28px; font-weight: 700; color: #0d2b4e; margin-bottom: 16px; }
.intro-text p { color: #64748b; margin-bottom: 16px; line-height: 1.8; }
.stat-card .stat-num { font-size: 28px; font-weight: 700; }
.process-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.process-step { background: #fff; border-radius: 6px; padding: 32px 24px; text-align: center; border: 1px solid #e2e8f0; transition: all 0.3s; position: relative; }
.process-step:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.process-step__num { width: 48px; height: 48px; background: #2a7de1; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 700; margin: 0 auto 16px; }
.process-step__title { font-size: 16px; font-weight: 700; color: #0d2b4e; margin-bottom: 8px; }
.process-step__desc { font-size: 14px; color: #64748b; line-height: 1.6; }
.cap-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cap-card { background: #fff; border-radius: 6px; overflow: hidden; border: 1px solid #e2e8f0; transition: all 0.3s; }
.cap-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.cap-card__img { height: 200px; overflow: hidden; }
.cap-card__img img { width: 100%; height: 100%; object-fit: cover; }
.cap-card__body { padding: 24px; }
.cap-card__title { font-size: 18px; font-weight: 700; color: #0d2b4e; margin-bottom: 8px; }
.cap-card__desc { font-size: 14px; color: #64748b; line-height: 1.6; margin-bottom: 12px; }
.cap-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.cap-tag { background: #eff6ff; color: #2a7de1; padding: 4px 10px; border-radius: 4px; font-size: 12px; font-weight: 500; }
.software-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.software-card { background: rgba(255,255,255,0.1); border-radius: 6px; padding: 24px; text-align: center; border: 1px solid rgba(255,255,255,0.15); transition: all 0.3s; }
.software-card:hover { background: rgba(255,255,255,0.15); transform: translateY(-2px); }
.software-card__icon { font-size: 36px; margin-bottom: 12px; }
.software-card__name { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.software-card__type { font-size: 12px; opacity: 0.7; }
.work-card { background: #fff; border-radius: 6px; overflow: hidden; border: 1px solid #e2e8f0; transition: all 0.3s; }
.work-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.work-card__img { height: 220px; overflow: hidden; background: #f5f7fa; display: flex; align-items: center; justify-content: center; }
.work-card__img img { width: 100%; height: 100%; object-fit: cover; }
.work-card__body { padding: 20px; }
.work-card__title { font-size: 16px; font-weight: 600; color: #0d2b4e; margin-bottom: 6px; }
.work-card__desc { font-size: 13px; color: #64748b; line-height: 1.5; }
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.benefit-card { background: rgba(255,255,255,0.08); border-radius: 6px; padding: 28px; border: 1px solid rgba(255,255,255,0.1); transition: all 0.3s; }
.benefit-card:hover { background: rgba(255,255,255,0.12); transform: translateY(-2px); }
.benefit-card__icon { width: 48px; height: 48px; background: #2a7de1; border-radius: 6px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.benefit-card__icon svg { width: 24px; height: 24px; fill: #fff; }
.benefit-card__title { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.benefit-card__desc { font-size: 14px; opacity: 0.8; line-height: 1.6; }
.footer-col h3 { font-size: 16px; font-weight: 700; margin-bottom: 16px; color: #fff; }

/* ============================================
Page-specific: design-for-manufacturability
============================================ */
.breadcrumb span { color: rgba(255,255,255,0.5); margin: 0 8px; }
.dfm-intro { display: flex; gap: 48px; align-items: flex-start; }
.dfm-intro__text { flex: 1; }
.dfm-intro__text p { margin-bottom: 16px; color: var(--text-dark); font-size: 16px; line-height: 1.8; }
.dfm-intro__text strong { color: var(--primary); }
.dfm-intro__sidebar { width: 320px; flex-shrink: 0; }
.dfm-report-card { background: var(--bg-light); border: 1px solid var(--border); border-radius: 6px; padding: 28px; text-align: center; }
.dfm-report-card__icon { width: 56px; height: 56px; margin: 0 auto 16px; background: var(--accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.dfm-report-card__icon svg { width: 28px; height: 28px; fill: var(--white); }
.dfm-report-card h3 { font-size: 18px; font-weight: 600; color: var(--primary); margin-bottom: 8px; }
.dfm-report-card p { font-size: 14px; color: var(--text-light); margin-bottom: 16px; }
.dfm-sections { display: flex; gap: 40px; }
.dfm-nav { width: 240px; flex-shrink: 0; position: sticky; top: 90px; align-self: flex-start; }
.dfm-nav__list { list-style: none; border-left: 2px solid var(--border); }
.dfm-nav__item { padding: 10px 0 10px 20px; font-size: 14px; font-weight: 500; color: var(--text-light); cursor: pointer; transition: all 0.2s; border-left: 2px solid transparent; margin-left: -2px; }
.dfm-nav__item:hover, .dfm-nav__item.active { color: var(--accent); border-left-color: var(--accent); }
.dfm-content { flex: 1; }
.dfm-block { margin-bottom: 48px; padding-bottom: 48px; border-bottom: 1px solid var(--border); }
.dfm-block:last-child { border-bottom: none; }
.dfm-block__number { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; background: var(--accent); color: var(--white); border-radius: 50%; font-size: 16px; font-weight: 700; margin-bottom: 12px; }
.dfm-block h3 { font-size: 22px; font-weight: 700; color: var(--primary); margin-bottom: 12px; }
.dfm-block p { font-size: 15px; color: var(--text-dark); line-height: 1.8; margin-bottom: 12px; }
.dfm-block__highlight { background: #eef5fd; border-left: 4px solid var(--accent); padding: 16px 20px; border-radius: 0 6px 6px 0; margin: 16px 0; }
.dfm-block__highlight p { color: var(--primary); font-size: 14px; margin: 0; }
.dfm-block__link { display: inline-flex; align-items: center; gap: 6px; color: var(--accent); font-size: 14px; font-weight: 500; transition: gap 0.2s; }
.dfm-block__link:hover { gap: 10px; }
.dfm-visual { display: flex; gap: 24px; margin-top: 20px; }
.dfm-visual__card { flex: 1; background: var(--white); border: 1px solid var(--border); border-radius: 6px; padding: 20px; }
.dfm-visual__card h4 { font-size: 15px; font-weight: 600; color: var(--primary); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.dfm-visual__card h4 .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dfm-visual__card p { font-size: 13px; color: var(--text-light); line-height: 1.7; }
.dfm-block__image { margin-top: 16px; border-radius: 6px; overflow: hidden; border: 1px solid var(--border); }
.dfm-block__image img { width: 100%; height: auto; display: block; }
.dfm-block__image--caption { font-size: 12px; color: var(--text-light); text-align: center; padding: 8px 0 0; }
.dfm-nav__item.active { background: var(--accent); color: var(--white); }
/* removed: .nav-links .menu-item-mega was incorrectly hiding nav items */

/* ============================================
Page-specific: vdi-3400-texture-card
============================================ */
.product-hero { max-width: 1240px; margin: 0 auto; padding: 60px 24px; display: flex; gap: 48px; align-items: flex-start; }
.product-hero__gallery { flex: 1; max-width: 560px; }
.product-hero__main-img { width: 100%; border-radius: 8px; border: 1px solid var(--border); margin-bottom: 12px; }
.product-hero__thumbs { display: flex; gap: 8px; }
.product-hero__thumb { width: 72px; height: 72px; border-radius: 4px; border: 2px solid var(--border); object-fit: cover; cursor: pointer; transition: border-color 0.2s; }
.product-hero__thumb:hover, .product-hero__thumb.active { border-color: var(--accent); }
.product-hero__info { flex: 1; }
.product-hero__badge { display: inline-block; background: #e8f4fd; color: var(--accent); padding: 4px 12px; border-radius: 4px; font-size: 12px; font-weight: 600; text-transform: uppercase; margin-bottom: 12px; }
.product-hero__title { font-size: 32px; font-weight: 700; color: var(--primary); margin-bottom: 8px; line-height: 1.2; }
.product-hero__subtitle { font-size: 16px; color: var(--text-light); margin-bottom: 20px; }
.product-hero__desc { font-size: 15px; color: var(--text-dark); margin-bottom: 24px; line-height: 1.7; }
.product-hero__specs { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 28px; }
.spec-item { display: flex; align-items: center; gap: 10px; padding: 12px; background: var(--bg-light); border-radius: 6px; }
.spec-item__icon { width: 36px; height: 36px; background: var(--accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 14px; flex-shrink: 0; }
.spec-item__label { font-size: 12px; color: var(--text-light); }
.spec-item__value { font-size: 14px; font-weight: 600; color: var(--text-dark); }
.product-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.section--light { background: var(--bg-light); }
.section__title { font-size: 32px; font-weight: 700; color: var(--primary); margin-bottom: 12px; }
.section--dark .section__title { color: #fff; }
.section__subtitle { font-size: 16px; color: var(--text-light); max-width: 640px; margin: 0 auto; }
.section--dark .section__subtitle { color: rgba(255,255,255,0.7); }
.section__inner { max-width: 1240px; margin: 0 auto; }
.plaque-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.plaque-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; transition: transform 0.2s, box-shadow 0.2s; }
.plaque-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.plaque-card__img { width: 100%; height: 180px; object-fit: cover; background: var(--bg-light); }
.plaque-card__body { padding: 16px; }
.plaque-card__label { font-size: 13px; font-weight: 700; color: var(--accent); margin-bottom: 4px; }
.plaque-card__text { font-size: 14px; color: var(--text-dark); }
.plaque-card__vdis { font-size: 13px; color: var(--text-light); margin-top: 6px; }
.material-tag__name { font-size: 14px; font-weight: 600; color: var(--primary); }
.material-tag__detail { font-size: 12px; color: var(--text-light); margin-top: 2px; }
.matter-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.matter-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.matter-card__img { width: 100%; height: 200px; object-fit: cover; }
.matter-card__body { padding: 20px; }
.matter-card__title { font-size: 16px; font-weight: 700; color: var(--primary); margin-bottom: 8px; }
.matter-card__text { font-size: 14px; color: var(--text-light); margin-bottom: 12px; line-height: 1.6; }
.matter-card__link { color: var(--accent); font-weight: 600; font-size: 14px; }
.stat-item { text-align: center; }
.stat-item__num { font-size: 36px; font-weight: 700; color: var(--accent); }
.stat-item__label { font-size: 14px; color: var(--text-light); margin-top: 4px; }
.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.testimonial-card__quote { font-size: 14px; color: var(--text-dark); font-style: italic; line-height: 1.7; margin-bottom: 16px; }
.testimonial-card__author { font-size: 14px; font-weight: 600; color: var(--primary); }
.testimonial-card__role { font-size: 12px; color: var(--text-light); }
.testimonial-card__company { font-size: 12px; color: var(--accent); }
.custom-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.custom-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 24px; text-align: center; }
.custom-card__icon { width: 48px; height: 48px; margin: 0 auto 12px; background: #e8f4fd; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; }
.custom-card__title { font-size: 16px; font-weight: 600; color: var(--primary); margin-bottom: 8px; }
.custom-card__text { font-size: 14px; color: var(--text-light); }
.cta-banner__text { font-size: 16px; color: rgba(255,255,255,0.7); margin-bottom: 24px; }
.plaque-grid, .matter-grid, .testimonial-grid, .custom-grid { grid-template-columns: 1fr; }

/* ============================================
Page-specific: spi-surface-finish-card
============================================ */
.spi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.spi-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 16px; text-align: center; }
.spi-card__grade { font-size: 18px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
.spi-card__ra { font-size: 13px; color: var(--accent); font-weight: 600; }
.spi-card__method { font-size: 12px; color: var(--text-light); margin-top: 4px; }
.spi-card__category { font-size: 11px; color: #fff; background: var(--primary); display: inline-block; padding: 2px 8px; border-radius: 3px; margin-top: 6px; }

/* ============================================
Page-specific: mt-texture-plates
============================================ */
.mt-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.mt-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 32px; transition: transform 0.2s, box-shadow 0.2s; }
.mt-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.mt-card__icon { width: 48px; height: 48px; background: #e8f4fd; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 16px; }
.mt-card__title { font-size: 18px; font-weight: 700; color: var(--primary); margin-bottom: 8px; }
.mt-card__sub { font-size: 14px; color: var(--accent); font-weight: 600; margin-bottom: 8px; }
.mt-card__text { font-size: 14px; color: var(--text-light); line-height: 1.6; }
.mt-card__features { list-style: none; padding: 0; margin-top: 12px; }
.mt-card__features li { padding: 4px 0; font-size: 13px; color: var(--text-dark); display: flex; align-items: center; gap: 8px; }
.mt-card__features li::before { content: ''; width: 6px; height: 6px; background: var(--accent); border-radius: 50%; flex-shrink: 0; }

/* ============================================
Page-specific: metal-vdi-spi-plates
============================================ */
.plate-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.plate-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 24px; transition: transform 0.2s, box-shadow 0.2s; }
.plate-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.plate-card__badge { display: inline-block; background: #e8f4fd; color: var(--accent); padding: 2px 10px; border-radius: 3px; font-size: 11px; font-weight: 600; margin-bottom: 10px; }
.plate-card__title { font-size: 16px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
.plate-card__sub { font-size: 13px; color: var(--accent); font-weight: 600; margin-bottom: 10px; }
.plate-card__text { font-size: 14px; color: var(--text-light); line-height: 1.6; }
.plate-card__specs { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); display: flex; flex-wrap: wrap; gap: 8px; }
.plate-card__spec { font-size: 12px; background: var(--bg-light); padding: 3px 8px; border-radius: 3px; color: var(--text-dark); }

/* ============================================
Page-specific: texture-books
============================================ */
.book-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
.book-card { background: #fff; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; display: flex; gap: 24px; padding: 28px; transition: transform 0.2s, box-shadow 0.2s; }
.book-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.book-card__img { width: 180px; height: 140px; object-fit: cover; border-radius: 4px; flex-shrink: 0; background: var(--bg-light); }
.book-card__body { flex: 1; }
.book-card__badge { display: inline-block; padding: 2px 10px; border-radius: 3px; font-size: 11px; font-weight: 600; margin-bottom: 8px; }
.book-card__badge--value { background: #e8f4fd; color: var(--accent); }
.book-card__badge--premium { background: #fff3e0; color: #e65100; }
.book-card__badge--more { background: #e8f5e9; color: #2e7d32; }
.book-card__title { font-size: 18px; font-weight: 700; color: var(--primary); margin-bottom: 6px; }
.book-card__text { font-size: 14px; color: var(--text-light); line-height: 1.6; margin-bottom: 12px; }
.book-card__features { list-style: none; padding: 0; }
.book-card__features li { font-size: 13px; color: var(--text-dark); padding: 3px 0; display: flex; align-items: center; gap: 6px; }
.book-card__features li::before { content: ''; width: 5px; height: 5px; background: var(--accent); border-radius: 50%; flex-shrink: 0; }

/* ============================================
Page-specific: pricing-guide
============================================ */
.page-hero__inner { max-width: 900px; margin: 0 auto; text-align: center; }
.pricing-intro { max-width: 900px; margin: 0 auto; padding: 60px 24px; }
.pricing-intro p { font-size: 16px; line-height: 1.8; color: #475569; margin-bottom: 16px; }
.price-examples { background: #f5f7fa; padding: 60px 24px; }
.price-examples__inner { max-width: 1100px; margin: 0 auto; }
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.price-card { background: #fff; border-radius: 6px; overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,0.06); transition: transform 0.2s, box-shadow 0.2s; }
.price-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.price-card__img { width: 100%; height: 200px; object-fit: cover; }
.price-card__body { padding: 24px; }
.price-card__label { display: inline-block; background: #eef4ff; color: #2a7de1; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; padding: 4px 10px; border-radius: 4px; margin-bottom: 12px; }
.price-card__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.price-stat { background: #f8fafc; border-radius: 6px; padding: 12px; text-align: center; }
.price-stat__value { font-size: 20px; font-weight: 700; color: #0d2b4e; }
.price-stat__value span { font-size: 13px; font-weight: 400; color: #64748b; }
.price-stat__label { font-size: 11px; color: #64748b; margin-top: 2px; }
.price-card__details { display: flex; flex-wrap: wrap; gap: 6px; }
.price-detail { font-size: 12px; background: #f1f5f9; color: #475569; padding: 4px 10px; border-radius: 4px; }
.factors-section { padding: 80px 24px; max-width: 1100px; margin: 0 auto; }
.factors-intro { max-width: 700px; margin: 0 auto 48px; text-align: center; }
.factors-intro p { font-size: 16px; color: #475569; line-height: 1.7; }
.factors-list { list-style: none; display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-bottom: 16px; }
.factors-list li { background: #2a7de1; color: #fff; font-size: 13px; font-weight: 600; padding: 8px 18px; border-radius: 20px; }
.factor-block { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; margin-bottom: 64px; padding-bottom: 64px; border-bottom: 1px solid #e2e8f0; }
.factor-block:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.factor-block:nth-child(even) .factor-content { order: 2; }
.factor-block:nth-child(even) .factor-visual { order: 1; }
.factor-num { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; background: #2a7de1; color: #fff; border-radius: 50%; font-size: 16px; font-weight: 700; margin-bottom: 12px; }
.factor-content h3 { font-size: 26px; font-weight: 700; color: #0d2b4e; margin-bottom: 12px; }
.factor-content p { font-size: 15px; color: #475569; line-height: 1.7; margin-bottom: 16px; }
.factor-highlight { background: #fffbeb; border-left: 4px solid #f5762a; padding: 14px 18px; border-radius: 0 6px 6px 0; font-size: 14px; color: #92400e; line-height: 1.6; }
.factor-visual img { width: 100%; border-radius: 6px; box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.material-bar { margin-top: 20px; }
.material-bar__item { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.material-bar__name { width: 50px; font-size: 13px; font-weight: 600; color: #0d2b4e; text-align: right; }
.material-bar__track { flex: 1; height: 24px; background: #f1f5f9; border-radius: 4px; overflow: hidden; position: relative; }
.material-bar__fill { height: 100%; border-radius: 4px; display: flex; align-items: center; justify-content: flex-end; padding-right: 8px; font-size: 11px; font-weight: 600; color: #fff; }
.material-bar__fill.lcp { width: 90%; background: #dc2626; }
.material-bar__fill.pa { width: 68%; background: #f5762a; }
.material-bar__fill.pc { width: 55%; background: #eab308; }
.material-bar__fill.pp { width: 25%; background: #22c55e; }
.material-bar__fill.abs { width: 30%; background: #2a7de1; }
.mold-life-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 20px; }
.mold-life-item { text-align: center; padding: 16px 8px; border-radius: 6px; border: 2px solid #e2e8f0; transition: border-color 0.2s; }
.mold-life-item:hover { border-color: #2a7de1; }
.mold-life-item__name { font-size: 15px; font-weight: 700; color: #0d2b4e; margin-bottom: 4px; }
.mold-life-item__shots { font-size: 12px; color: #64748b; }
.mold-life-item__type { font-size: 11px; color: #2a7de1; font-weight: 600; margin-top: 4px; }
.mold-life-item.h13 { border-color: #dc2626; }
.mold-life-item.nak80 { border-color: #f5762a; }
.mold-life-item.p718h { border-color: #eab308; }
.mold-life-item.p20 { border-color: #22c55e; }
.color-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.color-tag { display: flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; font-size: 13px; font-weight: 500; border: 1px solid #e2e8f0; }
.color-dot { width: 12px; height: 12px; border-radius: 50%; border: 1px solid rgba(0,0,0,0.1); }
.color-tag.expensive { background: #fef2f2; border-color: #fecaca; color: #991b1b; }

/* ============================================
Page-specific: injection-molding-materials
============================================ */
*,*::before,*::after { box-sizing:border-box;margin:0;padding:0 }
.hero-download { display:inline-flex;align-items:center;gap:8px;background:#f5762a;color:#fff;padding:14px 32px;border-radius:6px;font-weight:600;font-size:15px;transition:background .2s;margin-top:16px }
.hero-download:hover { background:#e5641a;text-decoration:none;color:#fff }
.intro-section { padding:60px 0 40px;background:#f5f7fa }
.intro-image { flex:0 0 420px;border-radius:6px;overflow:hidden }
.intro-image img { width:100%;height:auto;display:block }
.materials-section { padding:60px 0 }
.section-header h2 { font-size:32px;font-weight:700;color:#0d2b4e;margin-bottom:12px }
.section-header p { font-size:16px;color:#64748b;max-width:600px;margin:0 auto }
.material-card { background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:28px;display:flex;gap:20px;transition:all .2s }
.material-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.08);transform:translateY(-2px) }
.material-img { flex:0 0 140px;border-radius:6px;overflow:hidden }
.material-img img { width:100%;height:120px;object-fit:cover;display:block }
.material-info { flex:1 }
.material-info h3 { font-size:18px;font-weight:700;color:#0d2b4e;margin-bottom:2px }
.material-info .full-name { font-size:13px;color:#2a7de1;font-weight:500;margin-bottom:10px }
.material-info p { font-size:14px;color:#64748b;line-height:1.7;margin-bottom:10px }
.learn-more { display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:#2a7de1 }
.learn-more:hover { text-decoration:none;color:#1a6dd1 }
.list-section { padding:60px 0;background:#f5f7fa }
.list-section h2 { font-size:28px;font-weight:700;color:#0d2b4e;text-align:center;margin-bottom:32px }
.properties-section { padding:60px 0 }
.properties-section h2 { font-size:28px;font-weight:700;color:#0d2b4e;text-align:center;margin-bottom:32px }
.props-table { width:100%;border-collapse:collapse;font-size:14px }
.props-table th { background:#0d2b4e;color:#fff;padding:12px 16px;text-align:left;font-weight:600;white-space:nowrap }
.props-table td { padding:10px 16px;border-bottom:1px solid #e2e8f0 }
.props-table tr:hover td { background:#f5f7fa }
.props-table .mat-name { font-weight:600;color:#0d2b4e }
.bar-cell { display:flex;align-items:center;gap:8px }
.bar { height:8px;border-radius:4px;background:#2a7de1;min-width:4px }
.bar-label { font-size:12px;color:#64748b;min-width:32px }
.props-table th,.props-table td { padding:8px 10px }

/* ============================================
Page-specific: micro-injection-molding
============================================ */
.nav a, .nav .menu-item-mega > a { font-size: 14px; font-weight: 500; color: #1e293b; transition: color 0.2s; }
.nav a:hover, .nav .menu-item-mega > a:hover { color: #2a7de1; }
.service-hero-inner { max-width: 1200px; margin: 0 auto; }
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.stat-card .stat-unit { font-size: 16px; font-weight: 500; opacity: 0.85; }
.micro-comparison { padding: 80px 24px; background: #fff; }
.section-inner { max-width: 1200px; margin: 0 auto; }
.section-desc { font-size: 16px; color: #64748b; text-align: center; max-width: 640px; margin: 0 auto 48px; }
.comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.comparison-card { border: 1px solid #e2e8f0; border-radius: 6px; overflow: hidden; transition: box-shadow 0.3s; }
.comparison-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.comparison-card img { width: 100%; height: 240px; object-fit: cover; }
.comparison-card-body { padding: 24px; }
.comparison-card h3 { font-size: 20px; font-weight: 700; color: #0d2b4e; margin-bottom: 12px; }
.comparison-card .tag { display: inline-block; font-size: 12px; font-weight: 600; padding: 4px 12px; border-radius: 4px; margin-bottom: 12px; }
.tag-micro { background: #e8f4ff; color: #2a7de1; }
.tag-traditional { background: #f0f0f0; color: #64748b; }
.comparison-card ul { list-style: none; padding: 0; }
.comparison-card ul li { padding: 6px 0; font-size: 14px; color: #1e293b; display: flex; align-items: flex-start; gap: 8px; }
.comparison-card ul li::before { content: ''; display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin-top: 8px; flex-shrink: 0; }
.tag-micro + ul li::before { background: #2a7de1; }
.tag-traditional + ul li::before { background: #94a3b8; }
.industries { padding: 80px 24px; background: #f5f7fa; }
.industry-card:hover { border-color: #2a7de1; box-shadow: 0 4px 16px rgba(42,125,225,0.1); transform: translateY(-2px); }
.industry-icon { width: 48px; height: 48px; margin: 0 auto 12px; background: #e8f4ff; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.industry-icon svg { width: 24px; height: 24px; color: #2a7de1; }
.industry-card h4 { font-size: 14px; font-weight: 600; color: #0d2b4e; line-height: 1.3; }
.materials { padding: 80px 24px; background: #fff; }
.materials-intro { text-align: center; margin-bottom: 48px; }
.materials-intro span { color: #2a7de1; font-weight: 700; }
.material-card img { width: 100%; height: 120px; object-fit: cover; }
.material-card-body { padding: 12px; text-align: center; }
.material-card h4 { font-size: 16px; font-weight: 700; color: #0d2b4e; }
.material-card p { font-size: 12px; color: #64748b; margin-top: 4px; }

/* ============================================
Page-specific: silicone-molding
============================================ */
.menu-item-mega.mega-open .mega-menu,
.menu-item-mega:hover .mega-menu { display: flex; }
.quick-nav__inner { display:flex; gap:0; }
.quick-nav__tab { padding:16px 28px; font-size:15px; font-weight:600; color:var(--color-text-light); border-bottom:3px solid transparent; cursor:pointer; transition:all 0.2s; text-decoration:none; }
.quick-nav__tab:hover, .quick-nav__tab.active { color:var(--color-accent); border-bottom-color:var(--color-accent); }
.part-card__image { height:220px; overflow:hidden; background:var(--color-bg-light); display:flex; align-items:center; justify-content:center; }
.part-card__image img { width:100%; height:100%; object-fit:cover; }
.part-card__body { padding:20px; }
.part-card__title { font-size:17px; font-weight:600; color:var(--color-primary); margin-bottom:6px; }
.part-card__desc { font-size:14px; color:var(--color-text-light); line-height:1.6; }
.parts-more { text-align:center; margin-top:32px; font-size:16px; color:var(--color-text-light); font-weight:500; }
.material-card__abbr { font-size:28px; font-weight:700; color:var(--color-accent); margin-bottom:8px; }
.material-card__name { font-size:14px; font-weight:600; color:var(--color-primary); margin-bottom:6px; }
.material-card__desc { font-size:13px; color:var(--color-text-light); line-height:1.5; }
.process-section { background:var(--color-primary); color:#fff; }
.process-section .section__title { color:#fff; }
.process-section .section__subtitle { color:rgba(255,255,255,0.7); }
.process-card__icon { margin-bottom:16px; }
.process-card__icon svg { width:40px; height:40px; }
.report-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.report-card { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.06); transition:transform 0.2s; }
.report-card:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,0.1); }
.report-card__image { height:200px; overflow:hidden; background:var(--color-bg-light); display:flex; align-items:center; justify-content:center; padding:16px; }
.report-card__image img { width:100%; height:100%; object-fit:contain; }
.report-card__body { padding:20px; }
.report-card__title { font-size:17px; font-weight:600; color:var(--color-primary); margin-bottom:6px; }
.report-card__desc { font-size:14px; color:var(--color-text-light); line-height:1.6; }
@media (max-width:1024px) { .service-hero__grid { grid-template-columns:1fr; gap:32px; } }
@media (max-width:768px) { .service-hero__title { font-size:28px; }
.parts-grid, .materials-grid, .process-grid, .report-grid { grid-template-columns:1fr; } }

/* ============================================
Page-specific: blow-molding
============================================ */

.service-hero .container { position:relative; z-index:2; }
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.hero-content h1 { font-size:42px; font-weight:700; line-height:1.2; margin-bottom:16px; }
.hero-content h1 span { color:var(--color-cta); }
.hero-desc { font-size:17px; line-height:1.7; color:rgba(255,255,255,0.9); margin-bottom:24px; }
.hero-tags { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.hero-tag { background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.25); padding:6px 16px; border-radius:20px; font-size:13px; font-weight:500; color:#fff; }
.hero-btns { display:flex; gap:16px; }
.hero-image img { border-radius:8px; box-shadow:0 20px 50px rgba(0,0,0,0.3); width:100%; height:320px; object-fit:cover; }
.quick-nav a:hover, .quick-nav a.active { color:var(--color-accent); border-bottom-color:var(--color-accent); }
.section--dark .section-title { color:#fff; }
.section--dark .section-subtitle { color:rgba(255,255,255,0.75); }
.product-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.product-card img { width:100%; height:200px; object-fit:cover; }
.product-card-body { padding:20px; }
.product-card-body h3 { font-size:16px; font-weight:700; color:var(--color-primary); margin-bottom:6px; }
.product-card-body p { font-size:14px; color:var(--color-text-light); line-height:1.5; }
.material-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.material-card .mat-abbr { font-size:24px; font-weight:700; color:var(--color-primary); margin-bottom:6px; }
.material-card .mat-full { font-size:12px; color:var(--color-text-light); line-height:1.4; }
.logo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.logo-card { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.logo-card img { width:100%; height:220px; object-fit:cover; }
.logo-card-body { padding:20px; text-align:center; }
.logo-card-body h3 { font-size:16px; font-weight:700; color:var(--color-primary); margin-bottom:6px; }
.logo-card-body p { font-size:14px; color:var(--color-text-light); }
.process-card h3 { font-size:18px; font-weight:700; color:#fff; margin-bottom:10px; }
.process-card p { font-size:14px; color:rgba(255,255,255,0.75); line-height:1.6; }
.process-card .process-icon { font-size:32px; margin-bottom:12px; }
.footer-about .footer-logo { display:flex; align-items:center; gap:8px; font-size:20px; font-weight:700; color:#fff; margin-bottom:16px; }
.footer-about .footer-logo .logo-icon { display:flex; gap:3px; }
.footer-about .footer-logo .logo-icon span { width:8px; height:8px; background:var(--color-accent); border-radius:2px; }
.hero-image { display:none; }

/* ============================================
Page-specific: vacuum-forming
============================================ */
.section-header .section-divider { margin-left:auto; margin-right:auto; }

/* ============================================
Page-specific: about
============================================ */
html { scroll-behavior: smooth; }
.logo-icon span { width: 8px; height: 8px; background: var(--color-accent); border-radius: 2px; }
.logo-icon span:nth-child(2) { background: var(--color-primary); }
.page-hero .divider { width: 60px; height: 3px; background: var(--color-accent); margin: 20px auto 0; border-radius: 2px; }
.section__header .divider { width: 60px; height: 3px; background: var(--color-accent); margin: 16px auto 0; border-radius: 2px; }
.section--dark .section__header .divider { background: rgba(255,255,255,0.5); }
.two-col--reverse { direction: rtl; }
.two-col--reverse > * { direction: ltr; }
.two-col img { border-radius: 6px; width: 100%; height: 320px; object-fit: cover; }
.two-col h3 { font-size: 24px; font-weight: 700; margin-bottom: 12px; }
.two-col p { color: var(--color-text-light); margin-bottom: 16px; line-height: 1.8; }
.quality-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.quality-card { background: var(--color-white); border-radius: 6px; padding: 32px 24px;
box-shadow: 0 2px 12px rgba(0,0,0,0.06); transition: transform 0.2s, box-shadow 0.2s; }
.quality-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.quality-card__icon { width: 48px; height: 48px; border-radius: 8px; background: rgba(42,125,225,0.1);
display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.quality-card__icon svg { width: 24px; height: 24px; color: var(--color-accent); }
.quality-card h3 { font-size: 18px; font-weight: 600; margin-bottom: 8px; }
.quality-card p { font-size: 14px; color: var(--color-text-light); line-height: 1.7; }
.cert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cert-card { background: rgba(255,255,255,0.08); border-radius: 6px; padding: 32px 24px;
text-align: center; border: 1px solid rgba(255,255,255,0.1); }
.cert-card__icon { font-size: 36px; margin-bottom: 12px; }
.cert-card h3 { font-size: 18px; font-weight: 600; margin-bottom: 4px; }
.cert-card p { font-size: 13px; color: rgba(255,255,255,0.6); }
.timeline { max-width: 700px; margin: 0 auto; position: relative; padding-left: 40px; }
.timeline::before { content: ''; position: absolute; left: 15px; top: 0; bottom: 0; width: 2px; background: var(--color-border); }
.timeline-item { position: relative; margin-bottom: 32px; }
.timeline-item::before { content: ''; position: absolute; left: -33px; top: 4px;
width: 12px; height: 12px; border-radius: 50%;
background: var(--color-accent); border: 3px solid var(--color-white);
box-shadow: 0 0 0 2px var(--color-accent); }
.timeline-item h3 { font-size: 18px; font-weight: 600; margin-bottom: 4px; }
.timeline-item p { font-size: 14px; color: var(--color-text-light); line-height: 1.7; }

/* ============================================
Page-specific: contact
============================================ */
.page-header { background: var(--color-primary); padding: 80px 24px 60px; text-align: center; }
.page-header h1 { font-size: 40px; font-weight: 700; color: #fff; margin-bottom: 12px; }
.page-header p { font-size: 17px; color: rgba(255,255,255,0.75); max-width: 600px; margin: 0 auto; }
.contact-page { max-width: 1200px; margin: 0 auto; padding: 64px 24px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.contact-form h2, .contact-info h2 { font-size: 24px; font-weight: 700; margin-bottom: 8px; }
.contact-form p.subtitle, .contact-info p.subtitle { font-size: 15px; color: var(--color-text-light); margin-bottom: 32px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form input, .contact-form textarea, .contact-form select { width: 100%; padding: 12px 16px; border: 1px solid var(--color-border); border-radius: var(--radius); font-size: 15px; margin-bottom: 16px; font-family: inherit; background: #fff; }
.contact-form textarea { min-height: 150px; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(42,125,225,0.1); }
.contact-form button { padding: 14px 40px; background: var(--color-cta); color: #fff; border: none; border-radius: var(--radius); font-size: 16px; font-weight: 600; cursor: pointer; transition: all 150ms; }
.contact-form button:hover { background: #e0651f; transform: translateY(-1px); }
.contact-info-list { list-style: none; padding: 0; }
.contact-info-list li { padding: 20px 0; border-bottom: 1px solid var(--color-border); display: flex; gap: 16px; align-items: flex-start; }
.contact-info-list li:last-child { border-bottom: none; }
.info-icon { width: 48px; height: 48px; background: var(--color-bg-light); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.info-icon svg { width: 22px; height: 22px; }
.info-content h4 { margin: 0 0 4px; font-size: 15px; color: var(--color-text); font-weight: 600; }
.info-content p { margin: 0; font-size: 14px; color: var(--color-text-light); line-height: 1.6; }
.info-content a { color: var(--color-accent); }
.info-content a:hover { text-decoration: underline; }
.contact-map { width: 100%; height: 200px; background: var(--color-bg-light); border-radius: var(--radius); margin-top: 32px; overflow: hidden; border: 1px solid var(--color-border); }
.contact-map iframe { width: 100%; height: 100%; border: 0; }
.footer-about h3, .footer-col h4 { color: #fff; margin-bottom: 16px; }
.footer-about h3 { font-size: 20px; }
.footer-col .parent-cat { font-weight: 600; color: #fff; margin-top: 12px; margin-bottom: 6px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; }
.footer-col .parent-cat:first-child { margin-top: 0; }
/* ============================================
   Mobile Responsive
   ============================================ */
@media (max-width: 992px) {
    .header-inner .btn, .header-inner .btn-cta { display: none; }
}

/* ============================================
   Missing utility classes
   ============================================ */
.btn-outline-dark { display:inline-block; padding:12px 28px; border:2px solid var(--color-primary); color:var(--color-primary); border-radius:var(--radius); font-weight:600; font-size:15px; text-decoration:none; transition:all .15s; }
.btn-outline-dark:hover { background:var(--color-primary); color:#fff; }
.fade-up { opacity:0; transform:translateY(30px); transition:opacity .6s ease-out,transform .6s ease-out; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.faq-content { padding: 24px 0; }
.faq-content[data-content] { display: none; }
.faq-content[data-content].active { display: block; }
.industry-card--even { background:#f8fafc; }
.industry-card__content { flex:1; }
.section--services { background:#fff; padding:80px 0; }
.section__header--light .section-subtitle { color:rgba(255,255,255,.7); }
.section__header--light .section-title { color:#fff; }
.section__header--light .section-desc { color:rgba(255,255,255,.8); }

/* ============================================
   Quick Quote Modal
   ============================================ */
.quote-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.55);z-index:9998;justify-content:center;align-items:center}
.quote-modal__overlay{position:absolute;top:0;left:0;width:100%;height:100%}
.quote-modal__container{background:#fff;border-radius:8px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;position:relative;animation:qqSlideIn .3s ease-out;box-shadow:0 20px 60px rgba(0,0,0,.25);padding:32px}
@keyframes qqSlideIn{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.quote-modal__close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#64748b;transition:color .15s}
.quote-modal__close:hover{color:#1e293b}
.quote-modal h2{font-size:24px;color:var(--color-primary);margin-bottom:4px}
.quote-modal__subtitle{font-size:14px;color:var(--color-text-light);margin-bottom:24px}
.quote-modal__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quote-modal__field{margin-bottom:16px}
.quote-modal__field label{display:block;font-size:13px;font-weight:600;color:#1e293b;margin-bottom:6px}
.quote-modal__field .required{color:var(--color-cta)}
.quote-modal__field input,.quote-modal__field select,.quote-modal__field textarea{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:inherit;color:var(--color-text-dark);transition:border-color .15s;background:#fff}
.quote-modal__field input:focus,.quote-modal__field select:focus,.quote-modal__field textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(42,125,225,.1)}
.quote-modal__field textarea{resize:vertical;min-height:80px}
.quote-modal__submit{width:100%;padding:12px;background:var(--color-cta);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}
.quote-modal__submit:hover{background:#e0661a}
.quote-modal__success{display:none;text-align:center;padding:32px 0}
.quote-modal__success svg{margin-bottom:16px}
.quote-modal__success h3{font-size:18px;font-weight:700;color:var(--color-primary);margin-bottom:8px}
.quote-modal__success p{font-size:14px;color:var(--color-text-light)}
@media(max-width:600px){.quote-modal__row{grid-template-columns:1fr}.quote-modal__container{width:95%;padding:20px}}
