/* =========================================================
   FULL SITE STYLESHEET — complete from top to bottom
   (Paths to uploaded assets you provided)
   Logo: /mnt/data/logo.jpg
   Hero video (examples): /mnt/data/5644254-hd_1920_1080_25fps.mp4
   ZIP contents folder: /mnt/data/lowveld_extracted/LOWVELD/
   ========================================================= */

/* =========================================================
   RESET + BASE
   ========================================================= */
:root{
  --accent:#0073e6;    /* primary blue accent (matches reference) */
  --accent-2:#1db954;  /* optional green */
  --muted:#777;
  --bg:#ffffff;
  --page-bg:#f9f9f9;
  --card:#f3f3f3;
  --max-width:1200px;
  --radius:12px;
  --transition:0.28s ease;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-family: "Helvetica Neue", Arial, sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  scroll-behavior: smooth;
  font-size: 16px;
  height:100%;
}

body {
  min-height:100%;
  background: var(--page-bg);
  color: #222;
  line-height:1.55;
  -webkit-text-size-adjust:100%;
}

/* Utility containers */
.container {
  width:90%;
  max-width:var(--max-width);
  margin:0 auto;
}

/* Links & images */
a { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; height:auto; }

/* =========================================================
   HEADER — White header with left logo, right hamburger/nav
   Matches the HTML:
   <header class="header"> ... <div id="navToggle" class="nav-toggle"> ... <nav id="navMenu" class="nav-menu">
   ========================================================= */
.top-banner {
  width: 100%;
  background: #0078ff;
  color: white;
  padding: 8px 0;
  text-align: center;
  font-weight: 600;
  font-size: 0.95rem;
  display: flex;
  justify-content: center;
  gap: 30px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2000;
}

.header {
  width:100%;
  background: var(--bg); /* white header so black logo shows */
  position: fixed;
  top:20px;
  left:0;
  z-index:1200;
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}
/* Ensure header itself is a flex row even without .container */
.header {
    display: flex;
    align-items: center;
    justify-content: space-between; /* pushes hamburger to the right */
    padding: 14px 20px;
}
.page-offset {
  padding-top: 121px;
}



/* inner layout */
.header .container {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}

/* logo */
.logo img {
  height:70px;
  width:auto;
  display:block;
  transform: scale(1.25);          /* make logo bigger */
  transform-origin: left center;   /* keeps alignment clean */
}

/* desktop nav */
.nav-menu {
  display:flex;
  gap:30px;
  align-items:center;
}

.nav-menu a {
  font-weight:600;
  color:#111;
  padding:6px 4px;
  transition: color var(--transition), transform var(--transition);
  border-radius:6px;
}

.nav-menu a:hover {
  color:var(--accent);
  transform:translateY(-1px);
}

/* nav-toggle (hamburger) — hidden on desktop */
.nav-toggle {
  display:none;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  user-select:none;
  -webkit-tap-highlight-color: transparent;
}

/* ensure page content doesn't hide under header */
.page-offset { padding-top: 86px; } /* add class to main wrapper or body padding-top:86px; */

/* =========================================================
   HERO — video background, overlay, centered text + CTA
   HTML expected:
   <section class="hero">
     <video class="hero-video" ...>...</video>
     <div class="hero-overlay"></div>
     <div class="hero-text">...</div>
   </section>
   ========================================================= */

.hero {
  position:relative;
  width:100%;
  height:85vh;
  min-height:480px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:linear-gradient(180deg, rgba(6,20,34,0.04), rgba(6,20,34,0.02));
}

/* video fills area */
.hero-video {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  -webkit-user-select:none;
  user-select:none;
  pointer-events:none;
}

/* subtle overlay for readability */
.hero-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.28), rgba(0,0,0,0.32));
  z-index:1;
}

/* text sits above video/overlay */
.hero-text {
  position:relative;
  z-index:2;
  color:#fff;
  padding: 0 18px;
  max-width:1000px;
}

.hero-text h1 {
  font-size: clamp(2rem, 4.2vw, 3.4rem);
  margin-bottom: .5rem;
  line-height:1.02;
  font-weight:700;
  letter-spacing:-0.5px;
  text-shadow: 0 6px 18px rgba(0,0,0,0.35);
}

.hero-text p{
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  color: rgba(255,255,255,0.92);
  margin-bottom: 18px;
}

/* CTA */
.cta-btn {
  display:inline-block;
  padding:12px 30px;
  background:var(--accent);
  color:#fff;
  border-radius:30px;
  font-weight:700;
  box-shadow: 0 8px 24px rgba(7,90,160,0.15);
  transition: transform var(--transition), background var(--transition);
}
.cta-btn:hover { transform: translateY(-3px); background:#005bb5; }

/* =========================================================
   SERVICES — cards grid
   ========================================================= */

.services {
  background: var(--bg);
  padding:80px 0;
}

.services .container { text-align:center; }

.services h2 {
  color:var(--accent);
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  margin-bottom:18px;
}

.service-cards {
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:28px;
}

.service-card {
  background:var(--card);
  padding:26px;
  border-radius:var(--radius);
  width:280px;
  box-shadow: 0 8px 20px rgba(16,24,40,0.04);
  transition: transform var(--transition), box-shadow var(--transition);
}
.service-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 18px 40px rgba(16,24,40,0.08);
}
.service-card h3 { margin:14px 0; font-size:1.15rem; color:#111; }
.service-card ul { list-style:none; padding-left:0; margin-top:6px; color:var(--muted); }
.service-card ul li { margin:8px 0; font-size:.98rem; }

/* =========================================================
   AREAS / LOCATIONS (grid of cards)
   ========================================================= */

.areas {
  background: linear-gradient(180deg, #e8f7ff 0%, #f6fbff 100%);
  padding:72px 0;
}
.areas .container { text-align:center; }
.areas h2 { color:var(--accent); font-size:2.1rem; margin-bottom:10px; }
.areas-intro { color:var(--muted); max-width:760px; margin:0 auto 22px; }

/* responsive auto-fit grid */
.areas-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap:14px;
  margin-top:20px;
}

.area-card {
  background:#fff;
  border-radius:10px;
  padding:14px 12px;
  border:1px solid #e6f3ff;
  font-weight:700;
  color:#222;
  text-align:center;
  transition: transform var(--transition), box-shadow var(--transition);
}
.area-card:hover { transform: translateY(-6px); box-shadow: 0 12px 30px rgba(3,50,90,0.06); }

/* =========================================================
   PORTFOLIO (grid)
   ========================================================= */

.portfolio-section {
  background:var(--bg);
  padding:80px 0;
}
.portfolio-section h2 { color:var(--accent); text-align:center; font-size:2rem; margin-bottom:10px;}
.portfolio-intro { text-align:center; color:var(--muted); max-width:780px; margin:0 auto 28px; }

.portfolio-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:20px;
}
.portfolio-item {
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  box-shadow: 0 10px 28px rgba(8,20,40,0.06);
  transition: transform var(--transition);
}
.portfolio-item img {
  width:100%;
  height:220px;
  object-fit:cover;
  transition: transform .45s ease, opacity .45s ease;
}
.portfolio-item:hover { transform: translateY(-8px); }
.portfolio-item:hover img { transform: scale(1.06); opacity:0.95; }

/* =========================================================
   ABOUT (hero + content)
   ========================================================= */

.about-hero {
  height:46vh;
  min-height:300px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  background: linear-gradient(180deg, rgba(0,115,230,0.95), rgba(0,115,230,0.85));
}
.about-hero h1 { font-size:2.6rem; margin-bottom:8px; }
.about-content { background:var(--page-bg); padding:70px 0; }
.about-content .container { max-width:1000px; margin:0 auto; }
.about-content h2 { color:var(--accent); margin-bottom:12px; }
.about-content p, .about-content ul li { color:var(--muted); margin-bottom:12px; }

/* =========================================================
   CONTACT (hero + buttons + form + map)
   ========================================================= */

.contact-hero { padding:64px 0; background:linear-gradient(180deg,#e0f7ff, #f8feff); text-align:center; color:var(--accent); }
.contact-hero h1 { font-size:2.4rem; margin-bottom:8px; }
.contact-hero p { color:#333; margin-bottom:14px; }

.contact-buttons { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; margin:26px 0; }
.contact-btn {
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 18px;
  border-radius:40px;
  border:2px solid var(--accent);
  background:#fff;
  color:var(--accent);
  font-weight:700;
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.contact-btn svg { width:20px; height:20px; display:block; }
.contact-btn:hover { background:var(--accent); color:#fff; transform:translateY(-4px); }

.contact-form-section { padding:72px 0; background:var(--bg); }
.contact-form { max-width:720px; margin:0 auto; display:grid; gap:14px; }
.contact-form input, .contact-form textarea {
  padding:12px 14px; border-radius:8px; border:1px solid #e0e0e0; font-size:1rem; color:#111; width:100%;
}
.contact-form textarea { min-height:140px; resize:vertical; }
.submit-btn {
  padding:12px 20px; border-radius:30px; border:none; background:var(--accent); color:#fff; font-weight:700; cursor:pointer;
}
.submit-btn:hover { background:#005bb5; }

/* map placeholder box */
.map-box { width:100%; max-width:920px; height:380px; margin:18px auto 0; border-radius:10px; overflow:hidden; box-shadow:0 10px 30px rgba(8,20,40,0.06); }

/* =========================================================
   FOOTER
   ========================================================= */

footer {
  background:#111;
  color:#fff;
  padding:50px 0;
  text-align:center;
}
footer a { color:#fff; text-decoration:underline; }

/* =========================================================
   HAMBURGER / MOBILE NAV behavior (clean, centered dropdown)
   Works with HTML IDs: #navToggle (nav-toggle clickable), #navMenu (nav container)
   ========================================================= */

/* make hamburger visible on small screens and hide desktop nav */
@media (max-width: 900px) {
  .nav-toggle { display:block; }
  .nav-menu { display:none; } /* base hidden; JS toggles .open */
  /* when open we'll show block and center it (JS adds .open to #navMenu) */
  .nav-menu.open {
    display:flex;
    position: fixed;
    top: 74px;
    left: 50%;
    transform: translateX(-50%) scale(1);
    width: 92%;
    max-width:420px;
    padding:20px 18px;
    background:#fff;
    border-radius:12px;
    box-shadow:0 20px 50px rgba(4,18,40,0.12);
    flex-direction:column;
    gap:8px;
    z-index:1205;
  }
}

/* subtle responsive adjustments */
@media (max-width: 768px) {
  .hero { height:66vh; min-height:360px; }
  .hero-text h1 { font-size: clamp(1.6rem, 6vw, 2.25rem); }
  .hero-text p { font-size: .98rem; }
  .service-card { width:100%; max-width:420px; }
  .portfolio-item img { height:180px; }
}

/* tilt-proof small devices */
@media (max-width: 420px) {
  .logo img { height:48px; }
  .nav-menu a { font-size:15px; }
  .nav-menu.open { width:95%; }
  .cta-btn { padding:10px 18px; font-size:0.95rem; }
}

/* =========================================================
   UTILITY CLASSES (helpers)
   ========================================================= */

.text-center { text-align:center; }
.mt-10 { margin-top:10px; }
.mb-10 { margin-bottom:10px; }
.hidden { display:none !important; }

/* =========================================================
   END OF STYLESHEET
   ========================================================= */
.top-banner {
  width: 100%;
  background: #0078ff;
  color: white;
  padding: 8px 0;
  text-align: center;
  font-weight: 600;
  font-size: 0.95rem;
  display: flex;
  justify-content: center;
  gap: 30px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2000;
}
header {
  margin-top: 35px;
}


@media (max-width: 480px) {
  .top-banner p {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
}
