:root{
  --bg:#f6f7f9;
  --text:#121212;
  --muted:rgba(18,18,18,0.62);
  --border:rgba(0,0,0,0.08);
  --shadow2:0 10px 25px rgba(0,0,0,0.08);
  --blue:#1E88E5;
  --blue2:#63A4FF;
  --greySolid:#e6e7ea;

  /* Mobile header height (set by JS) */
  --mobileHeaderH:78px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;overflow-x:hidden;}

body{
  font-family:"Poppins",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
}

.container{width:90%;max-width:1100px;margin:0 auto;}

.kicker{
  font-size:.95rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(18,18,18,0.55);
  margin-bottom:.6rem;
}
.subtext{color:var(--muted);margin-top:.7rem;font-size:1.05rem;max-width:820px;}
.muted{color:var(--muted);}

#services,#gallery,#contact,#quote{scroll-margin-top:130px;}

/* =========================
   HEADER (DESKTOP)
========================= */
header{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  width:90%;
  max-width:1200px;
  background:rgba(147,147,147,0.92);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.18);
  padding:.8rem 1.2rem;
  border-radius:15px;
  box-shadow:0 10px 30px rgba(0,0,0,0.16);
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.logo{
  font-family:"Playfair Display",serif;
  font-size:2rem;
  font-weight:700;
  background:linear-gradient(to right,#4a6ea9,#001f4d);
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  text-decoration:none;
  white-space:nowrap;
}

.header-right{display:flex;align-items:center;gap:.75rem;}

.nav ul{list-style:none;display:flex;gap:1.2rem;align-items:center;}
.nav a{
  text-decoration:none;
  color:#fff;
  font-weight:600;
  position:relative;
  padding:.2rem 0;
  transition:color .25s ease;
}
.nav a:hover,.nav a.active{color:var(--blue2);}
.nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  height:2px;
  width:100%;
  background:var(--blue2);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .28s ease;
  opacity:.95;
}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);}

.quote-btn{
  background:var(--blue);
  color:#fff;
  border:none;
  padding:.55rem .95rem;
  border-radius:12px;
  cursor:pointer;
  font-weight:800;
  box-shadow:0 12px 25px rgba(30,136,229,0.28);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.quote-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 35px rgba(30,136,229,0.34);
  background:#197fd6;
}

.hamburger{display:none;background:transparent;border:none;cursor:pointer;padding:.35rem;}
.hamburger span{
  display:block;width:26px;height:3px;background:#fff;border-radius:2px;margin:5px 0;
  transition:transform .28s cubic-bezier(.2,.8,.2,1), opacity .2s ease;
}
.hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

.nav-overlay{display:none;}
.mobile-nav{display:none;}
body.nav-open{overflow:hidden;}

/* =========================
   HERO (DESKTOP)
========================= */
.hero{
  height:100vh;
  min-height:100vh;
  width:100%;
  position:relative;
  overflow:hidden;
  background:#000;
}
.hero-media{
  position:absolute;
  inset:0;
  z-index:1;
}
.hero video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  filter:brightness(0.95) saturate(0.9);
}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.22);z-index:2;pointer-events:none;}
.hero-buttons-bottom{
  position:absolute;
  left:50%;transform:translateX(-50%);
  bottom:5%;
  display:flex;gap:1rem;
  z-index:3;
}
.hero-buttons-bottom button{
  padding:1rem 2rem;
  background:var(--blue);
  color:#fff;
  border:none;
  border-radius:12px;
  font-weight:800;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:0 16px 40px rgba(0,0,0,0.24);
}
.hero-buttons-bottom button:hover{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 20px 55px rgba(0,0,0,0.30);
}

/* =========================
   REVEAL ANIMATIONS
========================= */
.reveal{opacity:1;transform:none;filter:none;}
.split-line{opacity:1;transform:none;}

html.js .reveal{
  opacity:0;
  transform:translateY(18px) scale(0.975);
  filter:blur(10px);
  transition:opacity .9s cubic-bezier(.2,.8,.2,1),
             transform .9s cubic-bezier(.2,.8,.2,1),
             filter .9s cubic-bezier(.2,.8,.2,1);
}
html.js .reveal.in-view{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}

html.js .split-line{
  display:inline-block;
  transform:translateY(16px);
  opacity:0;
  transition:transform .9s cubic-bezier(.2,.8,.2,1), opacity .9s cubic-bezier(.2,.8,.2,1);
}
html.js .reveal.in-view .split-line{transform:translateY(0);opacity:1;}

/* ✅ Fail-safe: never hide the Services section if reveal animation fails */
#services .reveal,
#services .split-line{
  opacity:1 !important;
  transform:none !important;
  filter:none !important;
}

/* =========================
   SERVICES (BIGGER + NO INNER SCROLL)
========================= */
.services-premium{
  /* ✅ MAKE THE PAGE LONGER HERE */
  padding:9.5rem 0 16rem;   /* was 12rem bottom — now longer */
  background:var(--greySolid);
  position:relative;
  overflow:hidden;          /* decorative gradients stay contained */
}

/* ✅ IMPORTANT: prevent any inner scrolling even if something else tries to add it */
.services-premium,
.services-premium .container,
.services-grid{
  height:auto;
  max-height:none;
  overflow:visible;
}

.services-premium::before{
  content:"";
  position:absolute;
  inset:-200px;
  background:
    radial-gradient(520px 260px at 18% 18%, rgba(30,136,229,0.10), transparent 65%),
    radial-gradient(520px 260px at 88% 28%, rgba(99,164,255,0.08), transparent 70%);
  pointer-events:none;
}
.services-premium::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:28px;
  background:linear-gradient(to bottom, rgba(230,231,234,0), rgba(255,255,255,0.9));
  pointer-events:none;
}

.services-title{font-size:2.9rem;line-height:1.08;letter-spacing:-0.03em;}
.services-divider{
  height:1px;
  margin-top:1.7rem;
  background:linear-gradient(to right, rgba(0,0,0,0.12), rgba(0,0,0,0.02));
  border-radius:999px;
}

.services-grid{
  position:relative;
  margin-top:3.2rem;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1.3rem;
  padding-bottom:6rem; /* ✅ extra room under the last pill */
}

.service-pill{
  border-radius:18px;
  padding:1.25rem 1.15rem;
  background:rgba(255,255,255,0.82);
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:var(--shadow2);
  backdrop-filter:blur(10px);
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  transition:transform .25s ease, box-shadow .25s ease;
}
.service-pill:hover{transform:translateY(-4px);box-shadow:0 22px 60px rgba(0,0,0,0.12);}
.service-pill.wide{grid-column:1 / -1;}

/* =========================
   GALLERY
========================= */
.gallery{padding:6.5rem 0;background:#fff;}
.gallery-head h2{font-size:2.6rem;letter-spacing:-0.02em;}
.gallery-grid{margin-top:2rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;}
.gallery-photo{
  display:block;height:220px;border-radius:18px;overflow:hidden;background:#f0f3f8;
  border:1px solid rgba(0,0,0,0.06);
  box-shadow:var(--shadow2);
  transition:transform .25s ease, box-shadow .25s ease;
}
.gallery-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.gallery-photo:hover{transform:translateY(-4px);box-shadow:0 22px 55px rgba(0,0,0,0.16);}
.gallery-photo:hover img{transform:scale(1.08);}

/* =========================
   ABOUT PAGE
========================= */
.about-page{
  padding:160px 0 6rem;
  background:
    radial-gradient(900px 380px at 18% 10%, rgba(30,136,229,0.10), transparent 60%),
    radial-gradient(900px 380px at 92% 20%, rgba(99,164,255,0.08), transparent 62%),
    linear-gradient(135deg, #f7f8fb, #eef2f7);
}
.about-hero h1{font-size:3rem;line-height:1.06;letter-spacing:-0.03em;}
.about-metric-grid{margin-top:1.8rem;display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:1rem;}
.about-metric{border-radius:18px;background:rgba(255,255,255,0.78);border:1px solid rgba(0,0,0,0.08);box-shadow:var(--shadow2);padding:1.2rem;backdrop-filter:blur(10px);}
.about-metric h3{letter-spacing:-0.02em;margin-bottom:.2rem;}
.about-metric p{color:var(--muted);}
.about-section{margin-top:1.6rem;border-radius:18px;background:rgba(255,255,255,0.78);border:1px solid rgba(0,0,0,0.08);box-shadow:var(--shadow2);padding:1.6rem;backdrop-filter:blur(10px);}
.about-section h2{letter-spacing:-0.02em;margin-bottom:.4rem;}
.about-bullets{list-style:none;margin-top:.8rem;display:grid;gap:.6rem;padding-left:0;}
.about-bullets li{position:relative;padding-left:1.1rem;color:var(--muted);}
.about-bullets li::before{content:"•";position:absolute;left:0;top:0;color:var(--blue);font-weight:900;}
.about-split{margin-top:1.2rem;display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:1rem;}
.about-card{border-radius:18px;background:rgba(255,255,255,0.78);border:1px solid rgba(0,0,0,0.08);box-shadow:var(--shadow2);padding:1.5rem;backdrop-filter:blur(10px);}
.about-card h2{letter-spacing:-0.02em;margin-bottom:.35rem;}
.about-steps{margin-top:.75rem;display:grid;gap:.9rem;}
.step{display:grid;grid-template-columns:44px 1fr;gap:.9rem;align-items:start;border-radius:18px;background:rgba(255,255,255,0.86);border:1px solid rgba(0,0,0,0.08);box-shadow:var(--shadow2);padding:1.1rem;}
.step-num{width:44px;height:44px;border-radius:14px;background:rgba(30,136,229,0.12);display:grid;place-items:center;font-weight:900;color:var(--blue);}
.step-body h4{margin-bottom:.15rem;letter-spacing:-0.01em;}
.step-body p{color:var(--muted);}
.about-cta{margin-top:1.8rem;border-radius:18px;background:rgba(255,255,255,0.78);border:1px solid rgba(0,0,0,0.08);box-shadow:0 18px 45px rgba(0,0,0,0.10);padding:1.6rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;backdrop-filter:blur(10px);}
.cta-actions{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;}
.cta-btn{display:inline-block;padding:.9rem 1.05rem;border-radius:12px;background:var(--blue);color:#fff;text-decoration:none;font-weight:900;box-shadow:0 14px 35px rgba(30,136,229,0.26);transition:transform .25s ease, box-shadow .25s ease, background .25s ease;}
.cta-btn:hover{transform:translateY(-1px);box-shadow:0 18px 45px rgba(30,136,229,0.32);}
.cta-btn.ghost{background:rgba(18,18,18,0.06);color:rgba(18,18,18,0.88);box-shadow:none;}
.cta-back{color:rgba(18,18,18,0.62);text-decoration:none;font-weight:800;}
.cta-back:hover{color:rgba(18,18,18,0.85);}

/* =========================
   FOOTER + MODAL
========================= */
footer{margin-top:auto;background:#121212;color:rgba(255,255,255,0.70);padding:2.2rem 0;text-align:center;font-size:.98rem;}
footer a{color:var(--blue2);text-decoration:none;}
footer a:hover{color:#9bc6ff;}

.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,0.0);z-index:2000;padding:1.2rem;transition:background .28s ease;}
.modal.show{display:flex;}
.modal.is-visible{background:rgba(0,0,0,0.62);}
.modal-content{width:100%;max-width:560px;background:#fff;border-radius:18px;border:1px solid rgba(0,0,0,0.06);box-shadow:0 22px 70px rgba(0,0,0,0.30);padding:2.5rem;max-height:86vh;overflow:auto;position:relative;transform:translateY(18px) scale(0.96);opacity:0;transition:transform .35s cubic-bezier(.2,.8,.2,1), opacity .35s ease;}
.modal.is-visible .modal-content{transform:translateY(0) scale(1);opacity:1;}
.modal.closing .modal-content{transform:translateY(12px) scale(0.98);opacity:0;}
.modal-content h2{margin-bottom:1.25rem;text-align:center;letter-spacing:-0.02em;}
.modal-content input,.modal-content select,.modal-content textarea{width:100%;padding:.9rem;margin:.55rem 0;border:1px solid rgba(0,0,0,0.14);border-radius:12px;font-size:1rem;outline:none;}
.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus{border-color:rgba(30,136,229,0.55);box-shadow:0 0 0 4px rgba(30,136,229,0.14);}
.modal-content textarea{resize:vertical;min-height:110px;}
.modal-content button[type="submit"]{width:100%;padding:1rem;margin-top:.6rem;background:var(--blue);color:#fff;border:none;border-radius:12px;font-weight:900;cursor:pointer;transition:transform .25s ease, box-shadow .25s ease, background .25s ease;box-shadow:0 14px 35px rgba(30,136,229,0.26);}
.modal-content button[type="submit"]:hover{transform:translateY(-1px);background:#197fd6;}
.modal-content button[type="submit"]:disabled{opacity:.7;cursor:not-allowed;}
.form-footnote{margin-top:.85rem;font-size:.92rem;color:rgba(18,18,18,0.55);text-align:center;}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;}
.close{position:absolute;top:14px;right:16px;font-size:1.7rem;font-weight:900;cursor:pointer;color:var(--blue);background:transparent;border:none;transition:transform .2s ease;}
.close:hover{transform:scale(1.12);}
.form-error{margin-top:.75rem;font-size:.95rem;color:#b00020;text-align:center;display:none;}

.success-overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:rgba(255,255,255,0.86);backdrop-filter:blur(10px);border-radius:18px;opacity:0;transition:opacity .6s ease;}
.success-overlay.show{display:flex;opacity:1;}
.success-overlay.fadeout{opacity:0;}
.success-card{width:100%;max-width:360px;padding:1.7rem 1.2rem;border-radius:20px;background:#fff;border:1px solid rgba(0,0,0,0.06);box-shadow:0 22px 70px rgba(0,0,0,0.20);text-align:center;}
.success-spinner{width:56px;height:56px;border-radius:50%;border:5px solid rgba(30,136,229,0.18);border-top-color:var(--blue);margin:0 auto;animation:spin .9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.success-check{width:64px;height:64px;margin:0 auto;display:none;}
.success-check-path{fill:none;stroke:var(--blue);stroke-width:6;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:60;stroke-dashoffset:60;}
.success-check.show{display:block;}
.success-check.show .success-check-path{animation:draw .45s ease forwards;}
@keyframes draw{to{stroke-dashoffset:0;}}
.success-text{margin-top:.95rem;font-weight:900;opacity:0;transform:translateY(6px);transition:opacity .35s ease, transform .35s ease;}
.success-text.show{opacity:1;transform:translateY(0);}

/* =========================
   MOBILE
========================= */
@media (max-width:768px){
  header{
    top:0;left:0;transform:none;width:100%;max-width:none;border-radius:0;
    padding:12px 12px;
    padding-top:calc(12px + env(safe-area-inset-top));
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    gap:.6rem;
  }
  .header-right{display:contents;}
  .nav{display:none;}
  .hamburger{display:block;justify-self:end;}
  .logo{font-size:0.98rem;max-width:none;overflow:visible;text-overflow:clip;white-space:normal;line-height:1.05;justify-self:start;}
  .quote-btn{justify-self:center;padding:.6rem .85rem;font-size:.95rem;}
  #services,#gallery,#contact,#quote{scroll-margin-top:96px;}

  .hero{
    position:relative;
    height:clamp(320px, 56.25vw, 520px);
    min-height:clamp(320px, 56.25vw, 520px);
    width:100%;
    background:#000;
    overflow:hidden;
  }
  .hero-media{
    position:absolute;
    top:var(--mobileHeaderH);
    left:0; right:0; bottom:0;
    overflow:hidden;
    z-index:1;
  }
  .hero video{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 12%;
    filter:none;
  }
  .hero-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.18);
    z-index:2;
    pointer-events:none;
  }

  .hero-buttons-bottom{
    position:absolute;
    left:0; right:0; bottom:0;
    z-index:3;
    padding:8px 10px calc(10px + env(safe-area-inset-bottom));
    display:flex;
    gap:8px;
    justify-content:center;
    background:linear-gradient(to top, rgba(0,0,0,0.62), rgba(0,0,0,0));
  }
  .hero-buttons-bottom button{
    width:46%;
    max-width:155px;
    padding:.52rem .6rem;
    font-size:.76rem;
    border-radius:10px;
  }

  .nav-overlay{
    display:block;position:fixed;inset:0;background:rgba(0,0,0,0.55);
    opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:1500;
  }
  .nav-overlay.active{opacity:1;pointer-events:auto;}

  .mobile-nav{
    display:block;
    position:fixed;top:0;right:0;height:100vh;width:min(360px, 84vw);
    background:rgba(18,18,18,0.92);backdrop-filter:blur(14px);
    border-left:1px solid rgba(255,255,255,0.10);
    transform:translateX(105%);
    transition:transform .35s cubic-bezier(.2,.8,.2,1);
    z-index:1600;
    padding:calc(18px + env(safe-area-inset-top)) 18px 24px;
    box-shadow:-20px 0 60px rgba(0,0,0,0.35);
    overflow:auto;
    pointer-events:none;
  }
  .mobile-nav.active{transform:translateX(0);pointer-events:auto;}
  .mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-top:72px;}
  .mobile-nav a{
    color:#fff;text-decoration:none;font-weight:800;display:block;
    padding:.85rem .95rem;border-radius:14px;
    background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.10);
    transition:transform .2s ease, background .2s ease, color .2s ease;
  }
  .mobile-nav a:hover{background:rgba(255,255,255,0.10);transform:translateX(-2px);color:var(--blue2);}
  .mobile-nav a.active{color:var(--blue2);}

  /* ✅ longer services section on mobile too */
  .services-premium{padding:7.8rem 0 15rem;}
  .services-grid{grid-template-columns:1fr; padding-bottom:7rem;}
  .service-pill.wide{grid-column:auto;}

  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr));}

  .about-metric-grid{grid-template-columns:1fr;}
  .about-split{grid-template-columns:1fr;}
}
