*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --navy:#0f2240; --navy2:#1a3460;
  --gold:#c9912f; --gold2:#e6b04a;
  --cream:#faf8f4; --sand:#f2ede3;
  --white:#fff; --text:#1a1a2e;
  --muted:#6b7280; --border:#e5ddd0;
  --radius:14px; --safe-bottom:env(safe-area-inset-bottom,0px);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Outfit',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{-webkit-tap-highlight-color:transparent}

/* ═══ NAV ═══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:60px;padding:0 4%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(15,34,64,0.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,145,47,0.2);
}
.n-logo{display:flex;align-items:center;text-decoration:none}
.n-logo-img{height:48px;width:auto;object-fit:contain;display:block}
.nav-right{display:flex;align-items:center;gap:10px}
.n-links{display:none}/* hidden mobile */
.n-call{
  display:flex;align-items:center;gap:6px;
  background:var(--gold);color:#fff;
  padding:8px 14px;border-radius:8px;
  font-size:0.8rem;font-weight:700;text-decoration:none;
  transition:background 0.2s;white-space:nowrap;
}
.n-call svg{width:14px;height:14px;stroke:#fff;flex-shrink:0}
.n-call:active{background:var(--gold2)}
/* hamburger */
.n-ham{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;padding:4px;cursor:pointer;
  background:rgba(255,255,255,0.07);border-radius:8px;border:none;
}
.n-ham span{display:block;height:2px;background:#fff;border-radius:2px;transition:all 0.3s}
/* mobile menu drawer */
.mob-menu{
  position:fixed;top:60px;left:0;right:0;z-index:299;
  background:rgba(15,34,64,0.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:none;flex-direction:column;padding:8px 0 20px;
  border-bottom:1px solid rgba(201,145,47,0.2);
}
.mob-menu.open{display:flex}
.mob-menu a{
  padding:14px 5%;font-size:1rem;font-weight:500;
  color:rgba(255,255,255,0.85);text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:space-between;
  transition:color 0.2s;
}
.mob-menu a:active{color:var(--gold2);background:rgba(255,255,255,0.04)}
.mob-menu a::after{content:'›';font-size:1.2rem;color:var(--gold)}

/* ═══ FLOATING CALL BAR (mobile) ═══ */
.float-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:290;
  display:grid;grid-template-columns:1fr 1fr;
  padding:10px 4% calc(10px + var(--safe-bottom));
  background:var(--navy);
  border-top:1px solid rgba(201,145,47,0.3);
  gap:10px;
}
.fb-call,.fb-quote{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px;border-radius:10px;
  font-size:0.9rem;font-weight:700;text-decoration:none;
  border:none;cursor:pointer;transition:all 0.15s;
  font-family:'Outfit',sans-serif;
}
.fb-call{background:var(--gold);color:#fff}
.fb-call:active{background:var(--gold2);transform:scale(0.98)}
.fb-quote{background:rgba(255,255,255,0.1);color:#fff;border:1.5px solid rgba(255,255,255,0.2)}
.fb-quote:active{background:rgba(255,255,255,0.18)}
.fb-call svg,.fb-quote svg{width:16px;height:16px;stroke:currentColor;flex-shrink:0}

/* ═══ HERO ═══ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:80px 5% 120px;/* bottom pad for float bar */
  background:var(--navy);overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('../images/hero-construction.jpg') center/cover no-repeat;
  opacity:0.2;
}
.hero-ov{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,34,64,0.6) 0%,rgba(15,34,64,0.97) 70%);
}
.hero-content{position:relative;z-index:2}
.hero-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(230,176,74,0.15);border:1px solid rgba(230,176,74,0.35);
  color:var(--gold2);padding:5px 12px;border-radius:100px;
  font-size:0.7rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:18px;animation:up 0.6s ease both;
}
.hero-pill::before{content:'';width:6px;height:6px;background:var(--gold2);border-radius:50%}
.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,10vw,5rem);
  font-weight:700;color:#fff;line-height:1.08;
  animation:up 0.6s 0.1s ease both;
}
.hero h1 em{color:var(--gold2);font-style:italic}
.hero-sub{
  margin-top:14px;font-size:0.95rem;color:rgba(255,255,255,0.6);
  font-weight:300;line-height:1.75;
  animation:up 0.6s 0.2s ease both;
}
.hero-btn{
  display:flex;flex-direction:column;gap:10px;margin-top:30px;
  animation:up 0.6s 0.3s ease both;
}
.hero-btn a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:15px;border-radius:10px;font-size:0.95rem;font-weight:700;
  text-decoration:none;transition:all 0.2s;
}
.hb-primary{background:var(--gold);color:#fff;box-shadow:0 4px 20px rgba(201,145,47,0.35)}
.hb-primary:active{background:var(--gold2)}
.hb-secondary{background:rgba(255,255,255,0.08);color:#fff;border:1.5px solid rgba(255,255,255,0.2)}
.hb-secondary:active{background:rgba(255,255,255,0.15)}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:32px;border-radius:12px;overflow:hidden;
  border:1px solid rgba(255,255,255,0.1);
  animation:up 0.6s 0.4s ease both;
}
.stat{
  padding:14px 8px;text-align:center;
  border-right:1px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.04);
}
.stat:last-child{border-right:none}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:700;color:var(--gold2);line-height:1}
.stat-l{font-size:0.58rem;color:rgba(255,255,255,0.4);margin-top:4px;text-transform:uppercase;letter-spacing:0.06em}

/* ═══ TRUST BAR ═══ */
.trust-bar{
  background:var(--white);padding:14px 5%;
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.trust-inner{
  display:flex;align-items:center;gap:10px;
  animation:scroll 18s linear infinite;
  width:max-content;
}
.trust-inner:hover{animation-play-state:paused}
.t-lbl{font-size:0.65rem;font-weight:700;color:var(--muted);letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap;margin-right:4px}
.t-chip{
  font-size:0.75rem;font-weight:600;color:var(--navy);opacity:0.6;
  padding:5px 12px;border:1px solid var(--border);border-radius:6px;white-space:nowrap;
}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ SECTION BASE ═══ */
section{padding:64px 5%}
.s-tag{
  font-size:0.68rem;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gold);margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.s-tag::before{content:'';width:20px;height:2px;background:var(--gold);flex-shrink:0}
.s-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.75rem,6vw,2.6rem);font-weight:700;
  color:var(--navy);line-height:1.15;
}
.s-title span{color:var(--gold)}
.s-desc{margin-top:12px;color:var(--muted);font-size:0.93rem;line-height:1.75}

/* ═══ ABOUT ═══ */
#about{background:var(--white)}
.about-img{
  width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);
  background:url('../images/logo-zumra-infra.jpg') center/cover;
  margin-bottom:28px;
  box-shadow:0 12px 40px rgba(15,34,64,0.12);
}
.about-glance{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:24px}
.gp{padding:14px;background:var(--sand);border-radius:10px;border:1px solid var(--border)}
.gp-k{font-size:0.65rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.08em}
.gp-v{font-size:0.88rem;font-weight:600;color:var(--navy);margin-top:3px}

/* ═══ SERVICES ═══ */
#services{background:var(--cream)}
.svc-grid{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.svc-card{
  background:var(--white);border-radius:var(--radius);padding:22px 20px;
  border:1px solid var(--border);display:flex;gap:16px;align-items:flex-start;
  transition:border-color 0.2s;
}
.svc-card:active{border-color:var(--gold)}
.svc-ico{
  width:44px;height:44px;background:var(--sand);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.svc-ico svg{width:22px;height:22px;stroke:var(--navy);stroke-width:1.8}
.svc-n{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:5px}
.svc-t{font-size:0.82rem;color:var(--muted);line-height:1.6}

/* ═══ PROJECTS ═══ */
#projects{background:var(--navy);padding:64px 5%}
#projects .s-title{color:#fff}
#projects .s-desc{color:rgba(255,255,255,0.55)}
.proj-scroll{
  display:flex;gap:14px;overflow-x:auto;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  padding-bottom:8px;margin:28px -5% 0;padding-left:5%;padding-right:5%;
  scrollbar-width:none;
}
.proj-scroll::-webkit-scrollbar{display:none}
.proj-card{
  flex:0 0 78vw;max-width:300px;
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/3;position:relative;
  scroll-snap-align:start;background:rgba(255,255,255,0.05);
}
.proj-card img{width:100%;height:100%;object-fit:cover;display:block}
.proj-grad{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(10,20,40,0.92) 100%);
  padding:16px;display:flex;flex-direction:column;justify-content:flex-end;
}
.proj-chip{
  font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--gold2);margin-bottom:4px;
}
.proj-nm{font-size:0.88rem;font-weight:700;color:#fff;margin-bottom:2px}
.proj-lc{font-size:0.75rem;color:rgba(255,255,255,0.6);display:flex;align-items:center;gap:4px}
.proj-dots{
  display:flex;justify-content:center;gap:6px;margin-top:16px;
}
.proj-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.2);transition:background 0.2s;cursor:pointer}
.proj-dot.active{background:var(--gold2)}
/* project table */
.pt{margin-top:36px}
.pt-hd{
  display:grid;grid-template-columns:36px 1fr 1fr;gap:10px;
  padding:10px 12px;
  font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--gold);border-bottom:1px solid rgba(255,255,255,0.1);
}
.pt-row{
  display:grid;grid-template-columns:36px 1fr 1fr;gap:10px;
  padding:14px 12px;border-bottom:1px solid rgba(255,255,255,0.06);
  align-items:center;border-radius:8px;transition:background 0.15s;
}
.pt-row:active{background:rgba(255,255,255,0.04)}
.pt-n{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--gold);opacity:0.5;font-weight:700}
.pt-p{font-size:0.82rem;font-weight:600;color:#fff}
.pt-c{font-size:0.75rem;color:rgba(255,255,255,0.5)}

/* ═══ WHY ═══ */
#why{background:var(--sand)}
.why-grid{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.why-card{
  background:var(--white);border-radius:var(--radius);padding:20px;
  display:flex;gap:14px;align-items:flex-start;
  border:1px solid var(--border);transition:border-color 0.2s;
}
.why-card:active{border-color:var(--gold)}
.why-ico{
  width:42px;height:42px;background:var(--navy);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.why-ico svg{width:18px;height:18px;stroke:var(--gold2);stroke-width:1.8}
.why-t{font-size:0.92rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.why-d{font-size:0.8rem;color:var(--muted);line-height:1.6}

/* ═══ CONTACT ═══ */
#contact{background:var(--white)}
.c-items{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.c-item{
  display:flex;gap:14px;align-items:center;
  padding:16px;background:var(--sand);border-radius:12px;
  border:1px solid var(--border);text-decoration:none;transition:border-color 0.2s;
}
.c-item:active{border-color:var(--gold)}
.c-ico{
  width:42px;height:42px;background:var(--navy);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.c-ico svg{width:18px;height:18px;stroke:var(--gold2);stroke-width:1.8}
.c-lbl{font-size:0.65rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.08em}
.c-val{font-size:0.9rem;font-weight:600;color:var(--navy);margin-top:2px}
.c-presence{
  margin-top:20px;background:var(--navy);border-radius:var(--radius);padding:24px;
}
.c-presence h4{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:14px;
}
.branches{list-style:none}
.branches li{
  display:flex;align-items:center;gap:9px;
  font-size:0.85rem;color:rgba(255,255,255,0.75);
  padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.07);
}
.branches li:last-child{border:none}
.bdot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex-shrink:0}

/* ═══ FOOTER ═══ */
footer{
  background:#08111f;padding:28px 5% calc(28px + var(--safe-bottom));
  text-align:center;
}
.f-logo{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:700;color:#fff}
.f-logo em{color:var(--gold);font-style:normal}
.f-copy{font-size:0.75rem;color:rgba(255,255,255,0.3);margin-top:6px}
/* extra bottom space for float bar */
.pb-float{height:80px}

/* ═══ MODAL ═══ */
#quoteModal{
  display:none;position:fixed;inset:0;z-index:400;
  align-items:flex-end;justify-content:center;
  background:rgba(8,17,31,0.8);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:0;
}
.modal-sheet{
  background:var(--white);width:100%;max-height:92svh;
  border-radius:20px 20px 0 0;overflow-y:auto;
  padding:20px 5% calc(20px + var(--safe-bottom));
  animation:sheetUp 0.3s cubic-bezier(0.32,0.72,0,1);
}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-handle{
  width:40px;height:4px;background:var(--border);border-radius:2px;
  margin:0 auto 20px;
}
.modal-close{
  position:absolute;top:12px;right:16px;
  background:var(--sand);border:none;cursor:pointer;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:var(--muted);
}
.modal-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:700;color:var(--navy);margin-bottom:4px;
}
.modal-sub{font-size:0.85rem;color:var(--muted);margin-bottom:22px;line-height:1.5}
.m-field{margin-bottom:14px}
.m-field label{display:block;font-size:0.7rem;font-weight:700;color:var(--navy);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:6px}
.m-field input,.m-field select,.m-field textarea{
  width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:10px;
  font-family:'Outfit',sans-serif;font-size:1rem;color:var(--text);
  background:var(--cream);outline:none;transition:border-color 0.2s;
  -webkit-appearance:none;appearance:none;
}
.m-field input:focus,.m-field select:focus,.m-field textarea:focus{border-color:var(--gold);background:#fff}
.m-field textarea{resize:none;height:80px}
.modal-send{
  width:100%;padding:15px;background:var(--navy);color:#fff;
  border:none;border-radius:10px;font-family:'Outfit',sans-serif;
  font-size:1rem;font-weight:700;cursor:pointer;
  transition:all 0.2s;margin-top:4px;letter-spacing:0.02em;
}
.modal-send:active{background:var(--gold)}
.modal-success{display:none;text-align:center;padding:32px 0}
.tick{width:64px;height:64px;background:rgba(34,197,94,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.tick svg{width:28px;height:28px;stroke:#16a34a;stroke-width:2.5}
.modal-success h4{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.modal-success p{font-size:0.88rem;color:var(--muted);line-height:1.6}

/* ═══ REVEAL ═══ */
.rv{opacity:0;transform:translateY(22px);transition:opacity 0.55s ease,transform 0.55s ease}
.rv.in{opacity:1;transform:none}

/* ═══ ANIMATIONS ═══ */
@keyframes up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ═══ DESKTOP UPGRADES (768px+) ═══ */
@media(min-width:768px){
  nav{height:68px;padding:0 6%}
  .n-links{
    display:flex;gap:24px;list-style:none;
  }
  .n-links a{
    font-size:0.78rem;font-weight:500;color:rgba(255,255,255,0.7);
    text-decoration:none;letter-spacing:0.08em;text-transform:uppercase;
    transition:color 0.2s;
  }
  .n-links a:hover{color:var(--gold2)}
  .n-ham{display:none}
  .mob-menu{display:none!important}
  .float-bar{display:none}
  .pb-float{display:none}
  .hero{padding:120px 6% 80px;justify-content:center}
  .hero-btn{flex-direction:row}
  .hero-btn a{padding:15px 32px}
  section{padding:88px 6%}
  .about-img{aspect-ratio:16/8}
  .svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .proj-scroll{margin:28px 0 0;padding:0 0 8px;overflow-x:auto}
  .proj-card{flex:0 0 280px}
  .why-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .c-presence{margin-top:0}
  #quoteModal{align-items:center;padding:20px}
  .modal-sheet{border-radius:18px;max-width:520px;padding:40px 36px}
  .sheet-handle{display:none}
}
@media(min-width:1024px){
  .about-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:48px}
  .about-img{margin-bottom:0;aspect-ratio:unset;height:380px}
  .contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:40px;align-items:start}
  .c-items{margin-top:0}
  .c-presence{margin-top:0}
}
