/* ══════════════════════════════════════
   NewSeed — Flatco Child Theme CSS
   ══════════════════════════════════════ */

:root {
    --dark: #1a1e32;
    --dark-lighter: #252a42;
    --accent: #99cc00;
    --accent-hover: #88b800;
    --text: #444444;
    --text-light: #666666;
    --text-muted: #999999;
    --border: #e0e0e0;
    --bg-gray: #f0f0f2;
    --white: #ffffff;
    --black: #000000;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { overflow-x: hidden; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Arial, sans-serif; color: var(--text); line-height: 1.7; background: var(--white); font-size: 16px; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }

/* ══════ HEADER ══════ */
.header-top { background: var(--dark); border-bottom: 1px solid rgba(255,255,255,0.08); }
.header-top-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: flex; align-items: center; height: 36px; justify-content: flex-end; gap: 24px; }
.header-top-inner a { font-size: 12px; color: rgba(255,255,255,0.6); transition: color .2s; }
.header-top-inner a:hover { color: #fff; }
.search-icon { color: rgba(255,255,255,0.5); cursor: pointer; transition: color .2s; display: flex; align-items: center; }
.search-icon:hover { color: #fff; }

/* Search Panel */
.search-panel { position: fixed; top: 0; left: 0; right: 0; background: var(--bg-gray); z-index: 1001; transform: translateY(-100%); transition: transform .35s ease; box-shadow: 0 4px 20px rgba(0,0,0,0.1); padding: 96px 0 48px; }
.search-panel.active { transform: translateY(0); }
.search-panel-header { position: absolute; top: 0; left: 0; right: 0; height: 96px; background: var(--dark); display: flex; align-items: center; }
.search-panel-header-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; width: 100%; display: flex; align-items: center; justify-content: space-between; }
.search-panel-logo { font-size: 18px; font-weight: 700; letter-spacing: 1px; color: #fff; }
.search-panel-close { width: 40px; height: 40px; border-radius: 50%; background: var(--accent); border: none; color: var(--dark); font-size: 20px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; }
.search-panel-close:hover { background: var(--accent-hover); }
.search-panel-inner { max-width: 1440px; margin: 0 auto; padding: 40px 60px 0; }
.search-panel-bar { display: flex; align-items: center; background: #fff; border-radius: 40px; padding: 6px 6px 6px 32px; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
.search-panel-bar input { border: none; background: none; outline: none; font-size: 18px; color: var(--text); width: 100%; font-family: inherit; padding: 12px 0; }
.search-panel-bar input::placeholder { color: var(--text-muted); }
.search-panel-submit { width: 48px; height: 48px; border-radius: 50%; background: var(--dark); border: none; color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; flex-shrink: 0; }
.search-panel-submit:hover { background: var(--accent); color: var(--dark); }

/* Hamburger */
.hamburger { display: none; background: none; border: none; cursor: pointer; padding: 4px; color: #fff; }
.hamburger svg { display: block; }
.nav-close-wrap { display: none; }
.nav-close { display: none; }

.header-main { background: var(--dark); }
.header-main-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: flex; align-items: center; height: 60px; justify-content: space-between; }
.logo { font-size: 18px; font-weight: 700; letter-spacing: 1px; color: #fff; text-decoration: none; }
.nav { display: flex; align-items: center; gap: 32px; list-style: none; }
.nav a { color: rgba(255,255,255,0.75); font-size: 14px; font-weight: 400; transition: color .2s; }
.nav a:hover { color: #fff; }
.nav a.active { color: #fff; }
.btn-contact-header { display: inline-flex; align-items: center; gap: 10px; border: 1px solid rgba(255,255,255,0.3); color: #fff !important; padding: 10px 26px; border-radius: 28px; font-size: 16px; font-weight: 400; transition: all .3s; background: transparent; }
.btn-contact-header svg { width: 16px; height: 16px; transition: all .3s; }
.btn-contact-header:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-contact-header:hover svg { transform: translateX(3px); }

/* ══════ HERO — Homepage ══════ */
.hero-home { background: var(--dark); padding: 80px 0 60px; position: relative; overflow: hidden; }
.hero-home-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.hero-home-left h1 { font-size: clamp(2.8rem, 2.5rem + 2.5vw, 4.2rem); font-weight: 700; line-height: 1.08; color: #fff; margin-bottom: 24px; }
.hero-home-left h1 span { color: var(--accent); }
.hero-home-desc { font-size: 18px; color: rgba(255,255,255,0.6); line-height: 1.8; margin-bottom: 40px; }
.hero-home-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.btn-outline-light { display: inline-flex; align-items: center; gap: 12px; background: transparent; color: #fff; padding: 16px 36px; border: 1.5px solid rgba(255,255,255,0.3); border-radius: 28px; font-size: 17px; font-weight: 400; cursor: pointer; text-decoration: none; font-family: inherit; transition: all .3s; }
.btn-outline-light:hover { border-color: #fff; background: rgba(255,255,255,0.05); }
.btn-outline-light svg { width: 18px; height: 18px; transition: all .3s; }
.btn-outline-light:hover svg { transform: translateX(4px); }
.hero-home-right { align-self: end; }
.hero-home-right img { width: 100%; height: auto; display: block; object-fit: cover; max-height: 520px; }

/* Hero Stats Bar */
.hero-stats-bar { background: var(--dark); border-top: 1px solid rgba(255,255,255,0.08); }
.hero-stats { max-width: 1440px; margin: 0 auto; padding: 40px 60px; display: flex; gap: 80px; }
.hero-stat-number { font-size: 32px; font-weight: 700; color: var(--accent); line-height: 1.2; }
.hero-stat-label { font-size: 13px; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }

/* Section Header (shared) */
.section-header { margin-bottom: 48px; }
.section-header h2 { font-size: 36px; font-weight: 600; color: var(--black); margin-bottom: 12px; }
.section-header p { font-size: 17px; color: var(--text-light); max-width: 560px; line-height: 1.7; }

/* ══════ HOW WE WORK ══════ */
.how-section { background: var(--bg-gray); padding: 96px 0; }
.how-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.how-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.how-item { background: var(--white); padding: 40px 32px; border: 1px solid var(--border); border-radius: 14px; transition: all .3s; }
.how-item:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.06); }
.how-icon { width: 88px; height: 88px; background: rgba(153,204,0,0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 24px; }
.how-icon svg { width: 40px; height: 40px; color: var(--accent); }
.how-item h3 { font-size: 18px; font-weight: 700; color: var(--black); margin-bottom: 10px; }
.how-item p { font-size: 15px; color: var(--text-light); line-height: 1.75; }

/* ══════ HERO — Shared Base ══════ */
.hero { background: var(--dark); padding: 56px 0 64px; }
.btn-accent { display: inline-flex; align-items: center; gap: 12px; background: var(--accent); color: #fff; padding: 16px 36px; border: none; font-size: 17px; font-weight: 400; cursor: pointer; text-decoration: none; font-family: inherit; transition: all .3s; border-radius: 28px; }
.btn-accent svg { width: 22px; height: 22px; transition: all .3s; stroke-width: 1.5; }
.btn-accent:hover { background: var(--accent-hover); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(153,204,0,0.3); }
.btn-accent:hover svg { transform: translateX(4px); }

/* ══════ HERO — Single Product (2-col with card) ══════ */
.hero.single-product { padding: 56px 0 64px; }
.hero.single-product .hero-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 340px; gap: 80px; align-items: start; }
.hero.single-product .hero-left h1 { font-size: clamp(2.2rem, 2rem + 1.5vw, 3.2rem); font-weight: 700; line-height: 1.12; color: #fff; margin-bottom: 20px; }
.hero.single-product .hero-desc { font-size: 16px; color: rgba(255,255,255,0.7) !important; line-height: 1.75; margin-bottom: 28px; }
.hero.single-product .hero-desc * { color: rgba(255,255,255,0.7) !important; }
.cert-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.cert-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; color: rgba(255,255,255,0.7); border: 1px solid rgba(255,255,255,0.15); padding: 5px 12px; }
.cert-badge svg { width: 13px; height: 13px; color: var(--accent); flex-shrink: 0; }

/* Hero Right — CAS Card */
.hero-card { background: var(--dark-lighter); border: 1px solid rgba(255,255,255,0.1); padding: 0; }
.hero-card-row { padding: 16px 24px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.hero-card-row:last-child { border-bottom: none; }
.hero-card-label { font-size: 11px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase; color: var(--accent); margin-bottom: 2px; }
.hero-card-value { font-size: 15px; font-weight: 600; color: #fff; }

/* ══════ HERO — Category Page (2-col with image) ══════ */
.hero.category-page { padding: 64px 0 0; }
.hero.category-page .hero-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.hero.category-page .hero-left { padding-bottom: 64px; }
.hero.category-page .hero-left h1 { font-size: clamp(2.4rem, 2rem + 2vw, 3.6rem); font-weight: 700; line-height: 1.1; color: #fff; margin-bottom: 24px; }
.hero.category-page .hero-desc { font-size: 16px; color: rgba(255,255,255,0.7); line-height: 1.8; margin-bottom: 32px; }
.hero-right { align-self: end; }
.hero-right img { width: 100%; height: auto; display: block; object-fit: cover; max-height: 420px; }
.hero-image-placeholder { width: 100%; aspect-ratio: 4/3; background: linear-gradient(145deg, #2a2f4a, #1e2238); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.3); font-size: 14px; }

/* ══════ HERO — Centered (Products Page, Blog) ══════ */
.hero.centered-hero { padding: 80px 0 88px; }
.hero.centered-hero .hero-inner { max-width: 820px; margin: 0 auto; padding: 0 60px; text-align: center; }
.hero.centered-hero .hero-inner h1 { font-size: clamp(2.4rem, 2rem + 2vw, 3.6rem); font-weight: 700; line-height: 1.1; color: #fff; margin-bottom: 20px; }
.hero.centered-hero .hero-desc { font-size: 17px; color: rgba(255,255,255,0.65); line-height: 1.8; margin-bottom: 32px; }

/* ══════ BREADCRUMB ══════ */
.breadcrumb-bar { background: var(--bg-gray); border-bottom: 1px solid var(--border); }
.breadcrumb-inner { max-width: 1440px; margin: 0 auto; padding: 14px 60px; font-size: 13px; color: var(--text-muted); }
.breadcrumb-inner a { color: var(--text-light); transition: color .2s; }
.breadcrumb-inner a:hover { color: var(--black); }
.breadcrumb-inner span { margin: 0 8px; color: var(--text-muted); }

/* ══════ SECTION NAV (Single Product) ══════ */
.section-nav { border-bottom: 1px solid var(--border); background: var(--white); position: sticky; top: 0; z-index: 100; }
.section-nav-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.section-nav ul { display: flex; gap: 0; list-style: none; }
.section-nav a { display: block; padding: 16px 20px 16px 0; font-size: 14px; color: var(--text-light); font-weight: 400; position: relative; margin-right: 12px; transition: color .2s; }
.section-nav a:hover { color: var(--black); }
.section-nav a.active { color: var(--black); font-weight: 500; }
.section-nav a.active::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 12px; height: 2px; background: var(--black); }

/* ══════ CONTENT (Single Product) ══════ */
.content-section { max-width: 1440px; margin: 0 auto; padding: 56px 48px; word-wrap: break-word; overflow-wrap: break-word; }
.content-row { display: grid; grid-template-columns: 200px 1fr; gap: 40px; margin-bottom: 56px; }
.content-row:last-child { margin-bottom: 0; }
.content-label h2 { font-size: 22px; font-weight: 600; color: var(--black); position: sticky; top: 80px; }
.content-body p { margin-bottom: 16px; font-size: 16px; color: var(--text) !important; line-height: 1.85; }
.content-body p span, .content-body p font, .content-body span { color: var(--text) !important; }
.content-body ul { margin: 8px 0 16px 20px; }
.content-body li { margin-bottom: 6px; font-size: 15px; color: var(--text); line-height: 1.7; }
.content-body h3 { font-size: 17px; font-weight: 600; color: var(--black); margin: 32px 0 14px; }
.content-body h3:first-child { margin-top: 0; }

/* Drop Cap */
.drop-cap::first-letter { float: left; font-size: 4.8em; line-height: 0.82; font-weight: 100; margin: 0 0.12em 0 0; color: var(--black); }

/* Spec Table */
.spec-table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.spec-table, .content-body table { width: 100%; border-collapse: collapse; min-width: 540px; }
.spec-table th, .spec-table td,
.content-body table th, .content-body table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border); font-size: 15px; color: var(--text); white-space: nowrap; }
.spec-table th, .content-body table th { font-weight: 600; color: var(--black); font-size: 13px; text-transform: uppercase; letter-spacing: 0.3px; }

/* Product Image Section */
.product-image-section { margin-bottom: 0; }
.product-image-section img { width: 100%; max-width: 560px; display: block; height: auto; }
.product-image-placeholder { width: 100%; max-width: 560px; aspect-ratio: 4/3; background: linear-gradient(145deg, #e8ede4, #d4ddd0); display: flex; align-items: center; justify-content: center; color: #999; font-size: 14px; }

/* Other Conditions */
.conditions-section { margin-top: 56px; }
.conditions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.condition-icon { width: 52px; height: 52px; background: rgba(153,204,0,0.1); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.condition-icon svg { width: 28px; height: 28px; color: var(--accent); }
.condition-item h4 { font-size: 16px; font-weight: 600; color: var(--black); margin-bottom: 8px; }
.condition-item p { font-size: 15px; color: var(--text); line-height: 1.75; }

/* ══════ INGREDIENT FINDER ══════ */
.finder-section { background: var(--bg-gray); padding: 64px 0; }
.finder-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.finder-inner h2 { font-size: 28px; font-weight: 600; color: var(--black); margin-bottom: 8px; }
.finder-subtitle { font-size: 15px; color: var(--text-light); margin-bottom: 28px; }
.finder-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.finder-item { background: var(--white); border: 1px solid var(--border); padding: 14px 18px; font-size: 14px; font-weight: 500; color: var(--text); cursor: pointer; transition: all .25s; text-decoration: none; display: block; text-align: center; }
.finder-item:hover { background: var(--accent); border-color: var(--accent); color: #fff; transform: translateY(-1px); }

/* ══════ CTA SECTION ══════ */
.cta-section { background: var(--white); padding: 80px 0; text-align: center; border-top: 1px solid var(--border); }
.cta-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.cta-section h2 { font-size: 32px; font-weight: 600; color: var(--black); margin-bottom: 14px; }
.cta-section p { font-size: 17px; color: var(--text-light); margin-bottom: 36px; line-height: 1.7; max-width: 520px; margin-left: auto; margin-right: auto; }
.btn-outline { display: inline-flex; align-items: center; gap: 12px; background: transparent; color: var(--dark); padding: 16px 36px; border: 1.5px solid var(--dark); border-radius: 32px; font-size: 17px; font-weight: 400; text-decoration: none; transition: all .3s; font-family: inherit; cursor: pointer; }
.btn-outline:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-outline svg { width: 18px; height: 18px; transition: all .3s; stroke-width: 1.5; }
.btn-outline:hover svg { transform: translateX(4px); }

/* ══════ RELATED INGREDIENTS (Single Product) ══════ */
.related-section { background: var(--bg-gray); padding: 80px 0; }
.related-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.related-inner h2 { font-size: 32px; font-weight: 600; color: var(--black); margin-bottom: 32px; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.related-card { background: var(--white); border: 1px solid var(--border); padding: 32px 28px; display: flex; flex-direction: column; min-height: 240px; transition: all .3s; text-decoration: none; position: relative; }
.related-card:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.1); }
.related-card h4 { font-size: 19px; font-weight: 700; color: var(--black); margin-bottom: 12px; transition: color .3s; }
.related-card p { font-size: 15px; color: var(--text-light); line-height: 1.65; flex: 1; transition: color .3s; }
.related-card:hover h4 { color: #fff; }
.related-card:hover p { color: rgba(255,255,255,0.85); }

/* ══════ PRODUCTS GRID (Category Page) ══════ */
.products-section { padding: 80px 0; }
.products-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.products-inner > h2 { font-size: 32px; font-weight: 600; color: var(--black); margin-bottom: 40px; }
.products-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.product-card { background: var(--white); border: 1px solid var(--border); padding: 32px 28px; display: flex; flex-direction: column; min-height: 200px; transition: all .3s; text-decoration: none; position: relative; }
.product-card:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.1); }
.product-card h3 { font-size: 19px; font-weight: 700; color: var(--black); margin-bottom: 10px; transition: color .3s; }
.product-card p { font-size: 15px; color: var(--text-light); line-height: 1.65; flex: 1; transition: color .3s; }
.product-card:hover h3 { color: #fff; }
.product-card:hover p { color: rgba(255,255,255,0.85); }

/* Shared Card Arrow */
.card-arrow { width: 48px; height: 48px; border: 1.5px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text-muted); align-self: flex-end; margin-top: 20px; transition: all .3s; }
.card-arrow svg { width: 20px; height: 20px; transition: all .25s; }
.product-card:hover .card-arrow,
.category-card:hover .card-arrow,
.related-card:hover .card-arrow { border-color: rgba(255,255,255,0.5); color: #fff; }
.product-card:hover .card-arrow svg,
.category-card:hover .card-arrow svg,
.related-card:hover .card-arrow svg { transform: scale(1.5); }

/* ══════ CATEGORIES GRID (Products Page) ══════ */
.categories-section { padding: 80px 0; }
.categories-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.categories-inner > h2 { font-size: 32px; font-weight: 600; color: var(--black); margin-bottom: 12px; }
.categories-subtitle { font-size: 16px; color: var(--text-light); margin-bottom: 40px; }
.categories-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.category-card { background: var(--white); border: 1px solid var(--border); padding: 36px 32px; display: flex; flex-direction: column; min-height: 220px; transition: all .3s; text-decoration: none; position: relative; border-radius: 14px; }
.category-card:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.1); }
.category-card-count { font-size: 12px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--accent); margin-bottom: 12px; transition: color .3s; }
.category-card:hover .category-card-count { color: rgba(255,255,255,0.7); }
.category-card h3 { font-size: 22px; font-weight: 700; color: var(--black); margin-bottom: 10px; transition: color .3s; }
.category-card p { font-size: 15px; color: var(--text-light); line-height: 1.7; flex: 1; transition: color .3s; }
.category-card:hover h3 { color: #fff; }
.category-card:hover p { color: rgba(255,255,255,0.85); }

/* ══════ ABOUT STRIP (Products Page) ══════ */
.about-strip { background: var(--dark); padding: 80px 0; }
.about-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.about-left h2 { font-size: 32px; font-weight: 600; color: #fff; margin-bottom: 16px; }
.about-left p { font-size: 16px; color: rgba(255,255,255,0.65); line-height: 1.8; margin-bottom: 24px; }
.about-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.stat-number { font-size: 36px; font-weight: 700; color: var(--accent); line-height: 1.2; }
.stat-label { font-size: 13px; color: rgba(255,255,255,0.5); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.about-right { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.about-card { background: var(--dark-lighter); border: 1px solid rgba(255,255,255,0.08); padding: 28px 24px; border-radius: 14px; }
.about-card-icon { width: 44px; height: 44px; background: rgba(153,204,0,0.12); border-radius: 10px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.about-card-icon svg { width: 22px; height: 22px; color: var(--accent); }
.about-card h4 { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.about-card p { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.65; }

/* ══════ FEATURED POSTS (Blog) ══════ */
.featured-section { padding: 64px 0 0; }
.featured-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.featured-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.featured-card { display: block; text-decoration: none; position: relative; overflow: hidden; background: var(--bg-gray); border-radius: 14px; }
.featured-card img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; transition: transform .4s; }
.featured-card .no-image { background: var(--dark); padding: 40px 28px; display: flex; flex-direction: column; justify-content: flex-end; min-height: 200px; }
.featured-card .no-image .featured-date { color: var(--accent); }
.featured-card .no-image h3 { color: #fff; }
.featured-card .no-image p { color: rgba(255,255,255,0.85); }
.featured-card:hover img { transform: scale(1.03); }
.featured-card-body { padding: 24px 28px 28px; }
.featured-date { font-size: 12px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.featured-card h3 { font-size: 22px; font-weight: 700; color: var(--black); line-height: 1.35; margin-bottom: 10px; transition: color .2s; }
.featured-card:hover h3 { color: var(--accent); }
.featured-card p { font-size: 15px; color: var(--text-light); line-height: 1.7; }

/* ══════ BLOG LISTING ══════ */
.blog-section { padding: 64px 0 80px; }
.blog-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.blog-card { display: block; text-decoration: none; background: var(--white); border: 1px solid var(--border); transition: all .3s; border-radius: 14px; overflow: hidden; }
.blog-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.08); }
.blog-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.blog-card-body { padding: 24px 24px 28px; }
.blog-date { font-size: 12px; font-weight: 500; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; margin-bottom: 10px; }
.blog-card h4 { font-size: 18px; font-weight: 700; color: var(--black); line-height: 1.4; margin-bottom: 10px; transition: color .2s; }
.blog-card:hover h4 { color: var(--accent); }
.blog-card p { font-size: 15px; color: var(--text-light); line-height: 1.7; }
.blog-read-more { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 500; color: var(--accent); margin-top: 14px; transition: gap .2s; }
.blog-card:hover .blog-read-more { gap: 10px; }

/* ══════ PAGINATION ══════ */
.pagination { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 56px; }
.pagination a, .pagination span { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; font-size: 14px; font-weight: 500; border: 1px solid var(--border); color: var(--text-light); transition: all .2s; text-decoration: none; }
.pagination a:hover { border-color: var(--accent); color: var(--accent); }
.pagination .current, .pagination span.current { background: var(--dark); border-color: var(--dark); color: #fff; }
.pagination .dots { border: none; color: var(--text-muted); }
.pagination .next { width: auto; padding: 0 16px; gap: 6px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; }

/* ══════ FOOTER ══════ */
.footer { background: var(--dark); padding: 56px 0 0; }
.footer-main { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 48px; padding-bottom: 48px; }
.footer-brand { font-size: 18px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #fff; margin-bottom: 14px; }
.footer-desc { font-size: 15px; line-height: 1.7; color: rgba(255,255,255,0.5); margin-bottom: 16px; }
.footer h4 { color: #fff; margin-bottom: 14px; font-size: 14px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; }
.footer a { color: rgba(255,255,255,0.6); font-size: 16px; transition: color .2s; }
.footer a:hover { color: #fff; }
.footer ul { list-style: none; }
.footer li { margin-bottom: 8px; }
.footer-contact { font-size: 15px; line-height: 1.8; color: rgba(255,255,255,0.5); margin-bottom: 14px; }
.footer-social { display: flex; gap: 16px; }
.footer-social a { color: rgba(255,255,255,0.5); }
.footer-social a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); }
.footer-bottom-inner { max-width: 1440px; margin: 0 auto; padding: 18px 60px; font-size: 14px; color: rgba(255,255,255,0.35); }

/* ══════ MODAL FORM ══════ */
.modal-overlay { position: fixed; inset: 0; background: rgba(26,30,50,0.55); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); z-index: 999; opacity: 0; visibility: hidden; transition: all .3s; display: flex; align-items: center; justify-content: center; padding: 20px; }
.modal-overlay.active { opacity: 1; visibility: visible; }
.modal-box { background: rgba(255,255,255,0.95); width: 100%; max-width: 820px; padding: 48px 56px; position: relative; box-shadow: 0 20px 60px rgba(0,0,0,0.15); max-height: 90vh; overflow-y: auto; border-radius: 20px; }
.modal-close { position: absolute; top: 20px; right: 20px; width: 36px; height: 36px; border: 1px solid var(--border); background: var(--white); display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 18px; color: var(--text-light); transition: all .2s; border-radius: 50%; }
.modal-close:hover { color: var(--black); border-color: var(--black); }
.modal-box h3 { font-size: 26px; font-weight: 600; color: var(--black); margin-bottom: 6px; }
.modal-box .modal-subtitle { font-size: 15px; color: var(--text-light); margin-bottom: 28px; }
.modal-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.modal-fields .full-width { grid-column: 1 / -1; }
.form-label { font-size: 12px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-light); margin-bottom: 6px; display: block; }
.form-group { }
.form-input { width: 100%; padding: 12px 16px; border: 1px solid var(--border); font-size: 15px; font-family: inherit; color: var(--text); background: var(--white); transition: border-color .2s; border-radius: 10px; }
.form-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(153,204,0,0.12); }
.form-input::placeholder { color: #aaa; }
textarea.form-input { resize: vertical; min-height: 100px; }
.btn-submit { display: inline-flex; align-items: center; gap: 10px; padding: 14px 36px; background: var(--accent); color: #fff; border: none; font-size: 16px; font-weight: 500; cursor: pointer; margin-top: 8px; transition: all .3s; font-family: inherit; border-radius: 28px; }
.btn-submit:hover { background: var(--accent-hover); transform: translateY(-1px); }
.btn-submit svg { transition: transform .2s; }
.btn-submit:hover svg { transform: translateX(3px); }

/* ══════ HERO — Blog Single ══════ */
.hero-blog { background: var(--dark); padding: 64px 0 72px; }
.hero-blog-inner { max-width: 860px; margin: 0 auto; padding: 0 60px; text-align: center; }
.hero-blog-meta { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.hero-blog-category { display: inline-block; font-size: 12px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--accent); background: rgba(153,204,0,0.12); padding: 4px 14px; border-radius: 20px; }
.hero-blog-date { font-size: 13px; color: rgba(255,255,255,0.4); }
.hero-blog-inner h1 { font-size: clamp(2rem, 1.6rem + 2vw, 3rem); font-weight: 700; line-height: 1.2; color: #fff; margin-bottom: 16px; }
.hero-blog-author { font-size: 14px; color: rgba(255,255,255,0.5); }
.hero-blog-author strong { color: rgba(255,255,255,0.8); font-weight: 600; }

/* ══════ ARTICLE LAYOUT ══════ */
.article-section { padding: 56px 0 80px; }
.article-wrapper { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 320px; gap: 64px; }

/* Main Article */
.article-content { min-width: 0; }
.article-featured-img { width: 100%; margin-bottom: 40px; border-radius: 14px; overflow: hidden; }
.article-featured-img img { width: 100%; height: auto; display: block; }
.article-body h2 { font-size: 24px; font-weight: 700; color: var(--black); margin: 40px 0 16px; line-height: 1.3; }
.article-body h2:first-child { margin-top: 0; }
.article-body h3 { font-size: 20px; font-weight: 600; color: var(--black); margin: 32px 0 12px; }
.article-body p { font-size: 16px; color: var(--text); line-height: 1.85; margin-bottom: 18px; }
.article-body ul, .article-body ol { margin: 12px 0 20px 24px; }
.article-body li { font-size: 16px; color: var(--text); line-height: 1.75; margin-bottom: 6px; }
.article-body strong { color: var(--black); }
.article-body a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.article-body a:hover { color: var(--accent-hover); }
.article-body blockquote { border-left: 3px solid var(--accent); padding: 16px 24px; margin: 24px 0; background: rgba(153,204,0,0.04); }
.article-body blockquote p { margin-bottom: 0; color: var(--text-light); font-style: italic; }
.article-body img { max-width: 100%; height: auto; border-radius: 8px; margin: 8px 0; }
.article-body table { width: 100%; border-collapse: collapse; margin: 20px 0 28px; }
.article-body th, .article-body td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border); font-size: 15px; color: var(--text); }
.article-body th { font-weight: 600; color: var(--black); font-size: 13px; text-transform: uppercase; letter-spacing: 0.3px; background: var(--bg-gray); }
.article-body tr:hover td { background: rgba(153,204,0,0.03); }

/* Tags */
.article-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--border); }
.article-tag { font-size: 13px; color: var(--text-light); background: var(--bg-gray); padding: 5px 14px; border-radius: 20px; transition: all .2s; }
.article-tag:hover { background: var(--accent); color: #fff; }

/* Share */
.article-share { display: flex; align-items: center; gap: 12px; margin-top: 20px; }
.article-share-label { font-size: 13px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.article-share a { width: 36px; height: 36px; border: 1px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text-light); transition: all .2s; }
.article-share a:hover { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ══════ SIDEBAR ══════ */
.sidebar { position: sticky; top: 24px; align-self: start; }
.sidebar-block { margin-bottom: 32px; }
.sidebar-block:last-child { margin-bottom: 0; }
.sidebar-block h3 { font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--black); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--accent); }
.sidebar-cta { background: var(--dark); padding: 28px 24px; border-radius: 14px; text-align: center; }
.sidebar-cta h3 { color: #fff; border-bottom-color: rgba(255,255,255,0.15); }
.sidebar-cta p { font-size: 14px; color: rgba(255,255,255,0.55); line-height: 1.65; margin-bottom: 20px; }
.sidebar-cta .btn-accent { width: 100%; justify-content: center; padding: 14px 24px; font-size: 15px; }
.sidebar-categories { list-style: none; }
.sidebar-categories li { margin-bottom: 0; }
.sidebar-categories a { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; font-size: 15px; color: var(--text); border-bottom: 1px solid var(--border); transition: color .2s; }
.sidebar-categories a:hover { color: var(--accent); }
.sidebar-categories .cat-count { font-size: 13px; color: var(--text-muted); background: var(--bg-gray); padding: 2px 10px; border-radius: 12px; }
.sidebar-related-item { display: flex; gap: 14px; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.sidebar-related-item:last-child { margin-bottom: 0; border-bottom: none; padding-bottom: 0; }
.sidebar-related-thumb { width: 72px; height: 72px; flex-shrink: 0; background: var(--bg-gray); border-radius: 8px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.sidebar-related-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-related-thumb .no-img { font-size: 10px; color: var(--text-muted); }
.sidebar-related-info h4 { font-size: 14px; font-weight: 600; color: var(--black); line-height: 1.4; margin-bottom: 4px; transition: color .2s; }
.sidebar-related-item:hover h4 { color: var(--accent); }
.sidebar-related-info .related-date { font-size: 12px; color: var(--text-muted); }

/* ══════ RELATED POSTS (Blog) ══════ */
.related-posts-section { background: var(--bg-gray); padding: 80px 0; }
.related-posts-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.related-posts-inner h2 { font-size: 32px; font-weight: 600; color: var(--black); margin-bottom: 32px; }
.related-posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.related-post-card { display: block; text-decoration: none; background: var(--white); border: 1px solid var(--border); transition: all .3s; border-radius: 14px; overflow: hidden; }
.related-post-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.08); }
.related-post-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.related-post-card .no-image { width: 100%; aspect-ratio: 16/10; background: var(--dark); display: flex; align-items: center; justify-content: center; }
.related-post-card .no-image span { color: rgba(255,255,255,0.2); font-size: 13px; }
.related-post-body { padding: 24px 24px 28px; }
.related-post-date { font-size: 12px; font-weight: 500; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; margin-bottom: 10px; }
.related-post-card h4 { font-size: 18px; font-weight: 700; color: var(--black); line-height: 1.4; margin-bottom: 10px; transition: color .2s; }
.related-post-card:hover h4 { color: var(--accent); }
.related-post-card p { font-size: 15px; color: var(--text-light); line-height: 1.7; }

/* ══════ HERO — About Us ══════ */
.hero-about { background: var(--dark); padding: 80px 0 88px; }
.hero-about-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.hero-about-left h1 { font-size: clamp(2.4rem, 2rem + 2vw, 3.6rem); font-weight: 700; line-height: 1.1; color: #fff; margin-bottom: 24px; }
.hero-about-left h1 span { color: var(--accent); }
.hero-about-desc { font-size: 18px; color: rgba(255,255,255,0.6); line-height: 1.8; margin-bottom: 32px; }
.hero-about-stats { display: flex; gap: 48px; }
.hero-about-stat-number { font-size: 36px; font-weight: 700; color: var(--accent); line-height: 1.2; }
.hero-about-stat-label { font-size: 13px; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.hero-about-right { position: relative; }
.hero-about-right img { width: 100%; height: auto; display: block; object-fit: cover; max-height: 440px; }
.hero-image-placeholder { width: 100%; aspect-ratio: 4/3; background: transparent; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.15); font-size: 14px; }

/* ══════ STORY SECTION ══════ */
.story-section { padding: 96px 0; }
.story-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 280px 1fr; gap: 80px; }
.story-label h2 { font-size: 28px; font-weight: 600; color: var(--black); position: sticky; top: 80px; }
.story-body p { font-size: 16px; color: var(--text); line-height: 1.85; margin-bottom: 20px; }
.story-body p:last-child { margin-bottom: 0; }

/* ══════ MISSION & VALUES ══════ */
.mission-section { padding: 96px 0; background: var(--bg-gray); }
.mission-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.mission-left h2 { font-size: 36px; font-weight: 600; color: var(--black); margin-bottom: 20px; }
.mission-left p { font-size: 16px; color: var(--text); line-height: 1.85; margin-bottom: 16px; }
.mission-left p:last-child { margin-bottom: 0; }
.mission-right { display: flex; align-items: center; justify-content: center; }
.mission-right img { width: 100%; max-width: 480px; height: auto; }

/* ══════ TIMELINE ══════ */
.timeline-section { background: var(--bg-gray); padding: 96px 0; }
.timeline-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.timeline { position: relative; padding-left: 40px; }
.timeline::before { content: ''; position: absolute; left: 7px; top: 8px; bottom: 8px; width: 2px; background: var(--border); }
.timeline-item { position: relative; margin-bottom: 48px; }
.timeline-item:last-child { margin-bottom: 0; }
.timeline-item::before { content: ''; position: absolute; left: -40px; top: 8px; width: 16px; height: 16px; background: var(--accent); border-radius: 50%; border: 3px solid var(--bg-gray); z-index: 1; }
.timeline-year { font-size: 14px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.timeline-item h3 { font-size: 20px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.timeline-item p { font-size: 15px; color: var(--text-light); line-height: 1.75; }

/* ══════ VALUES / WHAT SETS US APART ══════ */
.values-section { padding: 96px 0; }
.values-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.value-card { padding: 40px 32px; border: 1px solid var(--border); border-radius: 14px; transition: all .3s; }
.value-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.06); }
.value-icon { width: 64px; height: 64px; background: rgba(153,204,0,0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 24px; }
.value-icon svg { width: 30px; height: 30px; color: var(--accent); }
.value-card h3 { font-size: 18px; font-weight: 700; color: var(--black); margin-bottom: 10px; }
.value-card p { font-size: 15px; color: var(--text-light); line-height: 1.75; }

/* ══════ TEAM SECTION ══════ */
.team-section { background: var(--dark); padding: 96px 0; }
.team-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.team-section .section-header h2 { color: #fff; }
.team-section .section-header p { color: rgba(255,255,255,0.5); }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.team-card { background: var(--dark-lighter); border: 1px solid rgba(255,255,255,0.08); padding: 36px 32px; border-radius: 14px; }
.team-avatar { width: 72px; height: 72px; background: rgba(153,204,0,0.12); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.team-avatar svg { width: 32px; height: 32px; color: var(--accent); }
.team-card h3 { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.team-card .team-role { font-size: 13px; font-weight: 600; color: var(--accent); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 14px; }
.team-card p { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.7; }

/* ══════ CERTIFICATIONS ══════ */
.certs-section { padding: 96px 0; background: var(--bg-gray); }
.certs-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.certs-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cert-card { background: var(--white); border: 1px solid var(--border); padding: 32px 28px; text-align: center; border-radius: 14px; transition: all .3s; }
.cert-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.06); }
.cert-card-icon { width: 56px; height: 56px; background: rgba(153,204,0,0.1); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.cert-card-icon svg { width: 28px; height: 28px; color: var(--accent); }
.cert-card h4 { font-size: 16px; font-weight: 700; color: var(--black); margin-bottom: 6px; }
.cert-card p { font-size: 14px; color: var(--text-light); line-height: 1.6; }

/* ══════ HERO — Contact ══════ */
.hero-contact { background: var(--dark); padding: 72px 0 80px; }
.hero-contact-inner { max-width: 860px; margin: 0 auto; padding: 0 60px; text-align: center; }
.hero-contact-inner h1 { font-size: clamp(2.4rem, 2rem + 2vw, 3.6rem); font-weight: 700; line-height: 1.1; color: #fff; margin-bottom: 16px; }
.hero-contact-desc { font-size: 18px; color: rgba(255,255,255,0.55); line-height: 1.8; }

/* ══════ CONTACT SECTION ══════ */
.contact-section { padding: 80px 0 96px; }
.contact-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; display: grid; grid-template-columns: 1fr 400px; gap: 80px; }
.contact-form h2 { font-size: 28px; font-weight: 600; color: var(--black); margin-bottom: 8px; }
.contact-form > p { font-size: 15px; color: var(--text-light); margin-bottom: 32px; }
.contact-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.contact-fields .full-width { grid-column: 1 / -1; }
.contact-info h2 { font-size: 28px; font-weight: 600; color: var(--black); margin-bottom: 32px; }
.contact-info-item { display: flex; gap: 16px; margin-bottom: 28px; }
.contact-info-icon { width: 48px; height: 48px; background: rgba(153,204,0,0.1); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-info-icon svg { width: 22px; height: 22px; color: var(--accent); }
.contact-info-item h4 { font-size: 14px; font-weight: 700; color: var(--black); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.3px; }
.contact-info-item p { font-size: 15px; color: var(--text-light); line-height: 1.7; }
.contact-info-item a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.contact-info-item a:hover { color: var(--accent-hover); }
.contact-social { margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--border); }
.contact-social h4 { font-size: 14px; font-weight: 700; color: var(--black); margin-bottom: 14px; text-transform: uppercase; letter-spacing: 0.3px; }
.contact-social-links { display: flex; gap: 12px; }
.contact-social-links a { width: 42px; height: 42px; border: 1px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text-light); transition: all .2s; }
.contact-social-links a:hover { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ══════ MAP ══════ */
.map-section { background: var(--bg-gray); padding: 0; }
.map-container { width: 100%; height: 400px; background: var(--dark-lighter); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.2); font-size: 14px; }
.map-container iframe { width: 100%; height: 100%; border: none; }

/* ══════ WHY WORK WITH US ══════ */
.why-section { padding: 80px 0; }
.why-inner { max-width: 1440px; margin: 0 auto; padding: 0 60px; }
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.why-card { padding: 32px 24px; border: 1px solid var(--border); border-radius: 14px; text-align: center; transition: all .3s; }
.why-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.06); }
.why-card-icon { width: 56px; height: 56px; background: rgba(153,204,0,0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; }
.why-card-icon svg { width: 26px; height: 26px; color: var(--accent); }
.why-card h3 { font-size: 16px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.why-card p { font-size: 14px; color: var(--text-light); line-height: 1.65; }

/* ══════ CF7 INTEGRATION ══════ */
.modal-box .wpcf7-form,
.contact-form .wpcf7-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.modal-box .wpcf7-form .full-width,
.contact-form .wpcf7-form .full-width { grid-column: 1 / -1; }
.wpcf7 .wpcf7-not-valid-tip { font-size: 13px; color: #c0392b; margin-top: 4px; }
.wpcf7 .wpcf7-response-output { grid-column: 1 / -1; padding: 12px 16px; margin: 8px 0 0; border-radius: 10px; font-size: 14px; }
.wpcf7 .wpcf7-mail-sent-ok { border-color: var(--accent); color: var(--accent); }
.wpcf7 .wpcf7-validation-errors { border-color: #c0392b; color: #c0392b; }
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea { width: 100%; padding: 14px 18px; border: 1px solid var(--border); font-size: 15px; font-family: inherit; color: var(--text); background: var(--white); transition: border-color .2s; border-radius: 10px; }
.wpcf7 input:focus,
.wpcf7 textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(153,204,0,0.12); }
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder { color: #aaa; }
.wpcf7 textarea { resize: vertical; min-height: 100px; }
.wpcf7 .wpcf7-submit { display: inline-flex; align-items: center; gap: 10px; padding: 14px 36px; background: var(--accent); color: #fff; border: none; font-size: 16px; font-weight: 500; cursor: pointer; margin-top: 8px; transition: all .3s; font-family: inherit; border-radius: 28px; }
.wpcf7 .wpcf7-submit:hover { background: var(--accent-hover); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(153,204,0,0.3); }
.wpcf7 .wpcf7-spinner { display: none; }
.contact-form .wpcf7-form { gap: 20px; }

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */

@media (max-width: 1024px) {
    .hero-home-inner { grid-template-columns: 1fr; gap: 40px; }
    .hero-home-right img, .hero-home .hero-image-placeholder { max-height: 360px; }
    .hero-stats { flex-wrap: wrap; gap: 32px; }
    .how-grid { grid-template-columns: 1fr 1fr; }
    .hero.single-product .hero-inner { grid-template-columns: 1fr; gap: 32px; }
    .hero-card { max-width: 400px; }
    .hero.category-page .hero-inner { grid-template-columns: 1fr; gap: 0; }
    .hero.category-page .hero-left { padding-bottom: 40px; }
    .hero-right img, .hero-image-placeholder { max-height: 300px; }
    .content-row { grid-template-columns: 1fr; gap: 16px; }
    .content-label h2 { position: static; }
    .related-grid { grid-template-columns: 1fr 1fr; }
    .products-grid { grid-template-columns: 1fr 1fr; }
    .categories-grid { grid-template-columns: 1fr 1fr; }
    .about-inner { grid-template-columns: 1fr; gap: 40px; }
    .featured-grid { grid-template-columns: 1fr 1fr; }
    .blog-grid { grid-template-columns: 1fr 1fr; }
    .article-wrapper { grid-template-columns: 1fr; gap: 48px; }
    .sidebar { position: static; }
    .related-posts-grid { grid-template-columns: 1fr 1fr; }
    .hero-about-inner { grid-template-columns: 1fr; gap: 40px; }
    .mission-inner { grid-template-columns: 1fr; gap: 40px; }
    .story-inner { grid-template-columns: 1fr; gap: 24px; }
    .story-label h2 { position: static; }
    .values-grid { grid-template-columns: 1fr 1fr; }
    .team-grid { grid-template-columns: 1fr 1fr; }
    .certs-grid { grid-template-columns: 1fr 1fr; }
    .contact-inner { grid-template-columns: 1fr; gap: 56px; }
    .why-grid { grid-template-columns: 1fr 1fr; }
    .footer-main { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
    /* Header */
    .header-top-inner { padding: 0 20px; }
    .header-main-inner { padding: 0 20px; }
    .hamburger { display: block; }
    .nav { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: var(--dark); flex-direction: column; align-items: center; justify-content: center; gap: 24px; z-index: 1000; }
    .nav.open { display: flex; }
    .nav a { font-size: 22px; color: rgba(255,255,255,0.85); }
    .nav a:hover, .nav a.active { color: #fff; }
    .btn-contact-header { font-size: 18px; padding: 14px 30px; }
    .nav-close-wrap { display: block; position: absolute; top: 20px; right: 20px; }
    .nav-close { display: block; background: none; border: none; color: #fff; font-size: 28px; cursor: pointer; }

    /* Hero — Homepage */
    .hero-home { padding: 48px 0 40px; }
    .hero-home-inner { padding: 0 20px; gap: 32px; }
    .hero-home-left h1 { font-size: 2.2rem; }
    .hero-home-desc { font-size: 17px; }
    .hero-home-actions { flex-direction: column; }
    .btn-accent, .btn-outline-light { width: 100%; justify-content: center; }
    .btn-outline-light { padding: 14px 28px; font-size: 17px; }
    .hero-stats { padding: 24px 20px; gap: 20px; flex-wrap: wrap; }
    .hero-stat-number { font-size: 26px; }
    .hero-stat-label { font-size: 12px; }

    /* How We Work */
    .how-section { padding: 56px 0; }
    .how-inner { padding: 0 20px; }
    .how-grid { grid-template-columns: 1fr; }
    .how-icon { width: 72px; height: 72px; }
    .how-icon svg { width: 34px; height: 34px; }
    .how-item h3 { font-size: 19px; }
    .how-item p { font-size: 16px; }
    .section-header h2 { font-size: 28px; }
    .section-header p { font-size: 16px; }

    /* Hero — Single Product */
    .hero.single-product { padding: 36px 0 48px; }
    .hero.single-product .hero-inner { padding: 0 20px; gap: 24px; }
    .hero.single-product .hero-left h1 { font-size: 2rem; }
    .hero.single-product .hero-desc { font-size: 17px; }
    .hero-card { max-width: 100%; }
    .hero-card-label { font-size: 12px; }
    .hero-card-value { font-size: 16px; }
    .cert-badges { gap: 6px; }
    .cert-badge { font-size: 13px; padding: 6px 12px; }

    /* Hero — Category Page */
    .hero.category-page { padding: 40px 0 0; }
    .hero.category-page .hero-inner { padding: 0 20px; gap: 0; }
    .hero.category-page .hero-left { padding-bottom: 32px; }
    .hero.category-page .hero-left h1 { font-size: 2rem; }
    .hero.category-page .hero-desc { font-size: 17px; }

    /* Hero — Centered */
    .hero.centered-hero { padding: 48px 0 56px; }
    .hero.centered-hero .hero-inner { padding: 0 20px; }
    .hero.centered-hero .hero-inner h1 { font-size: 2rem; }
    .hero.centered-hero .hero-desc { font-size: 17px; }

    .btn-accent { padding: 14px 28px; font-size: 17px; }

    /* Breadcrumb */
    .breadcrumb-inner { padding: 12px 20px; }

    /* Section Nav */
    .section-nav-inner { padding: 0 20px; }
    .section-nav a { font-size: 15px; }
    .section-nav ul { overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; }

    /* Content */
    .content-section { padding: 32px 20px; }
    .content-label h2 { font-size: 24px; }
    .content-body p { font-size: 17px; }
    .content-body li { font-size: 17px; }
    .content-body h3 { font-size: 19px; }
    .content-row { margin-bottom: 40px; }
    .content-body ul { columns: 1 !important; }
    .drop-cap::first-letter { font-size: 3.5em; }
    .spec-table th, .spec-table td { font-size: 16px; }
    .spec-table th { font-size: 14px; }
    .condition-item h4 { font-size: 18px; }
    .condition-item p { font-size: 16px; }
    .conditions-grid { grid-template-columns: 1fr; gap: 24px; }
    .condition-icon { width: 44px; height: 44px; }
    .condition-icon svg { width: 24px; height: 24px; }

    /* Finder */
    .finder-inner { padding: 0 20px; }
    .finder-inner h2 { font-size: 26px; }
    .finder-subtitle { font-size: 16px; }
    .finder-item { font-size: 15px; }
    .finder-grid { grid-template-columns: 1fr 1fr; }

    /* Related */
    .related-grid { grid-template-columns: 1fr; }
    .related-section { padding: 48px 0; }
    .related-inner { padding: 0 20px; }
    .related-inner h2 { font-size: 26px; }
    .related-card h4 { font-size: 20px; }
    .related-card p { font-size: 16px; }

    /* Products grid */
    .products-section { padding: 48px 0; }
    .products-inner { padding: 0 20px; }
    .products-inner > h2 { font-size: 26px; margin-bottom: 28px; }
    .products-grid { grid-template-columns: 1fr; }
    .product-card h3 { font-size: 20px; }
    .product-card p { font-size: 16px; }

    /* Categories */
    .categories-section { padding: 48px 0; }
    .categories-inner { padding: 0 20px; }
    .categories-inner > h2 { font-size: 26px; }
    .categories-grid { grid-template-columns: 1fr; }
    .category-card h3 { font-size: 20px; }
    .category-card p { font-size: 16px; }

    /* About strip */
    .about-strip { padding: 48px 0; }
    .about-inner { padding: 0 20px; gap: 32px; }
    .about-left h2 { font-size: 26px; }
    .about-left p { font-size: 17px; }
    .about-stats { grid-template-columns: repeat(3, 1fr); gap: 20px; }
    .stat-number { font-size: 28px; }
    .stat-label { font-size: 12px; }

    /* Featured */
    .featured-section { padding: 40px 0 0; }
    .featured-inner { padding: 0 20px; }
    .featured-grid { grid-template-columns: 1fr; }
    .featured-card h3 { font-size: 20px; }
    .featured-card p { font-size: 16px; }

    /* Blog */
    .blog-section { padding: 40px 0 56px; }
    .blog-inner { padding: 0 20px; }
    .blog-grid { grid-template-columns: 1fr; }
    .blog-card h4 { font-size: 19px; }
    .blog-card p { font-size: 16px; }

    /* Blog Single */
    .hero-blog { padding: 40px 0 48px; }
    .hero-blog-inner { padding: 0 20px; }
    .hero-blog-inner h1 { font-size: 1.8rem; }
    .article-section { padding: 32px 0 56px; }
    .article-wrapper { padding: 0 20px; }
    .article-body h2 { font-size: 22px; margin: 32px 0 12px; }
    .article-body h3 { font-size: 18px; }
    .article-body p { font-size: 17px; }
    .article-body li { font-size: 17px; }
    .article-body th, .article-body td { font-size: 14px; padding: 10px 12px; }
    .related-posts-section { padding: 48px 0; }
    .related-posts-inner { padding: 0 20px; }
    .related-posts-inner h2 { font-size: 26px; }
    .related-posts-grid { grid-template-columns: 1fr; }
    .related-post-card h4 { font-size: 19px; }
    .related-post-card p { font-size: 16px; }

    /* About Us */
    .hero-about { padding: 48px 0 56px; }
    .hero-about-inner { padding: 0 20px; gap: 32px; }
    .hero-about-left h1 { font-size: 2.2rem; }
    .hero-about-desc { font-size: 17px; }
    .hero-about-stats { gap: 32px; flex-wrap: wrap; }
    .hero-about-stat-number { font-size: 28px; }
    .mission-section { padding: 56px 0; }
    .mission-inner { padding: 0 20px; gap: 32px; }
    .mission-left h2 { font-size: 28px; }
    .mission-left p { font-size: 17px; }
    .story-section { padding: 56px 0; }
    .story-inner { padding: 0 20px; gap: 20px; }
    .story-label h2 { font-size: 24px; }
    .story-body p { font-size: 17px; }
    .timeline-section { padding: 56px 0; }
    .timeline-inner { padding: 0 20px; }
    .values-section { padding: 56px 0; }
    .values-inner { padding: 0 20px; }
    .values-grid { grid-template-columns: 1fr; }
    .value-card h3 { font-size: 19px; }
    .value-card p { font-size: 16px; }
    .team-section { padding: 56px 0; }
    .team-inner { padding: 0 20px; }
    .team-grid { grid-template-columns: 1fr; }
    .certs-section { padding: 56px 0; }
    .certs-inner { padding: 0 20px; }
    .certs-grid { grid-template-columns: 1fr 1fr; }

    /* Contact */
    .hero-contact { padding: 48px 0 56px; }
    .hero-contact-inner { padding: 0 20px; }
    .hero-contact-inner h1 { font-size: 2.2rem; }
    .hero-contact-desc { font-size: 17px; }
    .contact-section { padding: 48px 0 56px; }
    .contact-inner { padding: 0 20px; }
    .contact-form h2 { font-size: 24px; }
    .contact-info h2 { font-size: 24px; }
    .contact-fields { grid-template-columns: 1fr; }
    .map-container { height: 280px; }
    .why-section { padding: 56px 0; }
    .why-inner { padding: 0 20px; }
    .why-grid { grid-template-columns: 1fr; }

    /* CTA */
    .cta-section { padding: 48px 0; }
    .cta-inner { padding: 0 20px; }
    .cta-section h2 { font-size: 26px; }
    .cta-section p { font-size: 17px; }
    .btn-outline { padding: 14px 28px; font-size: 17px; }

    /* Footer */
    .footer-main { grid-template-columns: 1fr; gap: 28px; padding: 0 20px 40px; }
    .footer-desc { font-size: 16px; }
    .footer a { font-size: 17px; }
    .footer-contact { font-size: 16px; }
    .footer-bottom-inner { padding: 16px 20px; font-size: 15px; }

    /* Modal + CF7 */
    .modal-overlay { padding: 12px; }
    .modal-box { padding: 28px 24px; max-width: 100%; border-radius: 16px; }
    .modal-box h3 { font-size: 24px; }
    .modal-box .modal-subtitle { font-size: 16px; }
    .modal-fields { grid-template-columns: 1fr; }
    .modal-box .wpcf7-form,
    .contact-form .wpcf7-form { grid-template-columns: 1fr; }
    .form-label { font-size: 13px; }
    .form-input { font-size: 16px; }
    .wpcf7 input[type="text"],
    .wpcf7 input[type="email"],
    .wpcf7 input[type="tel"],
    .wpcf7 textarea { font-size: 16px; }
    .btn-submit { font-size: 17px; }

    /* Search panel */
    .search-panel-inner { padding: 32px 20px 0; }
    .search-panel-header-inner { padding: 0 20px; }
    .search-panel-bar input { font-size: 16px; }
}
