/* ══════════════════════════════════════════
   REAL ENGINEERING SERVICES — MAIN STYLES
   ══════════════════════════════════════════ */

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #0F1B5C;
  --navy-mid:   #1A2B7A;
  --navy-light: #2C3E9E;
  --navy-pale:  #EEF1FA;
  --gold:       #C8970A;
  --gold-light: #E6B020;
  --gold-pale:  #FDF6E3;
  --gold-bg:    #FEF9EC;
  --white:      #FFFFFF;
  --gray-50:    #F8F9FC;
  --gray-100:   #F1F3F9;
  --gray-200:   #E2E7F0;
  --gray-400:   #9AA3BF;
  --gray-600:   #5A6480;
  --gray-800:   #2D3554;
  --text:       #1A2240;
  --body:       'Plus Jakarta Sans', sans-serif;
  --display:    'Playfair Display', serif;
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  16px;
  --shadow-sm:  0 1px 8px rgba(15,27,92,0.06);
  --shadow-md:  0 4px 20px rgba(15,27,92,0.10);
  --shadow-lg:  0 8px 40px rgba(15,27,92,0.14);
  --transition: 0.25s ease;
}

/* ══════════════════════════════════════════
   WORDPRESS OVERRIDE RESETS
   WP themes inject base styles that fight ours.
   These !important rules restore correct rendering.
   ══════════════════════════════════════════ */
html {
  scroll-behavior: smooth;
  font-size: 16px !important;
}
body {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  background: #FFFFFF !important;
  color: #1A2240 !important;
  overflow-x: hidden;
  line-height: 1.6 !important;
  -webkit-font-smoothing: antialiased;
  max-width: none !important;
}
/* Kill WP content width constraints */
.entry-content, .site-content, #content, #primary, #main,
.wp-site-blocks, .wp-block-group, .wp-block-template-part {
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}
/* WP adds unwanted margins to headings and paragraphs — reset in our sections */
.hero h1, .hero h2, .hero h3,
.about-strip h2, .about-strip h3, .about-strip h4,
.services-section h2, .services-section h3,
.img-banner h2, .projects-section h2, .projects-section h3,
.why-us h2, .why-us h3, .why-us strong,
.clients-section h2, .team-section h2, .team-section h3, .team-section h4,
.cta-band h2, .blog-section h2, .blog-section h3,
.page-hero-content h1, .page-hero h1,
.section-title, .proj-cta h3, .about-story-card .asc-num {
  margin-top: 0 !important;
  padding: 0 !important;
}
/* WP adds margin-bottom: 1em to all p — override in our sections */
.hero p, .about-strip p, .services-section p, .img-banner p,
.projects-section p, .why-us p, .clients-section p, .team-section p,
.cta-band p, .blog-section p, .site-footer p {
  margin-bottom: 0 !important;
}
/* WP lists get bullets back — force none */
.nav-links, .footer-col ul, .project-list, .why-points,
.service-features, .about-features, .chip-grid,
.hero-stats, .team-grid, .service-grid {
  list-style: none !important;
  padding-left: 0 !important;
  margin: 0 !important;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }

/* ── LAYOUT ── */
.container { width: 100%; max-width: 1560px; margin: 0 auto; padding: 0 20px; }
.section-pad { padding: 70px 0; }
.bg-gray { background: var(--gray-50); border-top: 1px solid var(--gray-200); border-bottom: 1px solid var(--gray-200); }
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 1.75rem; }

/* ── TYPOGRAPHY ── */
.section-tag {
  display: inline-flex !important; align-items: center; gap: 10px;
  font-size: 0.68rem !important; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 0.75rem;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}
.section-tag::before {
  content: ''; display: block; width: 24px; height: 2px;
  background: var(--gold); border-radius: 2px; flex-shrink: 0;
}
.section-tag.light { color: rgba(230,176,32,0.85); }
.section-tag.light::before { background: rgba(230,176,32,0.6); }
.section-tag.light-dim { color: rgba(230,176,32,0.6); }
.section-tag.light-dim::before { background: rgba(230,176,32,0.4); }

.section-title {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(1.7rem, 2.5vw, 2.4rem) !important;
  font-weight: 800 !important; color: var(--navy) !important;
  line-height: 1.12 !important; letter-spacing: -0.02em;
  margin-bottom: 0.75rem;
}
.section-title.light { color: var(--white) !important; }
.section-body { font-size: 0.9rem; color: var(--gray-600); line-height: 1.8; }

.section-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 2.25rem; flex-wrap: wrap; gap: 1rem;
}
.section-header.centered { flex-direction: column; align-items: center; text-align: center; margin-bottom: 2.5rem; }
.section-header-sub {font-size: 16px;color: var(--gray-600);max-width: 1000px;text-align: right;line-height: 1.7;}

/* ── BUTTONS ── */
.btn {
  display: inline-flex !important; align-items: center; justify-content: center;
  padding: 0.78rem 1.75rem; border-radius: var(--radius-sm);
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 0.85rem !important; font-weight: 700 !important;
  letter-spacing: 0.02em; border: none; transition: all var(--transition);
  white-space: nowrap; text-decoration: none !important; cursor: pointer;
  line-height: 1 !important;
}
.btn-navy { background: var(--navy) !important; color: var(--white) !important; }
.btn-navy:hover { background: var(--navy-mid) !important; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(15,27,92,0.22); }
.btn-gold { background: var(--gold) !important; color: var(--white) !important; }
.btn-gold:hover { background: var(--gold-light) !important; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(200,151,10,0.32); }
.btn-white { background: var(--white) !important; color: var(--navy) !important; }
.btn-white:hover { background: var(--gray-100) !important; }
.btn-outline-white { background: transparent !important; color: var(--white) !important; border: 2px solid rgba(255,255,255,0.45) !important; }
.btn-outline-white:hover { border-color: rgba(255,255,255,0.8) !important; background: rgba(255,255,255,0.08) !important; }
.btn-outline-white2 { background: transparent !important; color: var(--white) !important; border: 2px solid rgba(255,255,255,0.35) !important; }
.btn-outline-white2:hover { border-color: rgba(255,255,255,0.7) !important; background: rgba(255,255,255,0.06) !important; }
.btn-full { width: 100%; }

/* ── NAV ── */
.site-header {
  position: sticky !important; top: 0; z-index: 200;
  background: var(--white) !important; border-bottom: 1px solid var(--gray-200);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.3s;
  width: 100% !important;
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(15,27,92,0.1); }
.nav-inner {
  display: flex !important; align-items: center; justify-content: space-between;
  max-width: 1560px; margin: 0 auto; padding: 0 20px; height: 76px;
}
.nav-logo img { height: 54px !important; width: auto !important; display: block !important; }
.nav-logo-text { font-size: 1rem; font-weight: 800; color: var(--navy); }
.nav-links { display: flex !important; gap: 2.5rem !important; align-items: center; flex-wrap: nowrap; }
.nav-links li { margin: 0 !important; padding: 0 !important; }
.nav-links li a {
  font-size: 0.82rem !important; font-weight: 600; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--gray-600) !important; transition: color var(--transition);
  position: relative; display: inline-block !important;
  padding: 0 !important; margin: 0 !important;
}
.nav-links li a::after {
  content: ''; position: absolute; bottom: -3px; left: 0; right: 0;
  height: 2px; background: var(--gold); border-radius: 2px;
  transform: scaleX(0); transform-origin: left; transition: transform var(--transition);
}
.nav-links li a:hover { color: var(--navy) !important; }
.nav-links li a:hover::after { transform: scaleX(1); }
.nav-links li.current-menu-item > a { color: var(--navy) !important; }
.nav-links li.current-menu-item > a::after { transform: scaleX(1); }
.nav-cta {
  background: var(--navy) !important; color: var(--white) !important; border: none !important;
  padding: 0.58rem 1.35rem !important; border-radius: var(--radius-sm);
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 0.78rem !important; font-weight: 700 !important;
  letter-spacing: 0.05em; text-transform: uppercase; transition: all var(--transition);
  line-height: 1 !important;
}
.nav-cta:hover { background: var(--navy-mid) !important; transform: translateY(-1px); }
.nav-hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 4px; }
.nav-hamburger span { display: block; width: 24px; height: 2px; background: var(--navy); border-radius: 2px; transition: all 0.3s; }

/* ── PAGE HERO ── */
.page-hero {
  min-height: 50vh; display: flex; align-items: center;
  position: relative; overflow: hidden;
  background-size: cover !important; background-position: center !important;
}
.page-hero-short { min-height: 38vh; }
.page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(10,16,56,0.88) 0%, rgba(10,16,56,0.6) 60%, rgba(10,16,56,0.35) 100%); }
.page-hero-content { position: relative; z-index: 2; padding: 72px 0 56px; width: 100%; }
.page-hero-content h1 {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem) !important;
  font-weight: 800 !important; color: #FFFFFF !important;
  line-height: 1.1 !important; letter-spacing: -0.02em;
  margin: 0.9rem 0 0.75rem !important;
}
.page-hero-content h1 em { font-style: italic; color: var(--gold-light) !important; }
.page-hero-content p { font-size: 0.95rem; color: rgba(255,255,255,0.7) !important; max-width: 520px; line-height: 1.75; }

/* ── BREADCRUMB ── */
.breadcrumb-bar { background: var(--gray-50); border-bottom: 1px solid var(--gray-200); padding: 0.55rem 0; }
.breadcrumb-bar .container { display: flex; gap: 0.5rem; align-items: center; font-size: 0.73rem; color: var(--gray-400); }
.breadcrumb-bar a { color: var(--navy) !important; font-weight: 600; }
.breadcrumb-bar a:hover { color: var(--gold) !important; }

/* ── EYEBROW BADGE ── */
.eyebrow-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(200,151,10,0.15); border: 1px solid rgba(200,151,10,0.4);
  border-radius: 100px; padding: 0.28rem 0.9rem;
  font-size: 0.66rem !important; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold-light) !important;
}

/* ── HERO ── */
/* ── HERO — nuclear specificity: body.home beats any WP theme selector ── */
body .hero,
body section.hero,
body.home .hero,
body.home section.hero {
  position: relative !important;
  min-height: 88vh !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  width: 100% !important;
}
body .hero-bg-img,
body.home .hero-bg-img {
  position: absolute !important; inset: 0 !important;
  background-size: cover !important; background-position: center 40% !important;
  transition: transform 0.1s linear;
  width: 100% !important; height: 100% !important;
}
body .hero-overlay,
body.home .hero-overlay {
  position: absolute !important; inset: 0 !important;
  background: linear-gradient(105deg, rgba(10,16,56,0.92) 0%, rgba(10,16,56,0.72) 52%, rgba(10,16,56,0.25) 100%) !important;
}
body .hero-inner,
body.home .hero-inner {
  position: relative !important;
  z-index: 2 !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 3rem !important;
  align-items: center !important;
  padding: 80px 20px !important;
  width: 100% !important;
  max-width: 1560px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}
/* h1 — triple selector to beat any WP theme rule */
body .hero h1,
body section.hero h1,
body.home .hero h1,
body.home section.hero h1,
body.home .hero-inner h1,
body .hero-inner h1 {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(2.6rem, 4.5vw, 4.2rem) !important;
  font-weight: 800 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.025em !important;
  color: #FFFFFF !important;
  margin: 1.1rem 0 1.1rem !important;
  display: block !important;
  text-transform: none !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
body .hero h1 em,
body section.hero h1 em,
body.home .hero h1 em {
  font-style: italic !important;
  color: #E6B020 !important;
  font-family: 'Playfair Display', serif !important;
  font-size: inherit !important;
  display: inline !important;
}
body .hero-sub,
body.home .hero-sub {
  font-size: 1rem !important; color: rgba(255,255,255,0.7) !important;
  line-height: 1.8 !important; max-width: 460px !important;
  margin-bottom: 2rem !important; display: block !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  text-transform: none !important;
}
body .hero-actions,
body.home .hero-actions { display: flex !important; gap: 0.85rem !important; flex-wrap: wrap !important; }

/* HERO STATS */
body .hero-stats {
  display: flex !important;
  margin-top: 2.25rem !important;
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  padding: 0 !important;
  list-style: none !important;
  width: auto !important;
  max-width: none !important;
}
body .hero-stat {
  flex: 1 !important;
  padding: 1rem !important;
  border-right: 1px solid rgba(255,255,255,0.1) !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 2px !important;
}
body .hero-stat:last-child { border-right: none !important; }
/* stat-row wraps number+plus so WP can never split them */
body .hero-stat .stat-row,
body.home .hero-stat .stat-row {
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 1px !important;
  line-height: 1 !important;
}
body .hero-stat .stat-num,
body.home .hero-stat .stat-num {
  font-size: 1.6rem !important; font-weight: 800 !important;
  color: #E6B020 !important; letter-spacing: -0.04em !important;
  line-height: 1 !important; display: inline-block !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  margin: 0 !important; padding: 0 !important;
}
body .hero-stat .stat-plus,
body.home .hero-stat .stat-plus {
  font-size: 1rem !important; font-weight: 800 !important;
  color: #E6B020 !important; display: inline-block !important;
  margin: 0 !important; padding: 0 !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}
body .hero-stat .stat-label,
body.home .hero-stat .stat-label {
  display: block !important;
  font-size: 0.6rem !important; color: rgba(255,255,255,0.5) !important;
  font-weight: 600 !important; letter-spacing: 0.08em !important;
  text-transform: uppercase !important; margin-top: 5px !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  line-height: 1.3 !important;
}

/* Hero right cards */
.hero-right { display: flex !important; flex-direction: column; gap: 0.75rem; }
.hero-card {
  background: rgba(255,255,255,0.96) !important;
  border-radius: var(--radius-lg); padding: 1.4rem 1.6rem !important;
  box-shadow: 0 4px 28px rgba(0,0,0,0.18);
}
.hero-card-icon { font-size: 1.5rem; margin-bottom: 0.45rem; display: block !important; }
.hero-card h3 {font-size: 16px !important;font-weight: 700 !important;color: var(--navy) !important;margin-bottom: 0.25rem !important;font-family: 'Plus Jakarta Sans', sans-serif !important;}
.hero-card p {font-size: 12px !important;color: var(--gray-600) !important;line-height: 1.55 !important;}
.iso-card {
  background: var(--gold-bg) !important; border: 1px solid rgba(200,151,10,0.28);
  border-radius: var(--radius-lg); padding: 1rem 1.35rem;
  display: flex !important; align-items: center; gap: 0.85rem;
  box-shadow: 0 4px 24px rgba(0,0,0,0.1);
}
.iso-ring {
  width: 58px; height: 58px; min-width: 58px; border-radius: 50%;
  border: 3px solid var(--gold); display: flex !important; align-items: center;
  justify-content: center; font-size: 0.52rem !important; font-weight: 800; text-align: center;
  color: var(--gold) !important; line-height: 1.4;
}
.iso-text h4 {font-size: 16px !important;font-weight: 700 !important;color: var(--navy) !important;font-family: 'Plus Jakarta Sans', sans-serif !important;}
.iso-text p {font-size: 12px !important;color: var(--gray-600) !important;margin-top: 2px;}

.scroll-indicator { position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 6px; opacity: 0.5; }
.scroll-indicator span { width: 1px; height: 32px; background: rgba(255,255,255,0.5); display: block !important; }

/* ── ABOUT ── */
.about-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.about-img-stack { position: relative; height: 440px; }
.about-img-main { position: absolute; top: 0; left: 0; right: 50px; bottom: 50px; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); }
.about-img-main img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.about-img-inset { position: absolute; bottom: 0; right: 0; width: 52%; height: 46%; border-radius: var(--radius-md); overflow: hidden; border: 4px solid var(--white); box-shadow: var(--shadow-lg); }
.about-img-inset img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.about-badge { position: absolute; top: 20px; right: 62px; background: var(--navy) !important; color: var(--white) !important; border-radius: var(--radius-md); padding: 0.85rem 1.1rem; text-align: center; box-shadow: 0 4px 20px rgba(15,27,92,0.3); z-index: 2; }
.about-badge-num { font-family: 'Playfair Display', serif !important; font-size: 2rem !important; font-weight: 800 !important; color: var(--gold-light) !important; line-height: 1; display: block !important; }
.about-badge-plus { font-size: 1.2rem !important; font-weight: 800 !important; color: var(--gold-light) !important; }
.about-badge-label { display: block !important; font-size: 0.6rem !important; color: rgba(255,255,255,0.65) !important; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; margin-top: 3px !important; }
.about-features {display: flex !important;flex-direction: column;gap: 0.7rem;margin: 1.25rem 0 !important;}
.about-feature { display: flex !important; gap: 0.85rem; align-items: flex-start; padding: 0.85rem 1rem; border-radius: var(--radius-md); background: var(--gray-50) !important; border: 1px solid var(--gray-200); transition: border-color var(--transition); }
.about-feature:hover { border-color: rgba(200,151,10,0.3); }
.af-icon { font-size: 1.3rem; min-width: 30px; }
.about-feature strong { font-size: 0.84rem !important; font-weight: 700 !important; color: var(--navy) !important; display: block !important; margin-bottom: 2px !important; }
.about-feature p { font-size: 0.73rem !important; color: var(--gray-600) !important; line-height: 1.55 !important; margin: 0 !important; }
.cert-row { display: grid !important; grid-template-columns: 1fr 1fr; gap: 0.65rem; }
.cert-block { border-radius: var(--radius-md); padding: 0.85rem 1rem; display: flex !important; align-items: center; gap: 0.65rem; font-size: 0.7rem !important; font-weight: 700 !important; color: var(--navy) !important; line-height: 1.3; }
.cert-block.gold { background: var(--gold-bg) !important; border: 1px solid rgba(200,151,10,0.25); }
.cert-block.blue { background: var(--navy-pale) !important; border: 1px solid rgba(15,27,92,0.12); }
.cert-block span:first-child { font-size: 1.2rem; flex-shrink: 0; }

/* ── SERVICES ── */
.service-grid { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 1rem; }
.service-grid.service-grid-lg { grid-template-columns: repeat(4, 1fr) !important; }
.service-card {
  background: var(--white) !important; border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg); overflow: hidden; transition: all var(--transition);
  position: relative;
}
.service-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--navy), var(--gold));
  transform: scaleX(0); transform-origin: left; transition: transform 0.3s;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.service-card:hover { border-color: rgba(15,27,92,0.2); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.service-card:hover::before { transform: scaleX(1); }
.svc-img {width: 100% !important;height: auto;object-fit: cover !important;display: block !important;background: var(--gray-100);transition: transform 0.5s;aspect-ratio: 1.3;}
.service-card:hover .svc-img { transform: scale(1.04); }
.svc-body { padding: 1rem 1.1rem 1.25rem !important; }
.svc-icon { font-size: 1.4rem; display: block !important; margin-bottom: 0.45rem !important; }
.svc-name {font-size: 16px !important;font-weight: 700 !important;color: var(--navy) !important;line-height: 1.3 !important;margin-bottom: 0.3rem !important;font-family: 'Plus Jakarta Sans', sans-serif !important;}
.svc-scale { font-size: 0.63rem !important; font-weight: 700 !important; color: var(--gold) !important; letter-spacing: 0.06em; text-transform: uppercase; display: block !important; margin-bottom: 0.3rem !important; }
.svc-desc {font-size: 13px !important;color: var(--gray-600) !important;line-height: 1.6 !important;margin-bottom: 0.65rem !important;}
.svc-link { font-size: 0.73rem !important; font-weight: 700 !important; color: var(--navy) !important; transition: color var(--transition); }
.svc-link:hover { color: var(--gold) !important; }
.section-footer-link { text-align: center; margin-top: 2.25rem; }

/* Service Detail */
.service-detail-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.service-detail-grid.reverse { direction: rtl; }
.service-detail-grid.reverse > * { direction: ltr; }
.service-detail-img { border-radius: var(--radius-lg); overflow: hidden; }
.service-detail-img img { width: 100% !important; height: 380px !important; object-fit: cover !important; display: block !important; }
.svc-icon-lg { font-size: 2.25rem; display: block !important; margin-bottom: 0.5rem !important; }
.service-features { display: flex !important; flex-direction: column; gap: 0.45rem; margin: 1.1rem 0; list-style: none !important; padding: 0 !important; }
.service-features li { display: flex !important; align-items: flex-start; gap: 0.55rem; font-size: 0.82rem !important; color: var(--gray-800) !important; line-height: 1.5; }
.check { color: var(--gold) !important; font-weight: 700; min-width: 18px; }

/* ── IMAGE BANNER ── */
.img-banner { min-height: 380px; position: relative; overflow: hidden; display: flex !important; align-items: center; }
.parallax-banner { background-attachment: fixed; background-size: cover !important; background-position: center !important; }
.img-banner-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,16,56,0.88) 0%, rgba(10,16,56,0.55) 60%, transparent 100%); }
.img-banner-content {position: relative;z-index: 2;padding: 70px 0;max-width: 1000px;text-align: center;}
.img-banner-content h2 { font-family: 'Playfair Display', serif !important; font-size: clamp(1.7rem, 2.8vw, 2.4rem) !important; font-weight: 800 !important; color: var(--white) !important; line-height: 1.2 !important; margin-bottom: 0.65rem !important; }
.img-banner-content p {font-size: 16pxrem !important;color: rgba(255,255,255,0.68) !important;line-height: 1.75 !important;margin-bottom: 1.5rem !important;}

/* ── PROJECTS ── */
.projects-layout { display: grid !important; grid-template-columns: 1fr 1.2fr; gap: 3.5rem; align-items: start; margin-top: 2.5rem; }
.project-list { display: flex !important; flex-direction: column; }
.project-item {display: flex !important;align-items: flex-start;gap: 0.85rem;padding: 15px 0 !important;border-bottom: 1px solid var(--gray-200);list-style: none !important;}
.project-item:first-child { border-top: 1px solid var(--gray-200); }
.project-num {font-size: 16px !important;font-weight: 800 !important;color: var(--gold) !important;letter-spacing: 0.06em;min-width: 24px;flex-shrink: 0;}
.project-name {font-size: 16px !important;font-weight: 600 !important;color: var(--gray-800) !important;line-height: 1.5;}
.projects-img-block { display: flex !important; flex-direction: column; gap: 0.85rem; }
.proj-img-main {border-radius: var(--radius-lg);overflow: hidden;}
.proj-img-main img {width: 100% !important;height: 100% !important;object-fit: cover !important;display: block !important;transition: transform 0.5s;aspect-ratio: 2.5;}
.proj-img-main:hover img { transform: scale(1.03); }
.proj-img-row { display: grid !important; grid-template-columns: 1fr 1fr; gap: 0.85rem; }
.proj-img-small {border-radius: var(--radius-md);overflow: hidden;}
.proj-img-small img {width: 100% !important;height: 100% !important;object-fit: cover !important;display: block !important;transition: transform 0.5s;aspect-ratio: 2;}
.proj-cta { background: var(--navy) !important; border-radius: var(--radius-lg); padding: 1.5rem; color: var(--white) !important; }
.proj-cta h3 { font-family: 'Playfair Display', serif !important; font-size: 1.2rem !important; font-weight: 800 !important; margin-bottom: 0.45rem !important; line-height: 1.2 !important; color: var(--white) !important; }
.proj-cta p { font-size: 0.76rem !important; color: rgba(255,255,255,0.6) !important; line-height: 1.65 !important; margin-bottom: 1.1rem !important; }
.sector-tags { display: flex !important; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.85rem !important; }
.sector-tag { background: rgba(255,255,255,0.08) !important; border: 1px solid rgba(255,255,255,0.15); border-radius: 100px; padding: 0.25rem 0.7rem !important; font-size: 0.63rem !important; font-weight: 600 !important; letter-spacing: 0.06em; color: rgba(255,255,255,0.7) !important; text-transform: uppercase; }

/* Projects page cards */
.stats-bar { padding: 1.75rem 0; background: var(--navy) !important; }
.stats-bar-inner { display: grid !important; grid-template-columns: repeat(4, 1fr); gap: 0; }
.stats-bar-item { text-align: center; border-right: 1px solid rgba(255,255,255,0.1); padding: 0.85rem; }
.stats-bar-item:last-child { border-right: none; }
.stats-bar-item span:first-child { font-family: 'Playfair Display', serif !important; font-size: 2.2rem !important; font-weight: 800 !important; color: var(--gold-light) !important; line-height: 1; display: block !important; }
.stats-bar-item span:nth-child(2) { font-size: 1.3rem !important; font-weight: 800 !important; color: var(--gold-light) !important; }
.stats-bar-item span:last-child { display: block !important; font-size: 0.65rem !important; font-weight: 600 !important; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.5) !important; margin-top: 4px !important; }
.projects-filter-bar { display: flex !important; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.filter-btn { background: var(--white) !important; border: 1px solid var(--gray-200) !important; border-radius: 100px; padding: 0.42rem 1rem; font-family: 'Plus Jakarta Sans', sans-serif !important; font-size: 0.76rem !important; font-weight: 600 !important; color: var(--gray-600) !important; cursor: pointer; transition: all var(--transition); }
.filter-btn:hover, .filter-btn.active { background: var(--navy) !important; border-color: var(--navy) !important; color: var(--white) !important; }
.projects-cards-grid { display: grid !important; grid-template-columns: repeat(3, 1fr); gap: 1.35rem; }
.project-card { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); overflow: hidden; transition: all var(--transition); }
.project-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.project-card-img { height: 190px; overflow: hidden; position: relative; }
.project-card-img img { width: 100% !important; height: 100% !important; object-fit: cover !important; transition: transform 0.5s; }
.project-sector-badge { position: absolute; top: 10px; left: 10px; background: var(--navy) !important; color: var(--white) !important; font-size: 0.62rem !important; font-weight: 700 !important; letter-spacing: 0.06em; text-transform: uppercase; padding: 0.22rem 0.65rem; border-radius: 100px; }
.project-card-body { padding: 1.35rem !important; }
.project-card-body h3 { font-size: 0.88rem !important; font-weight: 700 !important; color: var(--navy) !important; margin-bottom: 0.65rem !important; line-height: 1.35 !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.project-metas { display: flex !important; flex-direction: column; gap: 0.22rem; margin-bottom: 0.75rem !important; }
.project-metas span { font-size: 0.7rem !important; color: var(--gray-400) !important; }
.project-card-body p { font-size: 0.76rem !important; color: var(--gray-600) !important; line-height: 1.65 !important; }
.project-meta { font-size: 0.7rem !important; color: var(--gray-400) !important; display: block !important; margin-bottom: 3px !important; }
.project-scale { display: inline-block !important; background: var(--gold-bg) !important; border: 1px solid rgba(200,151,10,0.25); color: var(--gold) !important; font-size: 0.63rem !important; font-weight: 700 !important; letter-spacing: 0.06em; text-transform: uppercase; padding: 0.2rem 0.65rem; border-radius: 100px; margin-bottom: 0.7rem !important; }

/* ── GALLERY STRIP ── */
.gallery-strip { display: grid !important; grid-template-columns: repeat(5, 1fr) !important; height: 200px; }
.gallery-strip-item { overflow: hidden; position: relative; cursor: pointer; }
.gallery-strip-item img { width: 100% !important; height: 100% !important; object-fit: cover !important; transition: transform 0.5s; }
.gallery-strip-item:hover img { transform: scale(1.08); }
.gallery-strip-item::after { content: ''; position: absolute; inset: 0; background: rgba(10,16,56,0.22); transition: background 0.3s; }
.gallery-strip-item:hover::after { background: rgba(10,16,56,0.04); }

/* ── CLIENTS ── */
.clients-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: 3rem; }
.chip-grid { display: flex !important; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.35rem !important; }
.client-chip { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); padding: 0.45rem 0.9rem; font-size: 0.73rem !important; font-weight: 700 !important; color: var(--navy) !important; transition: all var(--transition); }
.client-chip:hover { border-color: var(--navy); background: var(--navy-pale) !important; }
.partner-chip { background: var(--gold-bg) !important; border: 1px solid rgba(200,151,10,0.25); border-radius: var(--radius-sm); padding: 0.45rem 0.9rem; font-size: 0.73rem !important; font-weight: 700 !important; color: var(--gold) !important; transition: all var(--transition); }
.partner-chip:hover { border-color: var(--gold); }

/* ── TEAM ── */
.team-grid { display: grid !important; grid-template-columns: repeat(5, 1fr) !important; gap: 1.1rem; margin-top: 2.5rem !important; }
.team-card { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); overflow: hidden; transition: all var(--transition); }
.team-card:hover { border-color: rgba(15,27,92,0.22); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.team-img-wrap { overflow: hidden; }
.team-img {width: 100% !important;object-fit: cover !important;object-position: top;display: block !important;transition: transform 0.5s;aspect-ratio: 0.8;}
.team-card:hover .team-img { transform: scale(1.04); }
.team-body { padding: 0.9rem 1rem 1.1rem !important; text-align: center !important; }
.team-name {font-size: 18px !important;font-weight: 700 !important;color: var(--navy) !important;line-height: 1.35 !important;margin-bottom: 3px !important;display: block !important;font-family: 'Plus Jakarta Sans', sans-serif !important;}
.team-role {display: block !important;font-size: 12px !important;font-weight: 700 !important;letter-spacing: 0.08em;text-transform: uppercase;color: var(--gold) !important;margin-bottom: 6px !important;}
.team-phone {font-size: 12px !important;color: var(--gray-400) !important;display: block !important;}
.team-phone:hover { color: var(--navy) !important; }

/* About Page Team Full */
.team-grid-full { grid-template-columns: repeat(3, 1fr) !important; gap: 1.35rem; }
.team-card-full { display: grid !important; grid-template-columns: 130px 1fr; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); overflow: hidden; background: var(--white) !important; transition: all var(--transition); }
.team-card-full:hover { box-shadow: var(--shadow-md); border-color: rgba(15,27,92,0.2); }
.team-card-full .team-img-wrap img { width: 130px !important; height: 100% !important; object-fit: cover !important; object-position: top; display: block !important; }
.team-body-full { padding: 1.1rem 1.35rem !important; }
.team-body-full h4 { font-size: 0.86rem !important; font-weight: 700 !important; color: var(--navy) !important; margin-bottom: 4px !important; line-height: 1.3 !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.team-body-full p { font-size: 0.74rem !important; color: var(--gray-600) !important; line-height: 1.65 !important; margin: 0.45rem 0 0.7rem !important; }
.team-contact { display: flex !important; flex-direction: column; gap: 3px; }
.team-contact a { font-size: 0.7rem !important; color: var(--navy) !important; font-weight: 600 !important; }
.team-contact a:hover { color: var(--gold) !important; }

/* ── WHY US ── */
.why-us { position: relative; padding: 70px 0 !important; background: var(--navy) !important; }
.why-us-bg-img { position: absolute; inset: 0; background-size: cover !important; background-position: center; opacity: 0.07; }
.why-us-grid { position: relative; z-index: 2; display: grid !important; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.why-body { font-size: 0.9rem !important; color: rgba(255,255,255,0.6) !important; line-height: 1.8 !important; margin-top: 0.5rem !important; }
.why-points { display: flex !important; flex-direction: column; gap: 0.7rem; margin-top: 1.35rem !important; list-style: none !important; padding: 0 !important; }
.why-point { display: flex !important; gap: 0.85rem; align-items: flex-start; padding: 0.85rem 1rem !important; background: rgba(255,255,255,0.05) !important; border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-md); transition: background var(--transition); }
.why-point:hover { background: rgba(255,255,255,0.08) !important; }
.wp-icon { font-size: 1.3rem; min-width: 28px; }
.why-point strong {font-size: 16px !important;font-weight: 700 !important;color: var(--white) !important;display: block !important;margin-bottom: 2px !important;}
.why-point p {font-size: 13px !important;color: rgba(255,255,255,0.55) !important;line-height: 1.6 !important;margin: 0 !important;}
.why-img-main {border-radius: var(--radius-lg);overflow: hidden;}
.why-img-main img {width: 100% !important;height: 100% !important;object-fit: cover !important;display: block !important;object-position: bottom;aspect-ratio: 1.8;}
.why-stats-row { display: grid !important; grid-template-columns: repeat(4, 1fr); gap: 0.7rem; margin-top: 0.85rem !important; }
.why-stat {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.11);
  border-radius: var(--radius-md); padding: 1rem !important; text-align: center;
  display: flex !important; flex-direction: column; align-items: center; gap: 2px;
}
/* FIXED: why-stat numbers were rendering tiny in WP due to span inheritance */
.why-stat .counter {
  font-family: 'Playfair Display', serif !important;
  font-size: 40px !important;
  font-weight: 800 !important;
  color: var(--gold-light) !important;
  line-height: 1 !important;
  display: block !important;
}
.why-stat span:nth-child(2) {
  font-size: 1rem !important; font-weight: 800 !important;
  color: var(--gold-light) !important; display: inline !important;
}
.why-stat span:last-child {
  display: block !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4) !important;
  margin-top: 4px !important;
}

/* ── CTA BAND ── */
.cta-band { background: var(--navy) !important; padding: 56px 0 !important; }
.cta-band-inner { display: grid !important; grid-template-columns: 1fr auto; align-items: center; gap: 2.5rem; }
.cta-band h2 { font-family: 'Playfair Display', serif !important; font-size: clamp(1.5rem, 2.5vw, 2.2rem) !important; font-weight: 800 !important; color: var(--white) !important; line-height: 1.2 !important; }
.cta-band p { font-size: 0.88rem !important; color: rgba(255,255,255,0.55) !important; margin-top: 0.45rem !important; }
.cta-band-btns { display: flex !important; gap: 0.85rem; flex-shrink: 0; flex-wrap: wrap; }

/* ── BLOG ── */
.blog-grid { display: grid !important; grid-template-columns: repeat(3, 1fr); gap: 1.35rem; }
.blog-card { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); overflow: hidden; transition: all var(--transition); }
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.blog-card-img { height: 188px; overflow: hidden; }
.blog-card-img img { width: 100% !important; height: 100% !important; object-fit: cover !important; transition: transform 0.5s; }
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-body { padding: 1.35rem !important; }
.blog-date { font-size: 0.66rem !important; font-weight: 600 !important; color: var(--gold) !important; letter-spacing: 0.08em; text-transform: uppercase; display: block !important; margin-bottom: 0.45rem !important; }
.blog-card-body h3 { font-size: 0.95rem !important; font-weight: 700 !important; color: var(--navy) !important; line-height: 1.35 !important; margin-bottom: 0.55rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.blog-card-body h3 a:hover { color: var(--gold) !important; }
.blog-card-body p { font-size: 0.77rem !important; color: var(--gray-600) !important; line-height: 1.65 !important; margin-bottom: 0.9rem !important; }
.read-more { font-size: 0.76rem !important; font-weight: 700 !important; color: var(--navy) !important; transition: color var(--transition); }
.read-more:hover { color: var(--gold) !important; }

/* ── CONTACT PAGE ── */
.contact-layout { display: grid !important; grid-template-columns: 1fr 1.15fr; gap: 4rem; align-items: start; }
.contact-img { border-radius: var(--radius-lg); overflow: hidden; height: 190px; margin-bottom: 1.35rem; }
.contact-img img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.contact-info-blocks { display: flex !important; flex-direction: column; gap: 0.9rem; margin-top: 1.5rem !important; }
.contact-info-item { display: flex !important; gap: 0.9rem; align-items: flex-start; padding-bottom: 0.9rem !important; border-bottom: 1px solid var(--gray-200); }
.contact-info-item:last-child { border-bottom: none; }
.ci-icon { width: 38px; height: 38px; min-width: 38px; border-radius: 10px; background: var(--navy-pale) !important; display: flex !important; align-items: center; justify-content: center; font-size: 0.95rem; }
.ci-label { font-size: 0.62rem !important; font-weight: 700 !important; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold) !important; display: block !important; margin-bottom: 3px !important; }
.contact-info-item p { font-size: 0.82rem !important; font-weight: 600 !important; color: var(--navy) !important; line-height: 1.65 !important; margin: 0 !important; }
.contact-info-item a { color: var(--navy) !important; }
.contact-info-item a:hover { color: var(--gold) !important; }
.office-hours { background: var(--gray-50) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-md); padding: 1.1rem 1.35rem !important; margin-top: 1.35rem !important; }
.office-hours h4 { font-size: 0.78rem !important; font-weight: 800 !important; letter-spacing: 0.08em; text-transform: uppercase; color: var(--navy) !important; margin-bottom: 0.7rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.oh-row { display: flex !important; justify-content: space-between; font-size: 0.78rem !important; color: var(--gray-600) !important; padding: 0.28rem 0 !important; border-bottom: 1px solid var(--gray-200); }
.oh-row:last-child { border-bottom: none; }
.contact-form-card { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); padding: 2rem !important; box-shadow: var(--shadow-md); }
.contact-form-card h3 { font-family: 'Playfair Display', serif !important; font-size: 1.3rem !important; font-weight: 700 !important; color: var(--navy) !important; margin-bottom: 0.3rem !important; }
.form-sub { font-size: 0.8rem !important; color: var(--gray-600) !important; margin-bottom: 1.35rem !important; }
.form-row-2 { display: grid !important; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex !important; flex-direction: column; gap: 5px; margin-bottom: 0.9rem !important; }
.form-group label { font-size: 0.65rem !important; font-weight: 700 !important; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-600) !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.req { color: var(--gold) !important; }
.form-group input, .form-group select, .form-group textarea {
  background: var(--gray-50) !important; border: 1px solid var(--gray-200) !important; border-radius: var(--radius-sm) !important;
  padding: 0.72rem 0.95rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 0.84rem !important; color: var(--text) !important;
  outline: none !important; width: 100% !important; transition: border-color var(--transition);
  box-shadow: none !important;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color: var(--navy) !important; background: var(--white) !important; box-shadow: 0 0 0 3px rgba(15,27,92,0.07) !important; }
.form-group textarea { min-height: 110px; resize: vertical; }
.form-message { padding: 0.9rem 1.15rem; border-radius: var(--radius-sm); font-size: 0.84rem; font-weight: 600; margin-bottom: 0.9rem; }
.form-message.success { background: #d1fae5; border: 1px solid #6ee7b7; color: #065f46; }
.form-message.error { background: #fee2e2; border: 1px solid #fca5a5; color: #991b1b; }
.quick-contact-cards { display: grid !important; grid-template-columns: 1fr 1fr; gap: 0.9rem; margin-top: 1.1rem !important; }
.quick-card { display: flex !important; align-items: center; gap: 0.75rem; padding: 0.9rem 1.1rem !important; border-radius: var(--radius-md); border: 1px solid var(--gray-200); background: var(--white) !important; transition: all var(--transition); }
.quick-card:hover { border-color: var(--navy); box-shadow: var(--shadow-sm); }
.quick-card-green:hover { border-color: #059669; }
.qc-icon { font-size: 1.4rem; }
.quick-card strong { font-size: 0.78rem !important; font-weight: 700 !important; color: var(--navy) !important; display: block !important; }
.quick-card p { font-size: 0.7rem !important; color: var(--gray-400) !important; margin: 0 !important; }

/* Map */
.map-section { height: 340px; background: var(--gray-100); position: relative; overflow: hidden; }
.map-placeholder { width: 100%; height: 100%; display: flex !important; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--navy-pale) 0%, var(--gray-100) 100%); }
.map-pin-content { text-align: center; padding: 2rem; }
.map-pin-icon { font-size: 2.75rem; margin-bottom: 0.65rem; }
.map-pin-content h3 { font-size: 1.05rem !important; font-weight: 700 !important; color: var(--navy) !important; margin-bottom: 0.35rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.map-pin-content p { font-size: 0.8rem !important; color: var(--gray-600) !important; margin-bottom: 1.1rem !important; }

/* ── FAQ ── */
.faq-layout { display: grid !important; grid-template-columns: 1fr 1.5fr; gap: 4rem; align-items: start; }
.faq-list { display: flex !important; flex-direction: column; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); overflow: hidden; background: var(--white) !important; }
.faq-item { border-bottom: 1px solid var(--gray-200); }
.faq-item:last-child { border-bottom: none; }
.faq-q { display: flex !important; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem 1.35rem !important; font-size: 0.85rem !important; font-weight: 700 !important; color: var(--navy) !important; cursor: pointer; user-select: none; transition: background var(--transition); font-family: 'Plus Jakarta Sans', sans-serif !important; }
.faq-q:hover { background: var(--gray-50) !important; }
.faq-icon { width: 22px; height: 22px; min-width: 22px; border-radius: 50%; background: var(--navy-pale) !important; color: var(--navy) !important; display: flex !important; align-items: center; justify-content: center; font-size: 0.9rem; font-weight: 700; flex-shrink: 0; }
.faq-item.open .faq-icon { background: var(--navy) !important; color: var(--white) !important; }
.faq-a { padding: 0.7rem 1.35rem 1rem !important; font-size: 0.79rem !important; color: var(--gray-600) !important; line-height: 1.75 !important; border-top: 1px solid var(--gray-100); }

/* ── ABOUT PAGE SPECIFIC ── */
.about-story-grid { display: grid !important; grid-template-columns: 1.1fr 0.9fr; gap: 4rem; align-items: start; }
.about-milestones { margin-top: 1.75rem !important; display: flex !important; flex-direction: column; gap: 0; border-left: 2px solid var(--gray-200); padding-left: 1.35rem !important; }
.milestone { display: flex !important; gap: 1rem; align-items: flex-start; padding-bottom: 1.1rem !important; position: relative; }
.milestone::before { content: ''; position: absolute; left: -1.5rem; top: 6px; width: 10px; height: 10px; border-radius: 50%; background: var(--gold) !important; border: 2px solid var(--white); box-shadow: 0 0 0 2px var(--gold); }
.milestone-year { font-size: 0.73rem !important; font-weight: 800 !important; color: var(--gold) !important; letter-spacing: 0.05em; min-width: 40px; padding-top: 1px; }
.milestone-text { font-size: 0.8rem !important; color: var(--gray-800) !important; line-height: 1.5 !important; }
.about-story-img { width: 100% !important; height: 340px !important; object-fit: cover !important; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); margin-bottom: 0.9rem !important; }
.about-story-card { background: var(--navy) !important; color: var(--white) !important; border-radius: var(--radius-lg); padding: 1.35rem 1.75rem !important; display: flex !important; align-items: center; gap: 0.9rem; }
.asc-num { font-family: 'Playfair Display', serif !important; font-size: 2.75rem !important; font-weight: 800 !important; color: var(--gold-light) !important; line-height: 1 !important; }
.about-story-card > span:nth-child(2) { font-size: 1.4rem !important; font-weight: 800 !important; color: var(--gold-light) !important; align-self: flex-start; padding-top: 0.2rem; }
.asc-label { font-size: 0.78rem !important; color: rgba(255,255,255,0.65) !important; line-height: 1.5 !important; }
.values-grid { display: grid !important; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; margin-top: 2.5rem !important; }
.value-card { background: var(--white) !important; border: 1px solid var(--gray-200); border-radius: var(--radius-lg); padding: 1.6rem 1.35rem !important; transition: all var(--transition); }
.value-card:hover { border-color: rgba(15,27,92,0.2); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.value-icon { font-size: 1.85rem; display: block !important; margin-bottom: 0.75rem !important; }
.value-card h3 { font-size: 0.88rem !important; font-weight: 700 !important; color: var(--navy) !important; margin-bottom: 0.45rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.value-card p { font-size: 0.76rem !important; color: var(--gray-600) !important; line-height: 1.65 !important; }

/* ── FOOTER ── */
.site-footer { background: var(--white); }
.footer-top { background: var(--gray-50) !important; border-top: 1px solid var(--gray-200); padding: 3rem 0 2rem !important; }
.footer-grid { display: grid !important; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2.5rem; }
.footer-logo img { height: 50px !important; width: auto !important; display: block !important; margin-bottom: 0.75rem !important; }
.footer-desc { font-size: 0.77rem !important; color: var(--gray-600) !important; line-height: 1.78 !important; max-width: 250px; }
.footer-social { display: flex !important; gap: 0.65rem; margin-top: 1.1rem !important; }
.footer-social a { width: 34px; height: 34px; border-radius: 8px; background: var(--navy-pale) !important; border: 1px solid var(--gray-200); display: flex !important; align-items: center; justify-content: center; color: var(--navy) !important; transition: all var(--transition); }
.footer-social a:hover { background: var(--navy) !important; color: var(--white) !important; }
.footer-col h4 { font-size: 0.66rem !important; font-weight: 800 !important; letter-spacing: 0.12em; text-transform: uppercase; color: var(--navy) !important; margin-bottom: 0.9rem !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.footer-col ul { display: flex !important; flex-direction: column; gap: 0.5rem; list-style: none !important; padding: 0 !important; margin: 0 !important; }
.footer-col ul li a { font-size: 0.77rem !important; color: var(--gray-600) !important; transition: color var(--transition); display: block; }
.footer-col ul li a:hover { color: var(--navy) !important; }
.footer-contact-list { list-style: none !important; padding: 0 !important; }
.footer-contact-list li { display: flex !important; gap: 0.5rem; align-items: flex-start; font-size: 0.77rem !important; color: var(--gray-600) !important; padding: 0.28rem 0 !important; }
.footer-contact-list li svg { margin-top: 3px; flex-shrink: 0; color: var(--gold) !important; }
.footer-contact-list a { color: var(--gray-600) !important; }
.footer-contact-list a:hover { color: var(--navy) !important; }
.footer-bottom { background: var(--gray-100) !important; border-top: 1px solid var(--gray-200); padding: 1.1rem 0 !important; }
.footer-bottom .container { display: flex !important; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-copy { font-size: 0.7rem !important; color: var(--gray-400) !important; }
.footer-cities { font-size: 0.68rem !important; color: var(--gray-400) !important; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .service-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .team-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 2rem; }
  .hero-inner { grid-template-columns: 1fr !important; gap: 2rem; }
  .hero-right { display: none !important; }
  .about-grid { grid-template-columns: 1fr !important; gap: 2.5rem; }
  .about-img-stack { height: 320px; }
  .projects-layout { grid-template-columns: 1fr !important; }
  .projects-cards-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .clients-grid { grid-template-columns: 1fr !important; gap: 2rem; }
  .why-us-grid { grid-template-columns: 1fr !important; gap: 2.5rem; }
  .faq-layout { grid-template-columns: 1fr !important; }
  .contact-layout { grid-template-columns: 1fr !important; }
  .team-grid-full { grid-template-columns: repeat(2, 1fr) !important; }
  .values-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .about-story-grid { grid-template-columns: 1fr !important; }
  .cta-band-inner { grid-template-columns: 1fr !important; gap: 1.5rem; }
}

@media (max-width: 768px) {
  .section-pad { padding: 52px 0; }
  .nav-links, .nav-cta { display: none !important; }
  .nav-hamburger { display: flex !important; }
  .nav-links.open { display: flex !important; flex-direction: column; position: fixed; top: 72px; left: 0; right: 0; background: var(--white) !important; padding: 1.25rem 5%; border-bottom: 1px solid var(--gray-200); box-shadow: var(--shadow-md); gap: 0; z-index: 199; }
  .nav-links.open li { border-bottom: 1px solid var(--gray-100); margin: 0 !important; }
  .nav-links.open li a { display: block !important; padding: 0.8rem 0 !important; font-size: 0.88rem !important; }
  .service-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .team-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .hero { min-height: 100svh !important; }
  body .hero-inner,
  body.home .hero-inner {
    grid-template-columns: 1fr !important;
    padding: 100px 20px 60px !important;
    gap: 2rem !important;
  }
  body .hero-right,
  body.home .hero-right { display: none !important; }
  body .hero h1,
  body.home .hero h1 { font-size: clamp(2.2rem, 8vw, 3rem) !important; }
  body .hero-sub,
  body.home .hero-sub { font-size: 0.9rem !important; max-width: 100% !important; }
  body .hero-stats,
  body.home .hero-stats { margin-top: 1.75rem !important; }
  body .hero-stat,
  body.home .hero-stat { padding: 0.85rem 0.5rem !important; }
  body .hero-stat .stat-row .stat-num,
  body.home .hero-stat .stat-row .stat-num { font-size: 1.3rem !important; }
  .gallery-strip { grid-template-columns: repeat(3, 1fr) !important; height: 150px; }
  .gallery-strip-item:nth-child(4), .gallery-strip-item:nth-child(5) { display: none !important; }
  .stats-bar-inner { grid-template-columns: repeat(2, 1fr) !important; }
  .cta-band-btns { flex-direction: row; flex-wrap: wrap; }
  .projects-cards-grid { grid-template-columns: 1fr !important; }
  .team-card-full { grid-template-columns: 1fr !important; }
  .team-card-full .team-img-wrap img { width: 100% !important; height: 190px !important; }
  .values-grid { grid-template-columns: 1fr !important; }
  .form-row-2 { grid-template-columns: 1fr !important; }
  .quick-contact-cards { grid-template-columns: 1fr !important; }
  .section-header { flex-direction: column; align-items: flex-start; }
  .section-header-sub { text-align: left; max-width: 100%; }
  .why-stats-row { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 480px) {
  .service-grid { grid-template-columns: 1fr !important; }
  .team-grid {grid-template-columns:  1fr !important;}
  .blog-grid{
    grid-template-columns: 1fr;
}
  .cert-row { grid-template-columns: 1fr !important; }
  .hero-stats { flex-wrap: wrap; }
  .hero-stat { flex: 0 0 50%; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .hero-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.1); }
  .container { padding: 0 4%; }
}
