/* ═══════════════════════════════════════════════════════════
   BGS INFRA PROJECTS — Main Stylesheet
   Clean & Professional: Navy · Sky Blue · White · Blue-Grey
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;900&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── CSS Variables ───────────────────────────────────────── */
:root {
  /* Primary — from logo */
  --navy:         #1B2A6B;
  --navy-mid:     #243580;
  --navy-light:   #2E4299;
  --sky:          #2B9FD8;
  --sky-light:    #4DB8EE;
  --sky-pale:     #E8F5FC;

  /* Backgrounds */
  --bg-white:     #FFFFFF;
  --bg-section:   #F4F7FB;
  --bg-card:      #FFFFFF;
  --bg-bluegrey:  #EDF2F7;

  /* Text */
  --text-dark:    #0F1A3E;
  --text-body:    #2D3748;
  --text-muted:   #64748B;

  /* Aliases — keeps all old references working */
  --brown-dark:   #1B2A6B;
  --brown-mid:    #243580;
  --brown-light:  #2B9FD8;
  --cream-bg:     #F4F7FB;
  --cream-dark:   #D6E4F0;
  --cream-white:  #FFFFFF;
  --olive-dark:   #1B2A6B;
  --olive-mid:    #2B9FD8;
  --olive-light:  #4DB8EE;

  --shadow-sm:    0 2px 12px rgba(27,42,107,.07);
  --shadow-md:    0 6px 30px rgba(27,42,107,.12);
  --shadow-lg:    0 16px 60px rgba(27,42,107,.16);
  --radius:       6px;
  --transition:   all .3s cubic-bezier(.4,0,.2,1);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html {
  scroll-behavior:smooth;
  font-size:16px;
  overflow-x:hidden;
  max-width:100%;
}
body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg-white);
  color:var(--text-body);
  line-height:1.7;
  overflow-x:hidden;
  max-width:100%;
  width:100%;
}
img { max-width:100%; height:auto; display:block; }
a  { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; font-family:inherit; }

/* ── Utility ─────────────────────────────────────────────── */
.container   { max-width:1180px; margin:0 auto; padding:0 32px; }
.section-pad { padding:96px 0; }
.text-center { text-align:center; }

.section-label {
  display:inline-block;
  background:var(--sky);
  color:#fff;
  font-size:11px;
  font-weight:600;
  letter-spacing:2.5px;
  text-transform:uppercase;
  padding:5px 14px;
  border-radius:2px;
  margin-bottom:14px;
}

.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,3.5vw,42px);
  font-weight:700;
  color:var(--navy);
  line-height:1.2;
  margin-bottom:16px;
}

.section-sub {
  font-size:16px;
  color:var(--text-muted);
  max-width:520px;
  line-height:1.85;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'DM Sans',sans-serif;
  font-weight:600;
  font-size:15px;
  letter-spacing:.4px;
  border-radius:var(--radius);
  padding:14px 32px;
  transition:var(--transition);
  border:none;
}
.btn-primary {
  background:var(--sky);
  color:#fff;
}
.btn-primary:hover {
  background:var(--sky-light);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.btn-outline {
  background:transparent;
  color:#ffffff;
  border:1.5px solid rgba(255,255,255,.35);
}
.btn-outline:hover {
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.6);
}
.btn-dark {
  background:var(--navy);
  color:#ffffff;
}
.btn-dark:hover {
  background:var(--navy-mid);
  transform:translateY(-2px);
}

/* ══════════════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════════════ */
.navbar {
  position:fixed;
  top:0; left:0; right:0;
  z-index:1000;
  background:var(--navy);
  height:70px;
  transition:var(--transition);
}
.navbar.scrolled {
  height:60px;
  box-shadow:0 4px 30px rgba(27,42,107,.35);
}
.nav-inner {
  max-width:1180px;
  margin:0 auto;
  padding:0 32px;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:relative;
}
.nav-logo {
  display:flex;
  align-items:center;
  gap:12px;
}
.nav-logo-icon {
  width:42px; height:42px;
  flex-shrink:0;
}
.nav-logo-text .name {
  font-family:'Playfair Display',serif;
  font-size:20px;
  font-weight:700;
  color:#FFFFFF;
  display:block;
  line-height:1;
}
.nav-logo-text .tagline {
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--sky-light);
  display:block;
  margin-top:3px;
}
.nav-links {
  display:flex;
  align-items:center;
  gap:8px;
}
.nav-links a {
  color:rgba(255,255,255,.75);
  font-size:14px;
  font-weight:500;
  padding:8px 14px;
  border-radius:var(--radius);
  transition:var(--transition);
  position:relative;
}
.nav-links a::after {
  content:'';
  position:absolute;
  bottom:4px; left:14px; right:14px;
  height:1px;
  background:var(--sky-light);
  transform:scaleX(0);
  transition:transform .3s ease;
}
.nav-links a:hover { color:#fff; }
.nav-links a:hover::after,
.nav-links a.active::after { transform:scaleX(1); }
.nav-links a.active { color:#fff; }
.nav-cta {
  background:var(--sky) !important;
  color:#fff !important;
  padding:9px 22px !important;
  font-weight:600 !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--sky-light) !important; }

/* Hamburger */
.nav-hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:6px;
  cursor:pointer;
  flex-shrink:0;
}
.nav-hamburger span {
  display:block;
  width:24px; height:2px;
  background:#ffffff;
  border-radius:2px;
  transition:var(--transition);
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.nav-mobile {
  display:none;
  flex-direction:column;
  background:var(--navy);
  padding:16px 32px 24px;
  border-top:1px solid rgba(255,255,255,.08);
}
.nav-mobile.open { display:flex; }
.nav-mobile a {
  color:rgba(255,255,255,.75);
  font-size:16px;
  font-weight:500;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:color .2s;
}
.nav-mobile a:hover { color:#fff; }
.nav-mobile .nav-cta {
  margin-top:12px;
  background:var(--sky) !important;
  color:#fff !important;
  text-align:center;
  border-radius:var(--radius);
  border:none !important;
  padding:14px !important;
}

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero {
  min-height:100vh;
  width:100%;
  background:
    linear-gradient(135deg, rgba(27,42,107,.97) 0%, rgba(15,26,62,.98) 100%),
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 40px,
      rgba(255,255,255,.015) 40px,
      rgba(255,255,255,.015) 41px
    );
  display:flex;
  align-items:center;
  padding-top:70px;
  position:relative;
  overflow:hidden;
}
.hero::before {
  content:'';
  position:absolute;
  top:-200px; right:-200px;
  width:700px; height:700px;
  background:radial-gradient(circle, rgba(43,159,216,.15) 0%, transparent 70%);
  pointer-events:none;
}
.hero::after {
  content:'';
  position:absolute;
  bottom:-100px; left:-100px;
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(43,159,216,.08) 0%, transparent 70%);
  pointer-events:none;
}
.hero-inner {
  max-width:1180px;
  margin:0 auto;
  padding:80px 32px;
  position:relative;
  z-index:2;
}
.hero-badge {
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:var(--cream-dark);
  font-size:12px;
  font-weight:500;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:8px 18px;
  border-radius:2px;
  margin-bottom:32px;
}
.hero-badge-dot {
  width:7px; height:7px;
  background:var(--sky-light);
  border-radius:50%;
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(.7); }
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(36px,5.5vw,68px);
  font-weight:900;
  color:var(--cream-bg);
  line-height:1.12;
  margin-bottom:24px;
  max-width:680px;
}
.hero-title em {
  font-style:normal;
  color:var(--olive-light);
}
.hero-desc {
  font-size:17px;
  color:var(--cream-dark);
  opacity:.8;
  max-width:480px;
  line-height:1.85;
  margin-bottom:44px;
}
.hero-btns {
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:80px;
}
.hero-stats {
  display:flex;
  gap:56px;
  flex-wrap:wrap;
}
.hero-stat-divider {
  width:1px;
  background:rgba(255,255,255,.15);
}
.hero-stat strong {
  display:block;
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,4vw,48px);
  font-weight:700;
  color:var(--cream-bg);
  line-height:1;
}
.hero-stat span {
  font-size:12px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--sky-light);
  margin-top:6px;
  display:block;
}
/* hero scroll indicator */
.hero-scroll {
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  color:rgba(255,255,255,.3);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  animation:bounce-down 2s infinite;
}
.hero-scroll-line {
  width:1px; height:40px;
  background:linear-gradient(to bottom, rgba(255,255,255,.3), transparent);
}
@keyframes bounce-down {
  0%,100% { transform:translateX(-50%) translateY(0); }
  50%      { transform:translateX(-50%) translateY(8px); }
}

/* ══════════════════════════════════════════════════════════
   ABOUT
══════════════════════════════════════════════════════════ */
.about { background:var(--bg-white); }
.about-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.about-img-wrap { position:relative; }
.about-img { width:100%; height:480px; object-fit:cover; border-radius:var(--radius); }
.about-img-placeholder {
  width:100%; height:480px;
  background:linear-gradient(145deg,var(--navy-mid),var(--navy));
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.3); font-size:13px; letter-spacing:1px; text-transform:uppercase;
}
.about-badge-exp {
  position:absolute; bottom:32px; right:-24px;
  background:var(--navy); color:#fff;
  padding:24px 28px; border-radius:var(--radius);
  box-shadow:var(--shadow-lg); text-align:center;
}
.about-badge-exp strong {
  font-family:'Playfair Display',serif; font-size:42px; font-weight:900;
  display:block; color:var(--sky-light); line-height:1;
}
.about-badge-exp span {
  font-size:12px; letter-spacing:1.5px; text-transform:uppercase;
  opacity:.7; margin-top:6px; display:block;
}
.about-values { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:36px; }
.value-card {
  padding:18px 16px; background:var(--bg-section);
  border-left:3px solid var(--sky); border-radius:0 var(--radius) var(--radius) 0;
}
.value-card strong {
  display:block; font-size:12px; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--navy); margin-bottom:6px;
}
.value-card p { font-size:13px; color:var(--text-muted); line-height:1.6; }

/* ══════════════════════════════════════════════════════════
   SERVICES
══════════════════════════════════════════════════════════ */
.services { background:var(--bg-section); }
.services-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:56px;
}
.service-card {
  background:var(--cream-white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.service-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}
.service-card-img {
  height:180px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:52px;
  position:relative;
  overflow:hidden;
}
.service-card-img::after {
  content:'';
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.15);
  transition:opacity .3s;
}
.service-card:hover .service-card-img::after { opacity:0; }
.s-bg-1 { background:linear-gradient(135deg,#3B2A1A,#6B4226); }
.s-bg-2 { background:linear-gradient(135deg,#4A5240,#2e3326); }
.s-bg-3 { background:linear-gradient(135deg,#6B4226,#A0673A); }
.s-bg-4 { background:linear-gradient(135deg,#3D4A32,#4A5240); }
.service-card-body { padding:24px; }
.service-card-body h3 {
  font-family:'Playfair Display',serif;
  font-size:18px;
  color:var(--navy);
  margin-bottom:10px;
}
.service-card-body p { font-size:14px; color:var(--text-muted); line-height:1.7; }
.service-card-link {
  display:inline-flex; align-items:center; gap:6px;
  margin-top:16px; font-size:13px; font-weight:600;
  color:var(--sky); transition:gap .2s;
}
.service-card:hover .service-card-link { gap:10px; }

/* ══════════════════════════════════════════════════════════
   WHY CHOOSE US
══════════════════════════════════════════════════════════ */
.why { background:var(--navy); }
.why .section-title { color:#ffffff; }
.why .section-sub  { color:rgba(255,255,255,.65); }
.why-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:rgba(255,255,255,.06);
  margin-top:56px;
  border:1px solid rgba(255,255,255,.06);
}
.why-item {
  padding:40px 36px;
  background:rgba(255,255,255,.02);
  transition:background .3s;
}
.why-item:hover { background:rgba(255,255,255,.06); }
.why-num {
  font-family:'Playfair Display',serif; font-size:52px; font-weight:900;
  color:var(--sky-light); opacity:.35; line-height:1; margin-bottom:16px;
}
.why-item h3 {
  font-family:'Playfair Display',serif; font-size:18px;
  color:#ffffff; margin-bottom:12px;
}
.why-item p { font-size:14px; color:rgba(255,255,255,.6); line-height:1.8; }

/* ══════════════════════════════════════════════════════════
   PROJECTS
══════════════════════════════════════════════════════════ */
.projects { background:var(--bg-white); }
.projects-filter {
  display:flex; gap:10px; flex-wrap:wrap; margin:40px 0 32px;
}
.filter-btn {
  padding:8px 20px; border-radius:var(--radius);
  font-size:13px; font-weight:600;
  border:1.5px solid var(--bg-bluegrey);
  background:transparent; color:var(--text-muted); transition:var(--transition);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--navy); border-color:var(--navy); color:#fff;
}
.projects-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.project-card {
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  height:260px;
  cursor:pointer;
  transition:var(--transition);
}
.project-card:hover { transform:scale(1.02); box-shadow:var(--shadow-lg); }
.project-card-bg {
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .5s ease;
}
.project-card:hover .project-card-bg { transform:scale(1.07); }
.project-card-bg-placeholder {
  width:100%; height:100%;
  display:flex;
  align-items:flex-end;
  padding:24px;
}
.project-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(20,12,4,.88) 0%, transparent 55%);
  transition:opacity .3s;
}
.project-info {
  position:absolute;
  bottom:0; left:0; right:0;
  padding:24px;
  z-index:2;
  transform:translateY(4px);
  transition:transform .3s;
}
.project-card:hover .project-info { transform:translateY(0); }
.project-info h4 {
  font-family:'Playfair Display',serif;
  font-size:17px;
  color:#fff;
  margin-bottom:6px;
}
.project-type-badge {
  display:inline-block;
  background:var(--sky);
  color:#fff;
  font-size:11px;
  font-weight:600;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:2px;
}
.p-bg-1 { background:linear-gradient(135deg,#1B2A6B,#0F1A3E); }
.p-bg-2 { background:linear-gradient(135deg,#243580,#1B2A6B); }
.p-bg-3 { background:linear-gradient(135deg,#2B9FD8,#1B6E9E); }
.p-bg-4 { background:linear-gradient(135deg,#1a3a70,#0d2050); }
.p-bg-5 { background:linear-gradient(135deg,#2E4299,#1B2A6B); }
.p-bg-6 { background:linear-gradient(135deg,#1B6E9E,#124f73); }

/* ══════════════════════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════════════════════ */
.testimonials { background:var(--bg-section); }
.testi-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:56px;
}
.testi-card {
  background:var(--bg-white); border-radius:var(--radius);
  padding:36px 32px; box-shadow:var(--shadow-sm);
  position:relative; transition:var(--transition);
}
.testi-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.testi-card::before {
  content:'\201C'; position:absolute; top:20px; right:24px;
  font-family:'Playfair Display',serif; font-size:80px;
  color:var(--bg-bluegrey); line-height:1;
}
.testi-stars { color:var(--sky); font-size:15px; letter-spacing:2px; margin-bottom:16px; }
.testi-card p {
  font-size:15px; color:var(--text-muted); line-height:1.85;
  font-style:italic; margin-bottom:28px;
}
.testi-author strong { display:block; font-size:15px; color:var(--navy); font-weight:600; }
.testi-author span  { font-size:13px; color:var(--sky); }

/* ══════════════════════════════════════════════════════════
   CTA STRIP
══════════════════════════════════════════════════════════ */
.cta-strip { background:var(--navy-mid); padding:56px 0; }
.cta-strip-inner {
  max-width:1180px; margin:0 auto; padding:0 32px;
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
}
.cta-strip h2 {
  font-family:'Playfair Display',serif;
  font-size:clamp(22px,3vw,32px); color:#ffffff;
}
.cta-strip p { color:rgba(255,255,255,.65); font-size:15px; margin-top:6px; }

/* ══════════════════════════════════════════════════════════
   CONTACT
══════════════════════════════════════════════════════════ */
.contact { background:var(--bg-white); }
.contact-grid {
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:72px; align-items:start;
}
.contact-details { display:flex; flex-direction:column; gap:22px; margin-top:32px; }
.contact-item { display:flex; align-items:flex-start; gap:16px; }
.contact-icon {
  width:46px; height:46px; background:var(--bg-section);
  border:1px solid var(--bg-bluegrey); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex-shrink:0;
}
.contact-item-text strong {
  display:block; font-size:11px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--sky); font-weight:700; margin-bottom:4px;
}
.contact-item-text span { font-size:15px; color:var(--text-body); }
.contact-form {
  background:var(--bg-section); padding:44px 40px;
  border-radius:var(--radius); box-shadow:var(--shadow-sm);
}
.contact-form h3 {
  font-family:'Playfair Display',serif; font-size:22px;
  color:var(--navy); margin-bottom:28px;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; margin-bottom:16px; }
.form-group label {
  font-size:11px; font-weight:700; letter-spacing:1.2px;
  text-transform:uppercase; color:var(--navy-mid); margin-bottom:8px;
}
.form-group input, .form-group select, .form-group textarea {
  background:var(--bg-white); border:1.5px solid var(--bg-bluegrey);
  border-radius:var(--radius); padding:12px 16px;
  font-family:'DM Sans',sans-serif; font-size:15px;
  color:var(--text-body); outline:none; transition:border-color .2s;
}
.form-group input:focus, .form-group select:focus,
.form-group textarea:focus { border-color:var(--sky); }
.form-group textarea { height:110px; resize:vertical; }
.form-submit {
  width:100%; margin-top:8px; padding:16px;
  background:var(--navy); color:#fff; border:none;
  border-radius:var(--radius); font-family:'DM Sans',sans-serif;
  font-size:15px; font-weight:600; letter-spacing:1px;
  text-transform:uppercase; transition:var(--transition);
}
.form-submit:hover { background:var(--sky); transform:translateY(-1px); }
.form-success {
  display:none; background:#d4edda; color:#155724;
  border:1px solid #c3e6cb; border-radius:var(--radius);
  padding:16px; text-align:center; font-weight:600; margin-top:16px;
}
.form-error-msg { color:#c0392b; font-size:12px; margin-top:4px; display:none; }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
footer { background:#0A1030; padding:70px 0 28px; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:52px;
}
.footer-brand .logo-wrap { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer-brand p {
  color:rgba(255,255,255,.4); font-size:14px;
  line-height:1.85; max-width:260px; margin-bottom:24px;
}
.footer-socials { display:flex; gap:10px; }
.footer-social {
  width:38px; height:38px; background:rgba(255,255,255,.07);
  border-radius:var(--radius); display:flex; align-items:center;
  justify-content:center; color:rgba(255,255,255,.45);
  font-size:15px; font-weight:700; transition:var(--transition);
}
.footer-social:hover { background:var(--sky); color:#fff; }
.footer-col h4 {
  font-size:11px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; color:rgba(255,255,255,.7); margin-bottom:20px;
}
.footer-col li { margin-bottom:10px; }
.footer-col a { color:rgba(255,255,255,.4); font-size:14px; transition:color .2s; }
.footer-col a:hover { color:rgba(255,255,255,.8); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.07); padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  color:rgba(255,255,255,.28); font-size:13px; flex-wrap:wrap; gap:12px;
}

/* ══════════════════════════════════════════════════════════
   PAGE HERO (inner pages)
══════════════════════════════════════════════════════════ */
.page-hero {
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
  padding:120px 0 60px; text-align:center;
}
.page-hero h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,5vw,52px); font-weight:900;
  color:#ffffff; margin-bottom:14px;
}
.page-hero p { color:rgba(255,255,255,.65); font-size:16px; }
.breadcrumb {
  display:flex; align-items:center; justify-content:center;
  gap:8px; margin-top:16px; font-size:13px; color:rgba(255,255,255,.45);
}
.breadcrumb a { color:var(--sky-light); }
.breadcrumb a:hover { color:#fff; }

/* ══════════════════════════════════════════════════════════
   AOS overrides
══════════════════════════════════════════════════════════ */
[data-aos] { transition-property:transform,opacity !important; }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
  .services-grid  { grid-template-columns:repeat(2,1fr); }
  .why-grid       { grid-template-columns:repeat(2,1fr); }
  .footer-grid    { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .nav-links     { display:none; }
  .nav-hamburger { display:flex; }
  .about-grid    { grid-template-columns:1fr; }
  .about-badge-exp { right:16px; }
  .about-values  { grid-template-columns:1fr; }
  .services-grid { grid-template-columns:1fr; }
  .why-grid      { grid-template-columns:1fr; }
  .projects-grid { grid-template-columns:1fr 1fr; }
  .testi-grid    { grid-template-columns:1fr; }
  .contact-grid  { grid-template-columns:1fr; }
  .form-row      { grid-template-columns:1fr; }
  .footer-grid   { grid-template-columns:1fr; }
  .cta-strip-inner { flex-direction:column; text-align:center; }
  .hero-stats    { gap:32px; }
  .hero-stat-divider { display:none; }
  .hero-btns     { flex-direction:column; }
  .hero-btns .btn { text-align:center; justify-content:center; }
}
@media (max-width:480px) {
  .container      { padding:0 20px; }
  .section-pad    { padding:64px 0; }
  .projects-grid  { grid-template-columns:1fr; }
  .contact-form   { padding:28px 20px; }
  .hero-inner     { padding:60px 20px; }
}

.whatsapp-float {
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:999;
  width:56px; height:56px;
  background:#25D366;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  transition:var(--transition);
}

.whatsapp-float:hover { transform:scale(1.1); }
.whatsapp-float::before {
  content:'';
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:2px solid rgba(37,211,102,.5);
  animation:wa-pulse 2s infinite;
}
@keyframes wa-pulse {
  0%   { transform:scale(1);   opacity:1; }
  100% { transform:scale(1.5); opacity:0; }
}

/* ══════════════════════════════════════════════════════════
   PHASE 2 MOBILE FIXES
══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* About page — Vision/Mission/Values: 3 cols → 1 col */
  .section-pad [style*="repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* About page — Team: 5 cols → 2 cols */
  .section-pad [style*="repeat(5,1fr)"] {
    grid-template-columns: 1fr 1fr !important;
  }

  /* About + Projects — Stats: 4 cols → 2 cols */
  .section-pad [style*="repeat(4,1fr)"],
  section [style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr 1fr !important;
  }

  /* Contact page — Info cards: 4 cols → 1 col */
  section [style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* Contact page — Process steps: 4 cols → 2 cols */
  .section-pad [style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr 1fr !important;
  }

  /* Services page — detail grid reverse fix */
  .service-detail-grid.reverse {
    direction: ltr !important;
  }

  /* Founder section grid */
  [style*="grid-template-columns:340px"] {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 480px) {
  /* On very small screens — everything single column */
  .section-pad [style*="repeat(3,1fr)"],
  .section-pad [style*="repeat(4,1fr)"],
  .section-pad [style*="repeat(5,1fr)"],
  section [style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr !important;
  }
}