* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Inter',sans-serif; background:#fff; color:#000; line-height:1.7; overflow-x:hidden; }
.container { width:90%; max-width:1400px; margin:0 auto; }

/* HEADER */
.header { position:fixed; top:0; left:0; right:0; z-index:1000; height:90px; background:linear-gradient(to right,#ffffff 0%,#ffffff 45%,#0d1b3d 100%); backdrop-filter:blur(20px); border-bottom:1px solid rgba(0,0,0,0.08); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:100%; padding:0 5%; position:relative; }
.logo-text { display:flex; align-items:center; gap:16px; }
.logo-img { height:54px; }
.brand-name { font-size:1.55rem; font-weight:800; color:#000; letter-spacing:-0.6px; text-decoration:none; }
.center-nav-group { display:flex; align-items:center; justify-content:center; gap:3.2rem; padding:12px 38px; border:2px solid #000; border-radius:50px; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); background:transparent; height:56px; }
.nav-link { color:#000 !important; font-weight:600; font-size:1.05rem; text-decoration:none; white-space:nowrap; }
.dropdown { position:relative; }
.dropbtn { display:flex; align-items:center; gap:6px; }
.dropdown-content { display:none; position:absolute; top:100%; left:50%; transform:translateX(-50%); background:#0d1b3d; min-width:220px; border-radius:12px; overflow:hidden; box-shadow:0 15px 40px rgba(0,0,0,0.3); margin-top:12px; }
.dropdown-content a { color:#fff; padding:14px 20px; display:block; text-decoration:none; font-weight:500; }
.dropdown-content a:hover { background:#0250b4; }
.dropdown:hover .dropdown-content { display:block; }
.btn-quote-outline { color:#000; font-weight:700; font-size:1rem; padding:10px 26px; border:2px solid #000; border-radius:50px; text-decoration:none; transition:all .3s; }
.btn-quote-outline:hover { background:#000; color:#fff; }
@media (max-width:1000px) { .center-nav-group { display:none; } }

/* HERO */
.hero-final { position:relative; height:100vh; min-height:720px; overflow:hidden; }
.hero-bg-image { position:absolute; top:0; left:0; right:0; bottom:0; z-index:1; }
.hero-main-img { width:100%; height:100%; object-fit:cover; display:block; image-rendering:-webkit-optimize-contrast; image-rendering:crisp-edges; }
.location-tag, .seda-support { position:absolute; bottom:30px; color:#fff; font-size:1.1rem; font-weight:500; text-shadow:0 2px 12px rgba(0,0,0,0.7); z-index:10; }
.location-tag { right:40px; }
.seda-support { left:40px; }
.hero-content-final { position:absolute; top:50%; left:8%; transform:translateY(-50%); z-index:10; }
.hero-main-title { font-weight:900; font-size:8.2rem; line-height:0.88; letter-spacing:-5px; color:#fff; text-transform:uppercase; margin:0 0 2.5rem 0; text-shadow:0 15px 40px rgba(0,0,0,0.7); }
.play-slides-btn { background:transparent; color:#fff; border:2.5px solid #fff; padding:16px 42px; border-radius:50px; font-size:1.2rem; font-weight:700; cursor:pointer; transition:all .5s; }
.play-slides-btn:hover { background:#fff; color:#000; }

/* HERO POPUP */
/* HERO POPUP – PERFECT CENTERING & RESPONSIVE GRID */
.services-popup {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.95);
  backdrop-filter: blur(20px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all .6s ease;
  padding: 2rem;
}
.services-popup.active {
  opacity: 1;
  visibility: visible;
}

.popup-content {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.popup-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  padding: 3rem 1rem;
}

/* Perfect 4-card layout on desktop */
@media (max-width: 1024px) {
  .popup-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .popup-grid { grid-template-columns: 1fr; }
}

/* CARDS – PERFECT SIZE & ALIGNMENT */
.popup-card {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 28px;
  padding: 3rem 2rem;
  text-align: center;
  color: #fff;
  text-decoration: none;
  opacity: 0;
  transform: translateY(60px) scale(0.92);
  transition: all 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
  backdrop-filter: blur(12px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.3);
}

.popup-card.show {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.popup-card:hover {
  background: rgba(2,80,180,0.5);
  transform: translateY(-15px) scale(1.05) !important;
  box-shadow: 0 30px 70px rgba(2,80,180,0.4);
  border-color: #0250b4;
}

.popup-card h3 {
  font-size: 1.9rem;
  font-weight: 800;
  margin-bottom: 1rem;
  color: #fff !important;
}

.popup-card p {
  font-size: 1.15rem;
  opacity: 0.95;
  line-height: 1.6;
}

/* CLOSE BUTTON – PERFECTLY CENTERED BELOW */
.close-popup {
  position: absolute;
  bottom: -90px;
  left: 50%;
  transform: translateX(-50%);
  background: transparent;
  color: #fff;
  border: 2.5px solid #fff;
  padding: 14px 50px;
  border-radius: 50px;
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .4s;
  white-space: nowrap;
}
.close-popup:hover {
  background: #fff;
  color: #000;
}
.play-slides-btn {
  background: transparent;
  color: #fff;
  border: 3px solid #fff;
  padding: 18px 48px;
  border-radius: 60px;
  font-size: 1.35rem;
  font-weight: 800;
  cursor: pointer;
  transition: all .5s ease;
  text-transform: uppercase;
  letter-spacing: 1px;
  backdrop-filter: blur(10px);
}
.play-slides-btn:hover {
  background: #fff;
  color: #000;
  transform: scale(1.08);
}

/* ABOUT US – PERFECTLY BALANCED */
.about-us-full { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; padding:6rem 5%; background:#fff; }
.about-us-bg { position:absolute; top:0; left:0; right:0; bottom:0; background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%); z-index:1; }
.about-us-content { position:relative; z-index:2; text-align:center; max-width:1200px; }
.about-us-title { font-weight:900; font-size:7.8rem; line-height:0.92; letter-spacing:-5px; color:#000; text-transform:uppercase; margin:0 0 2rem 0; }
.about-us-text { font-size:1.5rem; line-height:1.7; color:#333; max-width:900px; margin:0 auto 3rem auto; font-weight:500; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2.5rem; max-width:1100px; margin:0 auto 3rem auto; }
.stat-card { background:#fff; padding:2.8rem 1.5rem; border-radius:28px; box-shadow:0 15px 40px rgba(0,0,0,0.08); transition:all .6s cubic-bezier(0.34,1.56,0.64,1); position:relative; overflow:hidden; }
.stat-card:hover { transform:translateY(-25px) scale(1.05); box-shadow:0 40px 90px rgba(2,80,180,0.3); }
.stat-card:hover .stat-number { color:#0250b4; transform:scale(1.1); }
.stat-label { font-size:1.05rem; color:#666; margin-bottom:0.8rem; font-weight:600; }
.stat-number { font-size:4.2rem; font-weight:900; color:#000; margin:0; transition:all .6s; }
.stat-number .plus { font-size:2.8rem; color:#0250b4; vertical-align:top; }
.mpumalanga-signature { font-family:'Dancing Script',cursive; font-size:3.2rem; color:#0250b4; font-weight:700; margin-top:1rem; }

/* WHAT WE DO – PERFECT CARD ALIGNMENT */
.what-we-do { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; padding:8rem 5%; background:#fff; }
.what-we-do-bg { position:absolute; top:0; left:0; right:0; bottom:0; background:linear-gradient(135deg,#f8f9ff 0%,#eef2ff 100%); z-index:1; }
.what-we-do-content { position:relative; z-index:2; text-align:center; max-width:1400px; }
.what-we-do-title { font-weight:900; font-size:8.2rem; line-height:0.9; letter-spacing:-6px; color:#000; text-transform:uppercase; margin:0 0 4rem 0; }
.services-cards-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:3rem; max-width:1300px; margin:0 auto 5rem auto; }
.service-card-modern { background:#fff; padding:3.5rem 2.5rem; border-radius:36px; box-shadow:0 20px 60px rgba(0,0,0,0.1); transition:all .7s cubic-bezier(0.25,0.8,0.25,1); position:relative; overflow:hidden; border:2px solid transparent; }
.service-card-modern:hover { transform:translateY(-28px) scale(1.04); box-shadow:0 50px 100px rgba(2,80,180,0.25); border-color:#0250b4; }
.service-card-modern:nth-child(odd):hover { background:#0250b4; color:#fff; }
.service-card-modern:nth-child(even):hover { background:#000; color:#fff; }
.service-card-modern h3 { font-size:1.9rem; font-weight:800; margin-bottom:1rem; transition:all .5s; }
.service-card-modern:hover h3 { transform:translateY(-8px); letter-spacing:1px; }
.service-card-modern p { font-size:1.1rem; line-height:1.7; margin-bottom:2rem; opacity:0.9; }
.btn-learn-more { display:inline-block; background:transparent; color:#000; border:2.2px solid #000; padding:14px 38px; border-radius:50px; font-size:1.05rem; font-weight:700; text-decoration:none; transition:all .4s; text-transform:uppercase; }
.btn-learn-more:hover { background:#000; color:#fff; }
.service-card-modern:hover .btn-learn-more { background:#fff !important; color:#000 !important; border-color:#fff !important; }

/* CONTACT BUTTONS IN WHAT WE DO */
.what-we-do-cta { display:flex; gap:2rem; justify-content:center; flex-wrap:wrap; }
.btn-contact-header-style { background:transparent; color:#000; border:2.5px solid #000; padding:18px 50px; border-radius:50px; font-size:1.3rem; font-weight:700; text-decoration:none; transition:all .4s; display:inline-block; }
.btn-contact-header-style:hover { background:#000; color:#fff; }
.btn-contact-header-style.primary { background:#0250b4; color:#fff; border-color:#0250b4; }
.btn-contact-header-style.primary:hover { background:#003d8a; }

/* CLEAN, NORMAL, BLACK FOOTER – NO SPACE, NO BLUE, NO BIG TEXT */
.footer-clean {
  background: #000;
  color: #fff;
  margin-top: 0 !important;
  padding: 3rem 0 2rem;
  border-top: 4px solid #000;
  font-family: 'Inter', sans-serif;
}

.footer-border-top {
  height: 4px;
  background: #000;
}

.footer-clean-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
  padding: 0 5%;
  max-width: 1400px;
  margin: 0 auto;
}

.footer-logo {
  height: 50px;
  filter: brightness(0) invert(1);
}

.copyright {
  margin: 1rem 0 0;
  font-size: 0.95rem;
  opacity: 0.8;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  flex: 1;
  min-width: 300px;
}

.footer-links a {
  color: #ccc;
  text-decoration: none;
  font-size: 1rem;
  font-weight: 600;
  transition: all .3s;
}

.footer-links a:hover {
  color: #fff;
}

.footer-right p {
  margin: 0.5rem 0;
  font-size: 1rem;
  text-align: right;
}

.highlight {
  color: #0250b4 !important;
  font-weight: 700;
}

.dev {
  font-size: 0.9rem;
  opacity: 0.8;
  margin-top: 1rem;
}

.footer-right a {
  color: #fff;
  text-decoration: underline;
}

/* MOBILE – PERFECT */
@media (max-width: 868px) {
  .footer-clean-inner {
    flex-direction: column;
    text-align: center;
  }
  .footer-left, .footer-right {
    text-align: center;
  }
  .footer-links {
    order: 3;
    margin-top: 1rem;
  }
  .footer-right p {
    text-align: center;
  }
}
/* EXTRA MOBILE FIXES – YOUR SITE NOW 100% PHONE PERFECT */
@media (max-width: 768px) {
  .hero-main-title { font-size: 4.8rem !important; letter-spacing: -3px; }
  .about-us-title, .what-we-do-title { font-size: 4.5rem !important; }
  .stats-grid, .services-cards-grid { grid-template-columns: 1fr !important; }
  .service-card-modern, .stat-card { padding: 2.5rem 1.8rem; }
  .btn-learn-more, .btn-contact-header-style { padding: 16px 36px; font-size: 1.1rem; }
  .service-hero .service-title { font-size: 4.2rem !important; }
  .service-grid { grid-template-columns: 1fr; }
  .play-slides-btn { padding: 16px 36px; font-size: 1.1rem; }
  .popup-grid { grid-template-columns: 1fr !important; gap: 1.5rem; }
  .close-popup { bottom: -70px; padding: 12px 36px; font-size: 1rem; }
}