/* ======================================================
   ALLGOOD DEPOT — Complete Stylesheet v5 (Final)
   Fonts : Montserrat (headings) | Poppins (body)
   Colors: Navy #1B2A5C  |  Orange #E8541A
   ====================================================== */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Poppins:wght@300;400;500;600&display=swap');

:root {
  --navy:    #1B2A5C;
  --navy-dk: #111d3e;
  --navy-md: #243270;
  --orange:  #E8541A;
  --orange-l:#f06b32;
  --white:   #ffffff;
  --off:     #f5f7fb;
  --gray-lt: #e6e9f4;
  --gray:    #9aa0b5;
  --gray-dk: #4a5068;
  --text:    #1a1f36;
  --fh: 'Montserrat', sans-serif;
  --fb: 'Poppins', sans-serif;
  --r:  8px;
  --r2: 16px;
  --sh:  0 2px 20px rgba(27,42,92,.09);
  --sh2: 0 12px 48px rgba(27,42,92,.15);
  --tr: .28s cubic-bezier(.4,0,.2,1);
}

/* ── reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--text);background:var(--white);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,textarea,select{font-family:var(--fb);font-size:1rem;border:none;outline:none;background:none}
p{font-size:.95rem;line-height:1.82;color:var(--gray-dk)}
h1,h2,h3,h4,h5{font-family:var(--fh);line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(2.3rem,5vw,4.2rem);font-weight:900}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:800}
h3{font-size:1.12rem;font-weight:700}
h4{font-size:1rem;font-weight:700}

/* ── layout ── */
.container{width:100%;max-width:1220px;margin:0 auto;padding:0 2rem}
.section{padding:5.5rem 0}
.section-sm{padding:3rem 0}

/* ── pill badge ── */
.pill{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(232,84,26,.09);color:var(--orange);
  font-family:var(--fh);font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.3rem .9rem;border-radius:100px;
  border:1px solid rgba(232,84,26,.22);margin-bottom:.9rem;
}

/* ── accent bar ── */
.accent-bar{width:44px;height:3px;background:linear-gradient(90deg,var(--orange),#f8a27a);border-radius:2px;margin:.5rem 0 1.6rem}
.accent-bar.c{margin-left:auto;margin-right:auto}

/* ── section head ── */
.section-head{margin-bottom:3rem}
.section-head h2{color:var(--navy);margin:.4rem 0 .6rem}
.section-head p{max-width:520px;margin:.5rem 0 0}
.section-head.center{text-align:center}
.section-head.center p{max-width:560px;margin:.5rem auto 0}

/* ── buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--fh);font-size:.82rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  padding:.82rem 1.9rem;border-radius:100px;cursor:pointer;
  transition:var(--tr);white-space:nowrap;border:2px solid transparent;
}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-primary{background:var(--orange);color:var(--white);border-color:var(--orange);box-shadow:0 4px 18px rgba(232,84,26,.28)}
.btn-primary:hover{background:var(--orange-l);border-color:var(--orange-l);transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,84,26,.38)}
.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-md);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.6);color:var(--white)}
.btn-ghost:hover{background:var(--white);border-color:var(--white);color:var(--navy)}
.btn-outline-navy{border-color:var(--navy);color:var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:var(--white)}
.btn-sm{padding:.55rem 1.3rem;font-size:.75rem}

/* ======================================================
   TOP BAR
   ====================================================== */
.top-bar{
  background:var(--navy-dk);color:rgba(255,255,255,.72);
  font-family:var(--fh);font-size:.72rem;font-weight:500;
  letter-spacing:.04em;padding:.48rem 0;
  border-bottom:2px solid var(--orange);
  position:relative;z-index:1001;
}
.top-bar .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}
.top-bar a{color:inherit;transition:color var(--tr)}
.top-bar a:hover{color:var(--orange)}
.top-left,.top-right{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:.38rem}
.ti svg{width:12px;height:12px;color:var(--orange);flex-shrink:0}

/* ======================================================
   HEADER — sticky, transparent over hero, white on scroll
   ====================================================== */
#site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--white);
  border-bottom:1px solid var(--gray-lt);
  box-shadow:var(--sh);
  transition:background var(--tr),box-shadow var(--tr);
}
.nav-inner{
  display:flex;align-items:center;
  justify-content:space-between;
  height:72px;gap:1rem;
}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:54px;width:auto;object-fit:contain}

/* nav links */
.nav-menu{display:flex;align-items:center;gap:.05rem}
.nav-item{position:relative}
.nav-link{
  display:block;font-family:var(--fh);font-size:.8rem;font-weight:600;
  letter-spacing:.02em;color:var(--navy);
  padding:.52rem .88rem;border-radius:100px;
  transition:background var(--tr),color var(--tr);white-space:nowrap;
}
.nav-link:hover,.nav-item.active>.nav-link{color:var(--orange);background:rgba(232,84,26,.07)}
.chev{display:inline-block;margin-left:.18rem;font-size:.6rem;transition:transform var(--tr)}
.nav-item:hover>.nav-link .chev{transform:rotate(180deg)}

/* dropdown */
.dropdown{
  display:none;position:absolute;
  top:100%;left:50%;transform:translateX(-50%);
  min-width:250px;background:var(--white);
  border-radius:var(--r2);box-shadow:var(--sh2);
  border:1px solid var(--gray-lt);border-top:3px solid var(--orange);
  padding:.6rem;padding-top:.8rem;z-index:300;
  /* invisible bridge so mouse can travel from link to dropdown */
  margin-top:0;
}
/* bridge: fills gap between nav-link and dropdown */
.dropdown::before{
  content:'';position:absolute;top:-10px;left:0;right:0;height:10px;
}
.nav-item:hover>.dropdown{display:block}
@keyframes ddIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.dd-link{
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--fh);font-size:.78rem;font-weight:600;
  color:var(--navy);padding:.62rem 1rem;border-radius:var(--r);
  transition:background var(--tr),color var(--tr);
}
.dd-link:hover{background:var(--off);color:var(--orange)}
.dd-link svg{width:15px;height:15px;color:var(--orange);flex-shrink:0}
.dd-sep{height:1px;background:var(--gray-lt);margin:.35rem 0}

.nav-cta{margin-left:.7rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:var(--tr)}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ======================================================
   HERO
   ====================================================== */
.hero{
  position:relative;min-height:94vh;
  display:flex;align-items:center;
  overflow:hidden;background:var(--navy-dk);
}
.hero-bg{
  position:absolute;inset:0;
  background:url('../images/hero-bg.jpg') center/cover no-repeat;
  opacity:.2;transform:scale(1.06);
  animation:hZoom 22s ease-in-out infinite alternate;
}
@keyframes hZoom{from{transform:scale(1.06)}to{transform:scale(1.13)}}
.hero-ov{
  position:absolute;inset:0;
  background:linear-gradient(130deg,rgba(17,29,62,.96) 42%,rgba(232,84,26,.13) 100%);
}
.blob{position:absolute;border-radius:50%;pointer-events:none}
.blob-1{width:600px;height:600px;background:var(--orange);top:-200px;right:-100px;opacity:.06;animation:bFloat 9s ease-in-out infinite}
.blob-2{width:320px;height:320px;background:var(--white);bottom:-100px;left:-80px;opacity:.05;animation:bFloat 13s ease-in-out infinite reverse}
@keyframes bFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-26px) scale(1.03)}}

.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;
  padding:5rem 0 4rem;width:100%;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(232,84,26,.18);border:1px solid rgba(232,84,26,.4);
  color:var(--orange);font-family:var(--fh);
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.35rem .9rem;border-radius:100px;margin-bottom:1.4rem;
}
.dot{width:6px;height:6px;background:var(--orange);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.hero h1{color:var(--white);margin-bottom:1.4rem;line-height:1.05}
.hero h1 .hl{color:var(--orange);display:block}
.hero h1 .soft{font-weight:400;opacity:.78}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.68);margin-bottom:2.4rem;max-width:480px;line-height:1.82}
.hero-btns{display:flex;flex-wrap:wrap;gap:.9rem}
.hero-trust{
  display:flex;align-items:center;gap:1.2rem;
  margin-top:2.8rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.avatars{display:flex}
.avatars span{
  width:34px;height:34px;border-radius:50%;
  background:var(--orange);border:2px solid var(--navy-dk);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:.6rem;font-weight:800;color:var(--white);
  margin-left:-8px;
}
.avatars span:first-child{margin-left:0}
.trust-txt strong{display:block;color:var(--white);font-family:var(--fh);font-size:.82rem;font-weight:700}
.trust-txt small{color:rgba(255,255,255,.42);font-size:.67rem}
.stars-sm{color:var(--orange);font-size:.82rem;letter-spacing:.06em;margin-bottom:.15rem}
.hero-visual{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.hv-main{grid-column:1/-1;border-radius:var(--r2);overflow:hidden;aspect-ratio:16/8.5;position:relative}
.hv-main img{width:100%;height:100%;object-fit:cover}
.hv-tag{position:absolute;bottom:.9rem;left:.9rem;background:rgba(17,29,62,.82);backdrop-filter:blur(6px);color:var(--white);font-family:var(--fh);font-size:.68rem;font-weight:700;padding:.35rem .75rem;border-radius:100px;border:1px solid rgba(255,255,255,.12)}
.hv-img{border-radius:var(--r2);overflow:hidden;aspect-ratio:4/3}
.hv-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.hv-img:hover img{transform:scale(1.06)}
.hv-stat{border-radius:var(--r2);background:linear-gradient(140deg,var(--orange),#f07a45);padding:1.4rem;display:flex;flex-direction:column;justify-content:center}
.hv-stat .n{font-family:var(--fh);font-size:2.4rem;font-weight:900;color:var(--white);line-height:1}
.hv-stat .l{font-family:var(--fh);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:.25rem}
.scroll-hint{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.35rem;color:rgba(255,255,255,.28);font-size:.6rem;font-family:var(--fh);font-weight:600;letter-spacing:.12em;text-transform:uppercase;animation:sHint 2.5s ease-in-out infinite}
.scroll-hint svg{width:20px;height:20px}
@keyframes sHint{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* hero entry anims */
.ha1{animation:aUp .6s .1s both}.ha2{animation:aUp .6s .2s both}.ha3{animation:aUp .6s .35s both}.ha4{animation:aUp .6s .5s both}.ha5{animation:aUp .75s .4s both}
@keyframes aUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* ======================================================
   TRUST BAND
   ====================================================== */
.trust-band{background:var(--off);border-bottom:1px solid var(--gray-lt);padding:1.2rem 0}
.tb-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.9rem 3rem}
.tb-item{display:flex;align-items:center;gap:.55rem;font-family:var(--fh);font-size:.75rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.tb-item svg{width:18px;height:18px;color:var(--orange);flex-shrink:0}

/* ======================================================
   SERVICES GRID
   ====================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{background:var(--white);border:1px solid var(--gray-lt);border-radius:var(--r2);padding:2.2rem 1.8rem;transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr);position:relative;overflow:hidden}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--orange),#f8a27a);transition:width .4s}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--sh2);border-color:rgba(232,84,26,.12)}
.svc-card:hover::after{width:100%}
.svc-icon{width:52px;height:52px;border-radius:var(--r);background:var(--off);display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem;transition:background var(--tr)}
.svc-icon svg{width:24px;height:24px;color:var(--orange);transition:color var(--tr)}
.svc-card:hover .svc-icon{background:var(--orange)}
.svc-card:hover .svc-icon svg{color:var(--white)}
.svc-card h3{font-size:.98rem;color:var(--navy);margin-bottom:.55rem}
.svc-card p{font-size:.86rem;margin:0}
.svc-more{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.06em;color:var(--orange);text-transform:uppercase;margin-top:1.1rem;transition:gap var(--tr)}
.svc-more svg{width:13px;height:13px}
.svc-card:hover .svc-more{gap:.55rem}

/* ======================================================
   ABOUT SECTION
   ====================================================== */
.about-section{background:var(--navy)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-left .pill{background:rgba(232,84,26,.18);border-color:rgba(232,84,26,.35)}
.about-left h2{color:var(--white);margin:.3rem 0 .4rem}
.about-left .accent-bar{background:linear-gradient(90deg,var(--orange),rgba(248,162,122,.5))}
.about-left p{color:rgba(255,255,255,.65);margin-bottom:.9rem}
.about-checks{margin:1.4rem 0 2.2rem}
.about-checks li{display:flex;align-items:flex-start;gap:.65rem;color:rgba(255,255,255,.74);font-size:.9rem;margin-bottom:.8rem}
.about-checks svg{width:16px;height:16px;color:var(--orange);flex-shrink:0;margin-top:3px}
.about-visual{position:relative;height:460px}
.av-img{position:absolute;border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh2)}
.av-img img{width:100%;height:100%;object-fit:cover}
.av-img-1{width:64%;height:62%;top:0;left:0}
.av-img-2{width:56%;height:54%;bottom:0;right:0}
.av-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--orange);color:var(--white);padding:1.1rem 1.4rem;border-radius:var(--r2);text-align:center;box-shadow:var(--sh2);z-index:10}
.av-badge .n{font-family:var(--fh);font-size:2.2rem;font-weight:900;line-height:1}
.av-badge .t{font-family:var(--fh);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.88;margin-top:.2rem}

/* ======================================================
   STATS BAR
   ====================================================== */
.stats-bar{background:var(--orange)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:2.8rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.18)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--fh);font-size:clamp(2.2rem,3.5vw,3rem);font-weight:900;color:var(--white);line-height:1}
.stat-lbl{font-family:var(--fh);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:.4rem}

/* ======================================================
   PROCESS / HOW IT WORKS
   ====================================================== */
.process-section{background:var(--off)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.process-grid::before{content:'';position:absolute;top:27px;left:12%;right:12%;height:2px;background:linear-gradient(90deg,var(--orange),var(--navy));opacity:.12;z-index:0}
.proc-card{background:var(--white);border-radius:var(--r2);padding:2rem 1.5rem;text-align:center;border:1px solid var(--gray-lt);position:relative;z-index:1;transition:transform var(--tr),box-shadow var(--tr)}
.proc-card:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.proc-num{width:54px;height:54px;background:var(--navy);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.2rem;font-weight:900;margin:0 auto 1.2rem;transition:var(--tr)}
.proc-card:hover .proc-num{background:var(--orange);box-shadow:0 0 0 5px rgba(232,84,26,.14)}
.proc-card h4{font-family:var(--fh);color:var(--navy);font-size:.9rem;margin-bottom:.45rem}
.proc-card p{font-size:.82rem}

/* ======================================================
   PORTFOLIO
   ====================================================== */
.pf-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.2rem}
.filter-btn{font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.48rem 1.2rem;border:2px solid var(--gray-lt);border-radius:100px;color:var(--gray-dk);cursor:pointer;background:var(--white);transition:var(--tr)}
.filter-btn.active,.filter-btn:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.pf-item{position:relative;overflow:hidden;border-radius:var(--r2);aspect-ratio:4/3;cursor:pointer;background:var(--off)}
.pf-item[style*="display: none"]{display:none!important}
.pf-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pf-item:hover{box-shadow:var(--sh2)}
.pf-item:hover img{transform:scale(1.07)}
.pf-ov,.pf-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,29,62,.88) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;opacity:0;transition:opacity var(--tr)}
.pf-item:hover .pf-ov,.pf-item:hover .pf-overlay{opacity:1}
.pf-ov .cat,.pf-overlay span{color:var(--orange);font-family:var(--fh);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.pf-ov h4,.pf-overlay h4{color:var(--white);font-family:var(--fh);font-size:.9rem;margin-top:.15rem}
.pf-zoom{position:absolute;top:.9rem;right:.9rem;width:36px;height:36px;background:rgba(255,255,255,.92);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--navy);opacity:0;transform:scale(.8);transition:var(--tr)}
.pf-item:hover .pf-zoom{opacity:1;transform:scale(1)}
.pf-zoom svg{width:15px;height:15px}

/* ======================================================
   TESTIMONIALS
   ====================================================== */
.testi-section{background:var(--navy)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.testi-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r2);padding:2rem;transition:var(--tr)}
.testi-card:hover{background:rgba(255,255,255,.09);border-color:rgba(232,84,26,.38)}
.testi-stars{color:var(--orange);font-size:.95rem;letter-spacing:.06em;margin-bottom:1rem}
.testi-card blockquote{color:rgba(255,255,255,.7);font-size:.88rem;font-style:italic;line-height:1.85;margin-bottom:1.4rem}
.testi-author{display:flex;align-items:center;gap:.85rem}
.t-av{width:40px;height:40px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.9rem;font-weight:800;color:var(--white);flex-shrink:0}
.t-name{font-family:var(--fh);font-weight:700;color:var(--white);font-size:.86rem}
.t-role{color:rgba(255,255,255,.38);font-size:.72rem;margin-top:.1rem}

/* ======================================================
   CTA BAND — ALL TEXT ALWAYS WHITE
   ====================================================== */
.cta-band{background:var(--orange);position:relative;overflow:hidden}
.cta-band::before{content:'AGC';position:absolute;right:-1rem;top:50%;transform:translateY(-50%);font-family:var(--fh);font-size:11rem;font-weight:900;color:rgba(255,255,255,.07);pointer-events:none;line-height:1}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:3.2rem 0;position:relative;z-index:1}
.cta-left h2,.cta-left p,.cta-band h2,.cta-band p{color:var(--white)!important}
.cta-left h2{font-size:clamp(1.5rem,2.8vw,2.1rem);margin-bottom:.4rem}
.cta-left p{font-size:.92rem;opacity:.9}
.cta-right{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.cta-phone-link{display:flex;align-items:center;gap:.6rem;color:var(--white)!important;font-family:var(--fh);font-size:1.4rem;font-weight:800;transition:opacity var(--tr)}
.cta-phone-link:hover{opacity:.82}
.cta-phone-link svg{width:20px;height:20px;flex-shrink:0}

/* ======================================================
   PAGE HERO  (inner pages)
   ====================================================== */
.page-hero{background:var(--navy);padding:4.5rem 0 3.5rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url('../images/hero-bg.jpg') center/cover no-repeat;opacity:.07}
.page-hero .container{position:relative;z-index:1}
.page-hero .pill{background:rgba(232,84,26,.2);border-color:rgba(232,84,26,.4)}
.page-hero h1{color:var(--white);font-size:clamp(1.9rem,4vw,2.9rem);margin:.5rem 0 0}
.breadcrumb{display:flex;align-items:center;gap:.45rem;margin-top:.9rem;font-family:var(--fh);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.38)}
.breadcrumb a{color:rgba(232,84,26,.9)}
.breadcrumb svg{width:11px;height:11px;opacity:.5}

/* ======================================================
   CONTACT
   ====================================================== */
.contact-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}
.contact-left h2{color:var(--navy);font-size:1.9rem;margin:.5rem 0 2rem}
.cinfo-item{display:flex;gap:.9rem;margin-bottom:1.7rem;align-items:flex-start}
.cinfo-icon{width:46px;height:46px;background:var(--off);border:1px solid var(--gray-lt);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}
.cinfo-icon svg{width:20px;height:20px;color:var(--orange)}
.cinfo-item strong{display:block;font-family:var(--fh);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);margin-bottom:.25rem}
.cinfo-item p,.cinfo-item a{font-size:.9rem;color:var(--gray-dk);line-height:1.6}
.cinfo-item a:hover{color:var(--orange)}
.hours-table{margin-top:.6rem}
.hours-row{display:flex;justify-content:space-between;gap:1rem;font-size:.85rem;padding:.24rem 0;border-bottom:1px solid var(--gray-lt)}
.hours-row:last-child{border:none}
.hours-row span{color:var(--gray)}
.hours-row strong{font-family:var(--fh);font-size:.78rem;color:var(--navy)}
.map-embed{border-radius:var(--r2);overflow:hidden;height:210px;border:1px solid var(--gray-lt);margin-top:1.6rem}
.map-embed iframe{width:100%;height:100%;border:0}
.cf-box{background:var(--off);border:1px solid var(--gray-lt);border-radius:var(--r2);padding:2.6rem}
.cf-box h3{font-family:var(--fh);color:var(--navy);font-size:1.3rem;margin-bottom:.3rem}
.cf-sub{font-size:.85rem;color:var(--gray);margin-bottom:1.8rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-family:var(--fh);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);margin-bottom:.4rem}
.fg input,.fg textarea,.fg select{width:100%;padding:.8rem 1rem;background:var(--white);border:1.5px solid var(--gray-lt);border-radius:var(--r);color:var(--text);font-size:.9rem;font-family:var(--fb);transition:border-color var(--tr),box-shadow var(--tr)}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,84,26,.1);outline:none}
.fg textarea{min-height:122px;resize:vertical}
.form-ok{display:none;background:#eef9f3;border:1px solid #80d4a4;color:#1a7a4a;border-radius:var(--r);padding:.85rem 1.1rem;font-family:var(--fh);font-weight:700;font-size:.82rem;text-align:center;margin-top:.9rem}

/* ======================================================
   ABOUT / SERVICE DETAIL PAGE
   ====================================================== */
.svc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.svc-detail-grid img{width:100%;border-radius:var(--r2);aspect-ratio:4/3;object-fit:cover;box-shadow:var(--sh2)}
.svc-detail-grid h2{color:var(--navy);margin:.4rem 0 .4rem}
.feat-list{margin:1.6rem 0 .5rem}
.feat-list li{display:flex;align-items:flex-start;gap:.65rem;font-size:.9rem;margin-bottom:.75rem;font-family:var(--fb)}
.feat-list svg{width:16px;height:16px;color:var(--orange);flex-shrink:0;margin-top:3px}
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.mc{background:var(--white);border-radius:var(--r2);padding:2rem 1.8rem;border:1px solid var(--gray-lt);border-top:3px solid var(--orange);transition:var(--tr)}
.mc:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.mc h4{font-family:var(--fh);color:var(--navy);margin-bottom:.55rem}
.mc p{font-size:.88rem}

/* ======================================================
   TEAM
   ====================================================== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.team-card{background:var(--white);border-radius:var(--r2);border:1px solid var(--gray-lt);overflow:hidden;transition:transform var(--tr),box-shadow var(--tr)}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--sh2)}
.team-photo{width:100%;aspect-ratio:1/1;overflow:hidden;background:var(--off)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-info{padding:1.3rem 1.2rem;text-align:center}
.team-info h4{font-family:var(--fh);color:var(--navy);font-size:.92rem;margin-bottom:.2rem}
.team-info .role{color:var(--orange);font-family:var(--fh);font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.team-info p{font-size:.8rem;margin-top:.35rem;color:var(--gray)}

/* ======================================================
   GALLERY SECTION (inner pages)
   ====================================================== */
.gallery-section{background:var(--off)}

/* ======================================================
   FOOTER
   ====================================================== */
footer{background:var(--navy-dk);color:rgba(255,255,255,.52)}
.footer-top{padding:4.5rem 0 3rem;display:grid;grid-template-columns:1.8fr 1fr 1fr 1.4fr;gap:3rem;border-bottom:1px solid rgba(255,255,255,.07)}
.fb-logo img{height:48px;width:auto;margin-bottom:1.1rem;filter:brightness(10)}
.fb-logo p{font-size:.85rem;line-height:1.82}
.fc-title{display:inline-block;font-family:var(--fh);font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--white);margin-bottom:1.3rem;padding-bottom:.5rem;border-bottom:2px solid var(--orange)}
.fc-links li{margin-bottom:.55rem}
.fc-links a{font-size:.85rem;color:rgba(255,255,255,.48);transition:color var(--tr);display:flex;align-items:center;gap:.38rem}
.fc-links a::before{content:'›';color:var(--orange)}
.fc-links a:hover{color:var(--orange)}
.fc-contact li{display:flex;align-items:flex-start;gap:.65rem;font-size:.85rem;margin-bottom:.9rem}
.fc-contact svg{width:14px;height:14px;color:var(--orange);flex-shrink:0;margin-top:3px}
.fc-contact a:hover{color:var(--orange)}
.socials{display:flex;gap:.55rem;margin-top:1.2rem}
.soc-btn{width:34px;height:34px;background:rgba(255,255,255,.06);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.42);transition:var(--tr)}
.soc-btn:hover{background:var(--orange);color:var(--white)}
.soc-btn svg{width:15px;height:15px}
.footer-bottom{padding:1.3rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-family:var(--fh);font-size:.7rem;font-weight:500}
.footer-bottom a:hover{color:var(--orange)}

/* ======================================================
   LIGHTBOX
   ====================================================== */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.94);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:var(--r)}
.lb-close{position:absolute;top:1.1rem;right:1.1rem;width:42px;height:42px;background:rgba(255,255,255,.1);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.3rem;transition:background var(--tr)}
.lb-close:hover{background:var(--orange)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.1);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--white);transition:background var(--tr)}
.lb-prev{left:1rem}.lb-next{right:1rem}
.lb-prev:hover,.lb-next:hover{background:var(--orange)}
.lb-prev svg,.lb-next svg{width:20px;height:20px}

/* ======================================================
   REVEAL ANIMATIONS
   ====================================================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ======================================================
   RESPONSIVE
   ====================================================== */
@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;padding:4.5rem 0 3rem}
  .hero-visual{display:none}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-visual{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid::before{display:none}
  .testi-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .contact-wrap{grid-template-columns:1fr;gap:2.5rem}
  .svc-detail-grid{grid-template-columns:1fr}
  .mission-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .section{padding:3.8rem 0}
  .top-bar{display:none}
  .nav-menu{
    display:none;position:fixed;
    top:72px;left:0;right:0;bottom:0;
    background:var(--white);
    flex-direction:column;align-items:stretch;
    padding:1.2rem 1.5rem;overflow-y:auto;
    border-top:3px solid var(--orange);z-index:999;
    gap:0;
  }
  .nav-menu.open{display:flex}
  .nav-toggle{display:flex}
  .nav-link{padding:.85rem 1rem;border-radius:var(--r);border-bottom:1px solid var(--gray-lt);color:var(--navy)!important}
  .dropdown{position:static;transform:none;box-shadow:none;border:none;border-radius:0;border-top:none;padding:0 0 .4rem 1rem;display:none;animation:none}
  .nav-item.mob-open>.dropdown{display:block!important}
  .nav-item.mob-open>.nav-link .chev{transform:rotate(180deg)}
  .nav-cta{margin:.8rem 0 0}
  .svc-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .pf-grid{grid-template-columns:repeat(2,1fr)}
  .cta-inner{text-align:center;justify-content:center}
  .cta-right{justify-content:center}
  .footer-top{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .mission-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  h1{font-size:2.2rem}
}
@media(max-width:480px){
  .container{padding:0 1.1rem}
  .pf-grid{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  .hero-btns .btn{width:100%;justify-content:center}
  .stats-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr}
  .mission-grid{grid-template-columns:1fr}
}

/* ── extra spacing utilities ── */
#commercial { scroll-margin-top: 90px; }
.section + .section { margin-top: 0; }
/* ensure gallery section bg works */
.gallery-section { background: var(--off); }
/* svc-detail-grid inner image fallback */
.svc-detail-grid > div > img {
  width:100%;border-radius:var(--r2);
  aspect-ratio:4/3;object-fit:cover;box-shadow:var(--sh2);
}

/* ── mobile accordion ── */
@media(max-width:768px){
  .nav-item.mob-open>.dropdown{display:block!important}
  .nav-item.mob-open>.nav-link .chev{transform:rotate(180deg)}
  .dropdown .dd-link{font-size:.82rem;padding:.6rem .9rem}
}
/* ── scrolled header (no transparent variant needed) ── */
#site-header.scrolled{box-shadow:0 4px 24px rgba(27,42,92,.13)}

/* ======================================================
   MOBILE FIXED BOTTOM BAR
   ====================================================== */
.mobile-cta-bar {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9000;
  background: var(--white);
  border-top: 1px solid var(--gray-lt);
  box-shadow: 0 -4px 24px rgba(27,42,92,.14);
  padding: .75rem 1rem calc(.75rem + env(safe-area-inset-bottom));
}
.mobile-cta-bar .cta-label {
  text-align: center;
  font-family: var(--fh);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: .55rem;
}
.mobile-cta-bar .cta-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
}
.mobile-cta-bar .btn-call {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  background: var(--navy);
  color: var(--white);
  font-family: var(--fh);
  font-size: .82rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase;
  padding: .88rem 1rem;
  border-radius: 100px;
  text-decoration: none;
  transition: var(--tr);
  border: none; cursor: pointer;
}
.mobile-cta-bar .btn-call svg { width: 16px; height: 16px; flex-shrink: 0; }
.mobile-cta-bar .btn-call:hover { background: var(--navy-md); }
.mobile-cta-bar .btn-start {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  background: var(--orange);
  color: var(--white);
  font-family: var(--fh);
  font-size: .82rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase;
  padding: .88rem 1rem;
  border-radius: 100px;
  text-decoration: none;
  transition: var(--tr);
  border: none; cursor: pointer;
  box-shadow: 0 4px 16px rgba(232,84,26,.3);
}
.mobile-cta-bar .btn-start svg { width: 16px; height: 16px; flex-shrink: 0; }
.mobile-cta-bar .btn-start:hover { background: var(--orange-l); }

/* Show only on mobile */
@media (max-width: 768px) {
  .mobile-cta-bar { display: block; }
  /* Push page content up so bar doesn't cover footer */
  body { padding-bottom: calc(80px + env(safe-area-inset-bottom)); }
}
