/* ============================================================
   Vishnu Chandra SEO Expert — v3.0 (PHP Classic Theme)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --black:  #0a0a0a;
  --white:  #f5f4f0;
  --accent: #c8f23a;
  --mid:    #6b6b6b;
  --border: #e2e0d8;
  --card:   #ffffff;
  --alt:    #f0ede6;
  --syne:   'Syne', sans-serif;
  --dm:     'DM Sans', sans-serif;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--dm); font-size: 16px; line-height: 1.65; color: var(--black); background: var(--white); -webkit-font-smoothing: antialiased; overflow-x: hidden; margin: 0; padding: 0; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s; }
ul { list-style: none; margin: 0; padding: 0; }
p, h1, h2, h3, h4 { margin: 0 0 16px; }
h1, h2, h3, h4 { font-family: var(--syne); font-weight: 800; line-height: 1.05; letter-spacing: -0.02em; color: var(--black); }

/* ── Container ── */
.vc-container { max-width: 1240px; margin: 0 auto; padding: 0 48px; }

/* ── Main ── */
.vc-main { display: block; }

/* ── Shared section ── */
.vc-section { padding: 88px 0; }
.vc-bg-white { background: var(--white); }
.vc-bg-alt   { background: var(--alt); }
.vc-bg-dark  { background: var(--black); }

/* ── Eyebrow ── */
.vc-eyebrow { font-size: .74rem; font-weight: 500; letter-spacing: .13em; text-transform: uppercase; color: var(--mid); display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.vc-eyebrow::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--accent); flex-shrink: 0; }
.vc-eyebrow-light { color: rgba(255,255,255,.4); }
.vc-eyebrow-light::before { background: var(--accent); }

/* ── Section title ── */
.vc-section-title { font-size: clamp(1.9rem,3.2vw,2.8rem); margin-bottom: 0; }
.vc-title-light   { color: #fff; }
.vc-section-sub   { font-size: .9rem; font-weight: 300; color: var(--mid); margin: 8px 0 48px; }
.vc-section-header { display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 20px; margin-bottom: 52px; }

/* ── Links ── */
.vc-link-arrow { font-size: .87rem; font-weight: 500; color: var(--mid); white-space: nowrap; transition: color .2s; }
.vc-link-arrow:hover { color: var(--black); }

/* ── Buttons ── */
.vc-btn-accent, .vc-btn-ghost, .vc-btn-dark, .vc-btn-large { display: inline-block; border-radius: 100px; font-family: var(--dm); font-size: .9rem; font-weight: 600; padding: 14px 30px; transition: opacity .2s, transform .2s, background .2s; cursor: pointer; border: none; }
.vc-btn-accent { background: var(--accent); color: var(--black); }
.vc-btn-accent:hover { opacity: .86; transform: translateY(-2px); }
.vc-btn-ghost  { background: transparent; color: var(--black); border: 1.5px solid var(--black); }
.vc-btn-ghost:hover  { background: var(--black); color: var(--white); }
.vc-btn-dark   { background: var(--black); color: var(--white); }
.vc-btn-dark:hover   { background: #222; }
.vc-btn-large  { background: var(--accent); color: var(--black); font-size: 1rem; padding: 16px 40px; }
.vc-btn-large:hover  { opacity: .88; transform: translateY(-2px); }

/* ── Two / Three col ── */
.vc-two-col   { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.vc-three-col { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }

/* ======================================================
   HEADER
====================================================== */
.vc-header { position: sticky; top: 0; z-index: 999; background: rgba(245,244,240,.95); backdrop-filter: blur(14px); border-bottom: 1px solid var(--border); transition: box-shadow .3s; }
.vc-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,.07); }
.vc-header-inner { max-width: 1240px; margin: 0 auto; padding: 16px 48px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.vc-logo { font-family: var(--syne); font-weight: 800; font-size: 1.1rem; letter-spacing: -.02em; color: var(--black); display: flex; align-items: center; gap: 8px; }
.vc-logo-badge { background: var(--accent); color: var(--black); font-size: .65rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 2px 8px; border-radius: 3px; line-height: 1.6; }
.vc-nav { display: flex; align-items: center; gap: 28px; }
.vc-nav a { font-size: .87rem; font-weight: 500; color: var(--mid); transition: color .2s; }
.vc-nav a:hover { color: var(--black); }
.vc-nav-cta { background: var(--black); color: var(--white) !important; border-radius: 100px; padding: 10px 20px; font-size: .84rem !important; transition: background .2s, transform .2s !important; }
.vc-nav-cta:hover { background: #222 !important; transform: translateY(-1px); }
.vc-hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.vc-hamburger span { display: block; width: 24px; height: 2px; background: var(--black); border-radius: 2px; transition: transform .3s, opacity .3s; }

/* Mobile menu */
.vc-mobile-menu { position: fixed; top: 0; right: -100%; width: 300px; height: 100vh; background: var(--black); z-index: 1001; display: flex; flex-direction: column; padding: 52px 32px 32px; gap: 4px; transition: right .35s ease; }
.vc-mobile-menu.open { right: 0; }
.vc-mobile-menu a { color: rgba(255,255,255,.85); font-family: var(--syne); font-size: 1.1rem; font-weight: 700; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.08); transition: color .2s; }
.vc-mobile-menu a:hover { color: var(--accent); }
.vc-mobile-cta { background: var(--accent) !important; color: var(--black) !important; border-radius: 100px !important; padding: 14px 22px !important; text-align: center; margin-top: 16px; border: none !important; font-size: .9rem !important; }
.vc-mobile-close { position: absolute; top: 16px; right: 16px; background: none; border: none; color: rgba(255,255,255,.6); font-size: 1.3rem; cursor: pointer; padding: 8px; transition: color .2s; }
.vc-mobile-close:hover { color: #fff; }
.vc-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 1000; display: none; }
.vc-overlay.open { display: block; }

/* ======================================================
   HERO
====================================================== */
.vc-hero { min-height: 100vh; background: var(--white); padding: 120px 0 80px; position: relative; overflow: hidden; display: flex; align-items: center; }
.vc-hero::before { content: ''; position: absolute; top: -150px; right: -150px; width: 500px; height: 500px; background: radial-gradient(circle, rgba(200,242,58,.18) 0%, transparent 70%); pointer-events: none; }
.vc-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 1; }
.vc-hero-title { font-size: clamp(2.8rem,5vw,4.5rem); line-height: 1.02; letter-spacing: -.03em; margin-bottom: 22px; }
.vc-highlight { background: var(--accent); border-radius: 2px; }
.vc-hero-desc { font-size: 1.05rem; font-weight: 300; line-height: 1.72; color: var(--mid); max-width: 460px; margin-bottom: 32px; }
.vc-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 0; }
.vc-stats { display: flex; flex-wrap: wrap; gap: 32px; margin-top: 44px; padding-top: 32px; border-top: 1px solid var(--border); }
.vc-stat { display: flex; flex-direction: column; gap: 3px; }
.vc-stat-num { font-family: var(--syne); font-weight: 800; font-size: 2rem; line-height: 1; color: var(--black); }
.vc-stat-label { font-size: .78rem; color: var(--mid); }

/* Profile card */
.vc-profile-card { background: var(--black); border-radius: 24px; padding: 40px; color: #fff; position: relative; overflow: hidden; }
.vc-profile-card::before { content: ''; position: absolute; top: -80px; right: -80px; width: 240px; height: 240px; background: radial-gradient(circle, rgba(200,242,58,.2) 0%, transparent 70%); pointer-events: none; }
.vc-card-label { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 24px; }
.vc-card-name { font-family: var(--syne); font-weight: 800; font-size: 1.9rem; line-height: 1.1; color: #fff; margin-bottom: 6px; }
.vc-card-role { font-size: .84rem; color: rgba(255,255,255,.5); margin-bottom: 28px; }
.vc-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 28px; }
.vc-tag { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.75); font-size: .75rem; padding: 5px 12px; border-radius: 100px; }
.vc-tag-accent { background: var(--accent); border-color: var(--accent); color: var(--black); font-weight: 600; }
.vc-card-metric { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 16px 20px; display: flex; align-items: center; gap: 14px; }
.vc-metric-icon { background: var(--accent); border-radius: 10px; padding: 8px; font-size: 1rem; flex-shrink: 0; line-height: 1; }
.vc-metric-val { font-family: var(--syne); font-weight: 800; font-size: 1.3rem; color: #fff; margin: 0; }
.vc-metric-label { font-size: .75rem; color: rgba(255,255,255,.42); margin: 0; }

/* ======================================================
   MARQUEE
====================================================== */
.vc-marquee { background: var(--black); padding: 16px 0; overflow: hidden; white-space: nowrap; }
.vc-marquee-track { display: inline-block; animation: marquee 32s linear infinite; font-size: .8rem; font-weight: 500; letter-spacing: .09em; text-transform: uppercase; color: rgba(255,255,255,.6); }
.vc-marquee-item { display: inline-block; padding: 0 24px; }
.vc-dot { color: var(--accent); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ======================================================
   SERVICES
====================================================== */
.vc-services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; background: var(--border); border: 1px solid var(--border); border-radius: 20px; overflow: hidden; }
.vc-svc-card { background: var(--card); padding: 40px 32px; transition: background .25s; }
.vc-svc-card:hover { background: var(--black); }
.vc-svc-card:hover .vc-svc-num,
.vc-svc-card:hover .vc-svc-desc { color: rgba(255,255,255,.65); }
.vc-svc-card:hover .vc-svc-name { color: #fff; }
.vc-svc-card:hover .vc-svc-list li { color: rgba(255,255,255,.65); }
.vc-svc-icon { font-size: 1.5rem; display: block; margin-bottom: 16px; }
.vc-svc-num { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); display: block; margin-bottom: 8px; transition: color .25s; }
.vc-svc-name { font-size: 1.15rem; color: var(--black); margin-bottom: 10px; transition: color .25s; }
.vc-svc-desc { font-size: .85rem; font-weight: 300; line-height: 1.65; color: var(--mid); margin-bottom: 14px; transition: color .25s; }
.vc-svc-list { margin: 0; padding: 0; }
.vc-svc-list li { font-size: .8rem; color: var(--mid); padding: 3px 0; display: flex; align-items: flex-start; gap: 6px; transition: color .25s; }
.vc-svc-list li::before { content: '✓'; color: var(--accent); font-size: .7rem; font-weight: 700; flex-shrink: 0; margin-top: 3px; }

/* ======================================================
   WHY ME
====================================================== */
.vc-why-list { margin-top: 32px; border-top: 1px solid var(--border); }
.vc-why-item { display: flex; gap: 18px; padding: 22px 0; border-bottom: 1px solid var(--border); }
.vc-why-num { font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); min-width: 26px; flex-shrink: 0; padding-top: 3px; }
.vc-why-title { font-size: 1rem; color: var(--black); margin-bottom: 5px; }
.vc-why-desc { font-size: .86rem; font-weight: 300; line-height: 1.65; color: var(--mid); margin: 0; }
.vc-dark-card { background: var(--black); border-radius: 24px; padding: 44px 40px; color: #fff; position: relative; overflow: hidden; }
.vc-dark-card::before { content: '"'; position: absolute; top: -20px; left: 28px; font-family: var(--syne); font-size: 12rem; font-weight: 800; color: rgba(200,242,58,.06); line-height: 1; pointer-events: none; }
.vc-dark-quote { font-family: var(--syne); font-weight: 700; font-size: 1.4rem; line-height: 1.35; color: #fff; margin-bottom: 32px; position: relative; z-index: 1; }
.vc-metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; position: relative; z-index: 1; }
.vc-metric-box { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.09); border-radius: 12px; padding: 18px 20px; }
.vc-metric-big { font-family: var(--syne); font-weight: 800; font-size: 1.75rem; color: var(--accent); margin-bottom: 3px; }
.vc-metric-small { font-size: .76rem; color: rgba(255,255,255,.42); margin: 0; }

/* ======================================================
   CASE STUDIES
====================================================== */
.vc-case-card { background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: 32px 28px; transition: transform .25s, box-shadow .25s; }
.vc-case-card:hover { transform: translateY(-4px); box-shadow: 0 18px 52px rgba(0,0,0,.08); }
.vc-case-tag { display: inline-block; background: var(--alt); color: var(--mid); font-size: .72rem; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; padding: 4px 12px; border-radius: 100px; margin-bottom: 16px; }
.vc-case-title { font-size: 1.05rem; line-height: 1.3; color: var(--black); margin-bottom: 10px; }
.vc-case-desc { font-size: .84rem; font-weight: 300; line-height: 1.65; color: var(--mid); margin-bottom: 22px; }
.vc-case-results { display: flex; gap: 22px; padding-top: 18px; border-top: 1px solid var(--border); }
.vc-result-val { font-family: var(--syne); font-weight: 800; font-size: 1.45rem; line-height: 1; color: var(--accent); margin-bottom: 2px; }
.vc-result-label { font-size: .74rem; color: var(--mid); }

/* ======================================================
   INDUSTRIES
====================================================== */
.vc-industries-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 48px; }
.vc-industry-card { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 28px 20px; text-align: center; transition: border-color .2s, transform .2s; }
.vc-industry-card:hover { border-color: var(--accent); transform: translateY(-3px); }
.vc-industry-icon { font-size: 2rem; display: block; margin-bottom: 12px; }
.vc-industry-name { font-size: .95rem; color: var(--black); margin-bottom: 6px; }
.vc-industry-desc { font-size: .78rem; font-weight: 300; line-height: 1.55; color: var(--mid); margin: 0; }

/* ======================================================
   PROCESS
====================================================== */
.vc-process-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; background: var(--border); border-radius: 20px; overflow: hidden; margin-top: 48px; }
.vc-process-step { background: var(--card); padding: 36px 28px; }
.vc-step-num { font-family: var(--syne); font-weight: 800; font-size: 3rem; line-height: 1; color: rgba(200,242,58,.4); margin-bottom: 18px; }
.vc-step-title { font-size: .98rem; color: var(--black); margin-bottom: 9px; }
.vc-step-desc { font-size: .84rem; font-weight: 300; line-height: 1.65; color: var(--mid); margin-bottom: 14px; }
.vc-step-del { font-size: .78rem; font-weight: 500; color: var(--mid); margin: 0; }

/* ======================================================
   TOOLS
====================================================== */
.vc-tools-header { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; gap: 32px; margin-bottom: 48px; }
.vc-tools-sub { font-size: .87rem; font-weight: 300; line-height: 1.7; color: rgba(255,255,255,.4); max-width: 280px; margin: 0; align-self: flex-end; }
.vc-tools-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 2px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); border-radius: 20px; overflow: hidden; }
.vc-tool-card { background: var(--black); padding: 28px 20px; text-align: center; transition: background .2s; }
.vc-tool-card:hover { background: rgba(255,255,255,.05); }
.vc-tool-icon { font-size: 1.8rem; display: block; margin-bottom: 10px; }
.vc-tool-name { font-size: .8rem; color: rgba(255,255,255,.65); }

/* ======================================================
   PRICING
====================================================== */
.vc-pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 48px; }
.vc-price-card { background: var(--card); border: 1px solid var(--border); border-radius: 22px; padding: 36px 30px; transition: transform .2s, box-shadow .2s; }
.vc-price-card:hover { transform: translateY(-3px); box-shadow: 0 14px 42px rgba(0,0,0,.07); }
.vc-price-featured { background: var(--black); border-color: var(--black); position: relative; overflow: hidden; }
.vc-price-featured::before { content: ''; position: absolute; top: -80px; right: -80px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(200,242,58,.15) 0%, transparent 70%); pointer-events: none; }
.vc-price-badge { display: inline-block; background: var(--accent); color: var(--black); font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 14px; border-radius: 100px; margin-bottom: 14px; }
.vc-price-tier { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); margin-bottom: 6px; }
.vc-price-featured .vc-price-tier { color: rgba(255,255,255,.4); }
.vc-price-name { font-size: 1.4rem; color: var(--black); margin-bottom: 6px; }
.vc-price-featured .vc-price-name { color: #fff; }
.vc-price-desc { font-size: .84rem; font-weight: 300; color: var(--mid); margin-bottom: 20px; }
.vc-price-featured .vc-price-desc { color: rgba(255,255,255,.5); }
.vc-price-amount { font-family: var(--syne); font-weight: 800; font-size: 2.4rem; line-height: 1; color: var(--black); margin-bottom: 4px; }
.vc-price-featured .vc-price-amount { color: var(--accent); }
.vc-price-period { font-size: .8rem; color: var(--mid); margin-bottom: 24px; }
.vc-price-featured .vc-price-period { color: rgba(255,255,255,.4); }
.vc-price-list { margin-bottom: 28px; }
.vc-price-list li { font-size: .86rem; color: var(--mid); padding: 8px 0; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; gap: 8px; }
.vc-price-list li::before { content: '✓'; color: var(--accent); font-size: .72rem; font-weight: 700; flex-shrink: 0; margin-top: 3px; }
.vc-price-featured .vc-price-list li { color: rgba(255,255,255,.7); border-bottom-color: rgba(255,255,255,.08); }
.vc-price-btn { display: block; text-align: center; padding: 13px 24px; border-radius: 100px; font-family: var(--dm); font-size: .88rem; font-weight: 600; transition: opacity .2s; }
.vc-price-btn-light { background: var(--alt); color: var(--black); }
.vc-price-btn-accent { background: var(--accent); color: var(--black); }
.vc-price-btn-dark { background: var(--card); color: var(--black); border: 1.5px solid var(--border); }
.vc-price-featured .vc-price-btn-dark { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.2); }
.vc-price-btn:hover { opacity: .85; }

/* ======================================================
   FREE AUDIT CTA
====================================================== */
.vc-cta-section { background: var(--black); padding: 88px 0; position: relative; overflow: hidden; text-align: center; }
.vc-cta-section::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 560px; height: 560px; background: radial-gradient(circle, rgba(200,242,58,.1) 0%, transparent 70%); pointer-events: none; }
.vc-cta-inner { position: relative; z-index: 1; }
.vc-cta-label { font-size: .74rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.vc-cta-title { font-size: clamp(2rem,3.8vw,3.6rem); line-height: 1; letter-spacing: -.03em; color: #fff; margin-bottom: 16px; }
.vc-cta-desc { font-size: 1rem; font-weight: 300; line-height: 1.7; color: rgba(255,255,255,.5); max-width: 440px; margin: 0 auto 34px; }
.vc-cta-note { font-size: .8rem; color: rgba(255,255,255,.35); margin-top: 20px; }

/* ======================================================
   TESTIMONIALS
====================================================== */
.vc-testimonial { background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: 30px 26px; transition: transform .2s, box-shadow .2s; }
.vc-testimonial:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(0,0,0,.06); }
.vc-stars { font-size: .9rem; letter-spacing: 2px; color: var(--accent); margin-bottom: 14px; }
.vc-testimonial-text { font-size: .9rem; font-style: italic; font-weight: 300; line-height: 1.72; color: var(--black); margin-bottom: 20px; }
.vc-author { display: flex; align-items: center; gap: 12px; }
.vc-author-avatar { background: var(--alt); color: var(--mid); font-family: var(--syne); font-weight: 700; font-size: .85rem; width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vc-author-name { font-family: var(--syne); font-weight: 700; font-size: .88rem; color: var(--black); margin-bottom: 2px; }
.vc-author-biz { font-size: .76rem; color: var(--mid); }

/* ======================================================
   LOCAL SEO
====================================================== */
.vc-local-intro { font-size: .95rem; font-weight: 300; line-height: 1.75; color: var(--mid); margin: 14px 0 28px; }
.vc-local-point { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--border); align-items: flex-start; }
.vc-local-point:first-of-type { border-top: 1px solid var(--border); }
.vc-local-icon { background: var(--alt); border-radius: 10px; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
.vc-local-title { font-size: .95rem; color: var(--black); margin-bottom: 4px; }
.vc-local-desc { font-size: .84rem; font-weight: 300; line-height: 1.6; color: var(--mid); margin: 0; }
.vc-map-card { background: var(--black); border-radius: 24px; padding: 44px 40px; color: #fff; min-height: 380px; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; }
.vc-map-card::before { content: '📍'; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: 10rem; opacity: .04; pointer-events: none; }
.vc-map-title { font-family: var(--syne); font-weight: 800; font-size: 1.6rem; line-height: 1.2; color: #fff; margin-bottom: 24px; position: relative; z-index: 1; }
.vc-area-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; position: relative; z-index: 1; }
.vc-area-tag { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.75); font-size: .8rem; padding: 5px 13px; border-radius: 100px; }
.vc-area-featured { background: var(--accent); border-color: var(--accent); color: var(--black); font-weight: 600; }
.vc-map-note { font-size: .86rem; font-weight: 300; line-height: 1.65; color: rgba(255,255,255,.5); padding-top: 20px; border-top: 1px solid rgba(255,255,255,.08); position: relative; z-index: 1; margin: 0; }

/* ======================================================
   FAQ
====================================================== */
.vc-faq-layout { align-items: start; gap: 60px; }
.vc-faq-intro { font-size: .95rem; font-weight: 300; line-height: 1.72; color: var(--mid); margin: 0 0 32px; }
.vc-faq-cta-box { background: var(--black); border-radius: 18px; padding: 28px; }
.vc-faq-cta-title { font-size: 1.1rem; color: #fff; margin-bottom: 8px; }
.vc-faq-cta-desc { font-size: .84rem; font-weight: 300; color: rgba(255,255,255,.5); margin-bottom: 18px; line-height: 1.6; }
.vc-faq-list { display: flex; flex-direction: column; gap: 3px; }
.vc-faq-item { background: var(--card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; transition: border-color .2s; }
.vc-faq-item[open] { border-color: var(--accent); }
.vc-faq-q { font-family: var(--syne); font-weight: 700; font-size: .95rem; color: var(--black); cursor: pointer; padding: 18px 20px; list-style: none; display: flex; justify-content: space-between; align-items: center; user-select: none; }
.vc-faq-q:hover { background: var(--alt); }
.vc-faq-q::-webkit-details-marker { display: none; }
.vc-faq-q::after { content: '+'; font-size: 1.2rem; font-weight: 300; color: var(--mid); transition: transform .3s; flex-shrink: 0; margin-left: 12px; }
.vc-faq-item[open] .vc-faq-q::after { transform: rotate(45deg); color: var(--accent); }
.vc-faq-a { font-size: .88rem; font-weight: 300; line-height: 1.72; color: var(--mid); padding: 0 20px 18px; margin: 0; }

/* ======================================================
   BLOG CARDS (shared)
====================================================== */
.vc-blog-card { background: var(--card); border: 1px solid var(--border); border-radius: 20px; overflow: hidden; transition: transform .25s, box-shadow .25s; }
.vc-blog-card:hover { transform: translateY(-4px); box-shadow: 0 18px 52px rgba(0,0,0,.08); }
.vc-blog-img { width: 100%; height: 190px; object-fit: cover; }
.vc-blog-img-placeholder { width: 100%; height: 190px; background: var(--alt); display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.vc-blog-body { padding: 22px 22px 26px; }
.vc-blog-cat a { background: var(--alt); color: var(--mid); font-size: .7rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: 3px 9px; border-radius: 100px; text-decoration: none; display: inline-block; margin-bottom: 8px; }
.vc-blog-title { font-size: 1rem; line-height: 1.3; margin-bottom: 8px; }
.vc-blog-title a { color: var(--black); text-decoration: none; }
.vc-blog-title a:hover { text-decoration: underline; }
.vc-blog-excerpt { font-size: .83rem; font-weight: 300; line-height: 1.65; color: var(--mid); margin-bottom: 12px; }
.vc-blog-meta { display: flex; justify-content: space-between; align-items: center; }
.vc-blog-date { font-size: .76rem; color: var(--mid); }
.vc-blog-read { font-size: .76rem; font-weight: 500; color: var(--black); text-decoration: none; }
.vc-no-posts { text-align: center; color: var(--mid); font-size: .95rem; }

/* ======================================================
   BLOG ARCHIVE PAGE
====================================================== */
.vc-blog-hero { background: var(--black); padding: 110px 0 60px; }
.vc-blog-hero-eyebrow { font-size: .74rem; font-weight: 500; letter-spacing: .13em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.vc-blog-hero-eyebrow::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--accent); }
.vc-blog-hero-title { font-size: clamp(2rem,4vw,3.5rem); color: #fff; margin-bottom: 14px; }
.vc-blog-hero-desc { font-size: 1rem; font-weight: 300; line-height: 1.7; color: rgba(255,255,255,.5); max-width: 520px; }
.vc-blog-archive-wrap { background: var(--alt); padding: 60px 0 80px; }
.vc-pagination { margin-top: 48px; }
.vc-pagination .nav-links { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.vc-pagination .page-numbers { background: var(--card); border: 1px solid var(--border); color: var(--mid); padding: 8px 16px; border-radius: 8px; font-size: .87rem; text-decoration: none; transition: background .2s, color .2s; }
.vc-pagination .page-numbers.current,
.vc-pagination .page-numbers:hover { background: var(--black); color: var(--white); border-color: var(--black); }

/* ======================================================
   SINGLE POST
====================================================== */
.vc-post-hero { background: var(--black); padding: 110px 0 52px; }
.vc-post-cat a { font-size: .72rem; font-weight: 600; letter-spacing: .09em; text-transform: uppercase; color: var(--accent); text-decoration: none; display: inline-block; margin-bottom: 12px; }
.vc-post-title { font-size: clamp(1.8rem,4vw,3rem); line-height: 1.1; color: #fff; margin-bottom: 20px; }
.vc-post-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: .84rem; color: rgba(255,255,255,.5); }
.vc-post-img-wrap { background: var(--black); }
.vc-post-img { width: 100%; max-height: 480px; object-fit: cover; }
.vc-post-content-wrap { background: var(--white); padding: 52px 0 80px; }
.vc-post-content-inner { max-width: 760px; margin: 0 auto; }
.vc-post-content { font-size: 1.05rem; line-height: 1.8; font-weight: 300; color: var(--black); }
.vc-post-content h2 { font-family: var(--syne); font-weight: 800; font-size: 1.65rem; margin: 44px 0 14px; letter-spacing: -.02em; }
.vc-post-content h3 { font-family: var(--syne); font-weight: 700; font-size: 1.2rem; margin: 34px 0 10px; }
.vc-post-content p { margin-bottom: 18px; }
.vc-post-content ul, .vc-post-content ol { padding-left: 22px; margin-bottom: 18px; }
.vc-post-content li { margin-bottom: 7px; }
.vc-post-content blockquote { border-left: 4px solid var(--accent); padding: 16px 22px; margin: 24px 0; background: var(--alt); border-radius: 0 12px 12px 0; font-style: italic; }
.vc-post-content img { border-radius: 12px; margin: 20px 0; }
.vc-post-cta { background: var(--black); border-radius: 20px; padding: 36px; margin-top: 48px; text-align: center; }
.vc-post-cta-label { font-size: .74rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.vc-post-cta-title { font-size: 1.5rem; color: #fff; margin-bottom: 10px; }
.vc-post-cta-desc { font-size: .9rem; font-weight: 300; color: rgba(255,255,255,.5); margin-bottom: 22px; }

/* ======================================================
   PAGE / 404
====================================================== */
.vc-page-wrap { padding: 120px 0 80px; }
.vc-page-title { font-size: clamp(2rem,4vw,3.5rem); margin-bottom: 36px; }
.vc-page-content { font-size: 1.05rem; line-height: 1.8; font-weight: 300; max-width: 760px; }
.vc-404-num { font-family: var(--syne); font-weight: 800; font-size: 7rem; line-height: 1; color: var(--accent); margin-bottom: 14px; }
.vc-404-title { font-size: 2.5rem; margin-bottom: 14px; }
.vc-404-desc { font-size: 1rem; font-weight: 300; color: var(--mid); margin-bottom: 0; }

/* ======================================================
   FOOTER
====================================================== */
.vc-footer { background: var(--black); color: #fff; padding: 64px 0 32px; }
.vc-footer-inner { max-width: 1240px; margin: 0 auto; padding: 0 48px; }
.vc-footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.08); }
.vc-footer-name { font-family: var(--syne); font-weight: 800; font-size: 1.3rem; color: #fff; margin-bottom: 10px; }
.vc-footer-desc { font-size: .84rem; font-weight: 300; line-height: 1.7; color: rgba(255,255,255,.45); margin-bottom: 20px; max-width: 250px; }
.vc-footer-socials { display: flex; gap: 8px; }
.vc-footer-socials a { width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.15); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: .85rem; color: rgba(255,255,255,.7); text-decoration: none; transition: border-color .2s, background .2s; }
.vc-footer-socials a:hover { border-color: var(--accent); background: rgba(200,242,58,.1); }
.vc-footer-col { display: flex; flex-direction: column; gap: 10px; }
.vc-footer-col-title { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 6px; }
.vc-footer-col a, .vc-footer-col span { font-size: .86rem; font-weight: 300; color: rgba(255,255,255,.6); text-decoration: none; transition: color .2s; }
.vc-footer-col a:hover { color: #fff; }
.vc-response-box { background: rgba(200,242,58,.08); border: 1px solid rgba(200,242,58,.2); border-radius: 10px; padding: 14px 16px; margin-top: 10px; }
.vc-response-label { font-size: .72rem; color: rgba(255,255,255,.45); margin-bottom: 4px; }
.vc-response-val { font-size: .88rem; font-weight: 500; color: rgba(255,255,255,.85); }
.vc-footer-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; padding-top: 24px; font-size: .78rem; color: rgba(255,255,255,.28); }
.vc-footer-badge { background: var(--accent); color: var(--black); font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 4px 12px; border-radius: 100px; }

/* ======================================================
   WHATSAPP BUTTON
====================================================== */
.vc-wa { position: fixed; bottom: 28px; right: 28px; z-index: 9999; width: 56px; height: 56px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; box-shadow: 0 4px 20px rgba(37,211,102,.45); text-decoration: none; transition: transform .2s, box-shadow .2s; }
.vc-wa:hover { transform: scale(1.1); box-shadow: 0 6px 28px rgba(37,211,102,.5); }

/* ======================================================
   RESPONSIVE — TABLET
====================================================== */
@media (max-width: 1024px) {
  .vc-container { padding: 0 28px; }
  .vc-header-inner { padding: 14px 28px; }
  .vc-footer-inner { padding: 0 28px; }
  .vc-nav { display: none; }
  .vc-hamburger { display: flex; }
  .vc-hero { padding: 100px 0 60px; min-height: auto; }
  .vc-hero-grid { grid-template-columns: 1fr; }
  .vc-hero-right { display: none; }
  .vc-two-col, .vc-three-col { grid-template-columns: 1fr 1fr; }
  .vc-services-grid { grid-template-columns: 1fr 1fr; }
  .vc-pricing-grid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
  .vc-industries-grid { grid-template-columns: 1fr 1fr 1fr 1fr; }
  .vc-process-grid { grid-template-columns: 1fr 1fr; }
  .vc-tools-grid { grid-template-columns: repeat(3,1fr); }
  .vc-footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .vc-faq-layout { grid-template-columns: 1fr; }
}

/* ======================================================
   RESPONSIVE — MOBILE
====================================================== */
@media (max-width: 768px) {
  .vc-container { padding: 0 20px; }
  .vc-header-inner { padding: 12px 20px; }
  .vc-footer-inner { padding: 0 20px; }
  .vc-hero { padding: 90px 0 52px; }
  .vc-section { padding: 60px 0; }
  .vc-two-col, .vc-three-col { grid-template-columns: 1fr; }
  .vc-services-grid { grid-template-columns: 1fr; }
  .vc-industries-grid { grid-template-columns: 1fr 1fr; }
  .vc-process-grid { grid-template-columns: 1fr 1fr; }
  .vc-tools-grid { grid-template-columns: repeat(2,1fr); }
  .vc-tools-header { flex-direction: column; }
  .vc-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .vc-footer-bottom { flex-direction: column; align-items: center; text-align: center; }
  .vc-wa { width: 50px; height: 50px; bottom: 20px; right: 20px; font-size: 1.3rem; }
  .vc-stats { gap: 20px; }
  .vc-section-header { flex-direction: column; align-items: flex-start; }
  .vc-blog-hero { padding-top: 90px; }
  .vc-post-hero { padding-top: 90px; }
  .vc-page-wrap { padding: 90px 0 60px; }
}
