/* =====================================================================
   MetaPro  ·  style.css  ·  Full Responsive (Mobile + Desktop)
   Palette: #0a0a0a Black  ·  #ffffff White  ·  #1a6b3c Royal Green
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap');

:root{
  --black:#0a0a0a;--black-soft:#111;--black-card:#161616;
  --white:#fff;--muted:#c0c0c0;
  --green:#1a6b3c;--green-l:#22873e;--green-a:#2bbd60;
  --green-glow:rgba(26,107,60,.35);
  --border:rgba(255,255,255,.08);--bgreen:rgba(26,107,60,.4);
  --r:10px;--rl:18px;
  --ease:.4s cubic-bezier(.25,.46,.45,.94);
  --fd:'Bebas Neue',sans-serif;
  --fh:'Syne',sans-serif;
  --fb:'DM Sans',sans-serif;
}

/* ── Reset ─────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--black);color:var(--white);font-family:var(--fb);line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{font-family:inherit;border:none;outline:none;background:none}
input,select,textarea{outline:none;font-family:var(--fb)}

/* Custom cursor — desktop only */
.cursor-dot,.cursor-ring{display:none;pointer-events:none;position:fixed;top:0;left:0;z-index:9999;transform:translate(-50%,-50%)}
@media(hover:hover)and(pointer:fine){
  body,a,button{cursor:none}
  .cursor-dot{display:block;width:8px;height:8px;background:var(--green-a);border-radius:50%}
  .cursor-ring{display:block;z-index:9998;width:36px;height:36px;border:1.5px solid var(--green-a);border-radius:50%;transition:width .3s,height .3s,background .3s}
  .cursor-ring.hov{width:52px;height:52px;background:rgba(43,189,96,.08)}
}

body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9990;opacity:.55}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--black)}::-webkit-scrollbar-thumb{background:var(--green);border-radius:4px}

/* =====================================================================
   NAVBAR — mobile-first
   ===================================================================== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:padding var(--ease),background var(--ease);
}
.navbar.scrolled{padding:10px 20px;background:rgba(10,10,10,.98)}
.nav-logo{display:inline-flex;align-items:center;gap:10px;flex-shrink:0;z-index:1001}
.nav-logo-icon{width:34px;height:34px;background:var(--green);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:15px;color:#fff;flex-shrink:0}
.nav-logo-text{font-family:var(--fh);font-weight:800;font-size:19px;letter-spacing:-.5px}
.nav-logo-text span{color:var(--green-a)}
.nav-links{display:none}
.nav-cta{padding:8px 18px;background:var(--green);color:var(--white);font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;border-radius:6px;transition:background var(--ease),box-shadow var(--ease)}
.nav-cta:hover{background:var(--green-l);box-shadow:0 6px 20px var(--green-glow);color:var(--white)}

/* Hamburger */
.nav-hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:8px;min-width:44px;min-height:44px;background:none;border:none;z-index:1001;cursor:pointer;-webkit-tap-highlight-color:transparent}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.mobile-nav{position:fixed;inset:0;background:rgba(10,10,10,.98);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease,visibility .35s ease}
.mobile-nav.open{opacity:1;visibility:visible;pointer-events:auto}
.mobile-close{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s}
.mobile-close:hover{background:rgba(255,255,255,.12)}
.mobile-nav a{display:block;padding:10px 28px;font-family:var(--fd);font-size:clamp(32px,9vw,52px);letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.6);transition:color .25s,transform .25s;-webkit-tap-highlight-color:transparent}
.mobile-nav a:hover,.mobile-nav a[aria-current="page"]{color:var(--green-a);transform:translateX(8px)}
.mobile-nav-social{display:flex;gap:12px;margin-top:20px}
.mobile-nav-social a{padding:6px 14px!important;font-family:var(--fh)!important;font-size:11px!important;letter-spacing:1px!important;transform:none!important;border:1px solid rgba(255,255,255,.15);border-radius:100px;color:rgba(255,255,255,.4)!important}
.mobile-nav-social a:hover{color:var(--green-a)!important;border-color:var(--green-a)}

@media(min-width:768px){
  .navbar{padding:18px 40px}
  .navbar.scrolled{padding:13px 40px}
  .nav-links{display:flex;align-items:center;gap:28px;list-style:none}
  .nav-links a{font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);position:relative;transition:color var(--ease)}
  .nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--green-a);transition:width var(--ease)}
  .nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--white)}
  .nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
  .nav-hamburger{display:none}
  .mobile-nav{display:none!important}
}
@media(min-width:1100px){
  .navbar{padding:20px 60px}
  .navbar.scrolled{padding:14px 60px}
  .nav-links{gap:36px}
}

/* =====================================================================
   LAYOUT / TYPOGRAPHY
   ===================================================================== */
section{padding:60px 20px;position:relative}
@media(min-width:768px){section{padding:80px 40px}}
@media(min-width:1100px){section{padding:100px 60px}}

.lbl{display:inline-flex;align-items:center;gap:10px;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--green-a);margin-bottom:14px}
.lbl::before{content:'';width:22px;height:2px;background:var(--green-a)}
.ht{font-family:var(--fd);font-size:clamp(36px,8vw,78px);line-height:.95;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.ht .gr{color:var(--green-a)}
.hs{font-size:15px;font-weight:300;color:var(--muted);line-height:1.75;max-width:560px}
.divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--bgreen),transparent)}

/* Buttons */
.btn-g{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;background:var(--green);color:var(--white);font-family:var(--fh);font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;border-radius:8px;transition:var(--ease);-webkit-tap-highlight-color:transparent}
.btn-g:hover{background:var(--green-l);transform:translateY(-2px);box-shadow:0 10px 28px var(--green-glow);color:var(--white)}
.btn-g .arr{transition:transform var(--ease)}
.btn-g:hover .arr{transform:translateX(4px)}
.btn-out{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;background:transparent;color:var(--white);font-family:var(--fh);font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;border:1px solid var(--border);border-radius:8px;transition:var(--ease);-webkit-tap-highlight-color:transparent}
.btn-out:hover{border-color:var(--green-a);color:var(--green-a);transform:translateY(-2px)}
.btn-white{display:inline-flex;align-items:center;gap:9px;padding:14px 32px;background:var(--white);color:var(--green);font-family:var(--fh);font-weight:800;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;border-radius:8px;transition:var(--ease);-webkit-tap-highlight-color:transparent}
.btn-white:hover{background:var(--black);color:var(--white);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.3)}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:90px 20px 52px;position:relative;overflow:hidden}
@media(min-width:768px){.hero{padding:110px 40px 70px}}
@media(min-width:1100px){.hero{justify-content:center;padding:120px 60px 80px}}

.hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(26,107,60,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(26,107,60,.05) 1px,transparent 1px);background-size:40px 40px;animation:gridMove 22s linear infinite}
@keyframes gridMove{0%{transform:translateY(0)}100%{transform:translateY(40px)}}
.hero::after{content:'';position:absolute;top:-20%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(26,107,60,.2) 0%,transparent 70%);animation:orbPulse 6s ease-in-out infinite;pointer-events:none}
@keyframes orbPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}

.hero-inner{position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 13px;background:rgba(26,107,60,.15);border:1px solid var(--bgreen);border-radius:100px;font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-a);margin-bottom:20px}
.hero-badge .dot{width:6px;height:6px;background:var(--green-a);border-radius:50%;animation:blink 1.5s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{font-family:var(--fd);font-size:clamp(52px,13vw,130px);line-height:.9;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px}
.hero-title .out{-webkit-text-stroke:1.5px var(--white);color:transparent}
.hero-title .gr{color:var(--green-a)}
@media(min-width:1100px){.hero-title .ln2{display:block;padding-left:80px}}
.hero-desc{font-size:15px;font-weight:300;color:var(--muted);line-height:1.8;margin-bottom:28px;max-width:500px}
@media(min-width:768px){.hero-desc{font-size:16px}}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}
.hero-stats{display:flex;flex-wrap:wrap;gap:20px 32px;padding-top:24px;border-top:1px solid var(--border);position:relative;z-index:2}
@media(min-width:1100px){.hero-stats{position:absolute;bottom:56px;right:60px;border-top:none;padding-top:0;margin-bottom:0;flex-wrap:nowrap;gap:44px}}
.stat-n{font-family:var(--fd);font-size:clamp(36px,6vw,50px);line-height:1;color:var(--white)}
.stat-n span{color:var(--green-a)}
.stat-l{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:2px}

.scroll-ind{display:none}
@media(min-width:1100px){
  .scroll-ind{display:flex;position:absolute;bottom:36px;left:60px;align-items:center;gap:11px;z-index:2}
  .scroll-ln{width:1px;height:54px;background:linear-gradient(to bottom,rgba(43,189,96,.8),transparent);animation:sani 2s ease-in-out infinite}
  @keyframes sani{0%,100%{opacity:.4}50%{opacity:1}}
  .scroll-tx{writing-mode:vertical-rl;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);font-family:var(--fh)}
}

/* =====================================================================
   MARQUEE
   ===================================================================== */
.mq-section{padding:18px 0;overflow:hidden;background:var(--green);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.mq-track{display:flex;animation:mq 22s linear infinite;white-space:nowrap;width:max-content}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.mq-item{display:inline-flex;align-items:center;gap:14px;padding:0 28px;font-family:var(--fd);font-size:16px;letter-spacing:2px;color:rgba(255,255,255,.9)}
.mq-dot{width:5px;height:5px;background:rgba(255,255,255,.4);border-radius:50%;flex-shrink:0}

/* =====================================================================
   ABOUT SNIPPET
   ===================================================================== */
.about-snip{padding:60px 20px;display:flex;flex-direction:column;gap:36px}
@media(min-width:768px){.about-snip{padding:80px 40px;gap:48px}}
@media(min-width:1100px){.about-snip{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:100px 60px}}
.snip-visual{position:relative}
.snip-img{width:100%;border-radius:var(--rl);background:var(--black-card);border:1px solid var(--border);overflow:hidden;aspect-ratio:4/3}
@media(min-width:1100px){.snip-img{aspect-ratio:4/5}}
.snip-float{position:absolute;bottom:-14px;right:-8px;background:var(--green);border-radius:var(--r);padding:16px 20px;border:1px solid rgba(255,255,255,.1);box-shadow:0 12px 40px rgba(0,0,0,.4)}
@media(min-width:768px){.snip-float{bottom:-20px;right:-16px;padding:20px 26px}}
@media(min-width:1100px){.snip-float{bottom:-24px;right:-24px;padding:22px 28px}}
.snip-num{font-family:var(--fd);font-size:clamp(32px,5vw,48px);color:var(--white);line-height:1}
.snip-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:3px}

/* =====================================================================
   SERVICES GRID
   ===================================================================== */
.srv-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:600px){.srv-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.srv-grid{grid-template-columns:repeat(3,1fr);gap:22px}}
.srv-card{background:var(--black-card);border:1px solid var(--border);border-radius:var(--rl);padding:26px 22px;position:relative;overflow:hidden;transition:var(--ease)}
.srv-card::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform var(--ease)}
.srv-card:hover{border-color:var(--bgreen);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.srv-card:hover::before{transform:scaleX(1)}
.srv-icon{width:46px;height:46px;margin-bottom:16px;background:rgba(26,107,60,.12);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:21px;transition:var(--ease)}
.srv-card:hover .srv-icon{background:var(--green);box-shadow:0 8px 24px var(--green-glow)}
.srv-ttl{font-family:var(--fh);font-size:17px;font-weight:700;margin-bottom:9px}
.srv-dsc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.srv-tags{display:flex;flex-wrap:wrap;gap:6px}
.srv-tag{padding:3px 9px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:100px;font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}

/* =====================================================================
   STATS BAR
   ===================================================================== */
.stats-bar{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(min-width:1100px){.stats-bar{grid-template-columns:repeat(4,1fr)}}
.sb-item{background:var(--black);padding:32px 18px;text-align:center}
@media(min-width:768px){.sb-item{padding:44px 28px}}
@media(min-width:1100px){.sb-item{padding:50px 36px}}
.sb-n{font-family:var(--fd);font-size:clamp(38px,8vw,62px);color:var(--green-a);line-height:1}
.sb-l{font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:7px}

/* =====================================================================
   PORTFOLIO
   ===================================================================== */
.port-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:0}
@media(min-width:600px){.port-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){
  .port-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .port-item:nth-child(1){grid-column:span 2;aspect-ratio:16/9}
  .port-item:nth-child(4){grid-column:span 2;aspect-ratio:16/9}
}
.port-item{border-radius:var(--rl);overflow:hidden;background:var(--black-card);border:1px solid var(--border);aspect-ratio:4/3;position:relative}
.port-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.port-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:18px;opacity:0;transition:opacity var(--ease)}
.port-item:hover .port-img{transform:scale(1.06)}
.port-item:hover .port-ov{opacity:1}
@media(hover:none){.port-ov{opacity:1}}
.port-cat{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--green-a);margin-bottom:4px}
.port-nm{font-family:var(--fh);font-size:16px;font-weight:700}

/* Portfolio full page */
.port-filters{display:flex;flex-wrap:wrap;gap:8px;padding:28px 20px 0}
@media(min-width:768px){.port-filters{padding:36px 40px 0;gap:10px}}
@media(min-width:1100px){.port-filters{padding:44px 60px 0}}
.flt-btn{padding:8px 16px;background:var(--black-card);border:1px solid var(--border);border-radius:100px;color:var(--muted);font-family:var(--fh);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;transition:var(--ease);cursor:pointer;min-height:36px;-webkit-tap-highlight-color:transparent}
.flt-btn:hover,.flt-btn.on{background:var(--green);border-color:var(--green);color:var(--white)}
.port-full{display:grid;grid-template-columns:1fr;gap:18px;padding:28px 20px 60px}
@media(min-width:600px){.port-full{grid-template-columns:1fr 1fr;padding:28px 40px 60px}}
@media(min-width:1100px){.port-full{grid-template-columns:repeat(3,1fr);gap:22px;padding:40px 60px 100px}}
.port-card{border-radius:var(--rl);overflow:hidden;border:1px solid var(--border);background:var(--black-card);transition:var(--ease)}
.port-card:hover{border-color:var(--bgreen);transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.port-card-img{aspect-ratio:16/9;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px}
.port-card-body{padding:18px}
.pc-cat{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--green-a);margin-bottom:4px}
.pc-ttl{font-family:var(--fh);font-size:16px;font-weight:700;margin-bottom:6px}
.pc-dsc{font-size:12px;color:var(--muted);line-height:1.6}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.testi{padding:60px 20px;background:var(--black-soft)}
@media(min-width:768px){.testi{padding:80px 40px}}
@media(min-width:1100px){.testi{padding:100px 60px}}
.testi-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:768px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.testi-grid{grid-template-columns:repeat(3,1fr);gap:22px}}
.testi-card{background:var(--black-card);border:1px solid var(--border);border-radius:var(--rl);padding:26px 22px;transition:var(--ease)}
.testi-card:hover{border-color:var(--bgreen);transform:translateY(-3px)}
.testi-stars{display:flex;gap:3px;margin-bottom:12px;font-size:13px;color:#f5c842}
.testi-txt{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:18px;font-style:italic}
.testi-auth{display:flex;align-items:center;gap:11px}
.testi-av{width:40px;height:40px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:13px;flex-shrink:0}
.testi-nm{font-family:var(--fh);font-weight:700;font-size:13px}
.testi-rl{font-size:10px;color:var(--muted);letter-spacing:1px}

/* =====================================================================
   CTA BAND
   ===================================================================== */
.cta-band{padding:80px 20px;text-align:center;background:var(--green);position:relative;overflow:hidden}
@media(min-width:768px){.cta-band{padding:100px 40px}}
.cta-band::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.04'%3E%3Cpath d='M20 20v-8h-2v8h-8v2h8v8h2v-8h8v-2h-8z'/%3E%3C/g%3E%3C/svg%3E")}
.cta-band h2{font-family:var(--fd);font-size:clamp(42px,10vw,96px);line-height:.95;text-transform:uppercase;position:relative;z-index:1;margin-bottom:16px}
.cta-band p{font-size:15px;color:rgba(255,255,255,.75);margin-bottom:32px;position:relative;z-index:1;max-width:420px;margin-left:auto;margin-right:auto}
.cta-band .btn-white{position:relative;z-index:1}

/* =====================================================================
   PAGE HERO VARIANTS
   ===================================================================== */
.pg-hero{min-height:50vh;display:flex;flex-direction:column;justify-content:flex-end;padding:95px 20px 44px;background:var(--black-soft);position:relative;overflow:hidden}
@media(min-width:768px){.pg-hero{padding:110px 40px 52px}}
@media(min-width:1100px){.pg-hero{padding:130px 60px 64px}}
.pg-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 50%,rgba(26,107,60,.15) 0%,transparent 65%);pointer-events:none}

/* =====================================================================
   SERVICES LIST PAGE
   ===================================================================== */
.srv-list{padding:44px 20px}
@media(min-width:768px){.srv-list{padding:60px 40px}}
@media(min-width:1100px){.srv-list{padding:80px 60px}}
.srv-row{display:flex;flex-direction:column;gap:14px;padding:32px 0;border-bottom:1px solid var(--border);position:relative}
@media(min-width:1100px){
  .srv-row{display:grid;grid-template-columns:56px 1fr 1fr;gap:36px;align-items:start;padding:44px 0}
  .srv-row::before{content:'';position:absolute;left:-60px;right:-60px;top:0;bottom:0;background:var(--black-card);opacity:0;transition:opacity var(--ease);z-index:-1}
  .srv-row:hover::before{opacity:1}
}
.srv-rn{font-family:var(--fd);font-size:32px;color:var(--border);line-height:1;transition:color var(--ease);display:none}
@media(min-width:1100px){.srv-rn{display:block;font-size:44px}}
.srv-row:hover .srv-rn{color:var(--green-a)}
.srv-rt{font-family:var(--fh);font-size:clamp(19px,3.5vw,26px);font-weight:800;margin-bottom:8px}
.srv-rd{font-size:13px;color:var(--muted);line-height:1.7}
.srv-rf{display:flex;flex-direction:column;gap:7px}
.srv-rf li{display:flex;align-items:flex-start;gap:9px;font-size:12px;color:var(--muted)}
.srv-rf li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green-a);flex-shrink:0;margin-top:4px}

/* =====================================================================
   PROCESS STEPS
   ===================================================================== */
.proc{padding:60px 20px}
@media(min-width:768px){.proc{padding:80px 40px}}
@media(min-width:1100px){.proc{padding:100px 60px}}
.proc-steps{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:44px}
@media(min-width:1100px){
  .proc-steps{grid-template-columns:repeat(5,1fr);position:relative}
  .proc-steps::before{content:'';position:absolute;top:25px;left:8%;right:8%;height:1px;background:var(--bgreen)}
}
.proc-step{text-align:center}
.proc-n{width:50px;height:50px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:18px;margin:0 auto 14px;box-shadow:0 0 0 5px var(--black),0 0 0 6px var(--bgreen);position:relative;z-index:1}
.proc-t{font-family:var(--fh);font-weight:700;font-size:13px;margin-bottom:5px}
.proc-d{font-size:12px;color:var(--muted);line-height:1.6}

/* =====================================================================
   ABOUT PAGE
   ===================================================================== */
.about-grid{display:flex;flex-direction:column;gap:36px;padding:60px 20px}
@media(min-width:768px){.about-grid{padding:80px 40px;gap:48px}}
@media(min-width:1100px){.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:100px 60px}}
.val-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:600px){.val-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.val-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
.val-card{padding:26px 22px;border:1px solid var(--border);border-radius:var(--rl);transition:var(--ease)}
.val-card:hover{border-color:var(--bgreen);background:var(--black-card)}
.val-n{font-family:var(--fd);font-size:50px;color:var(--border);line-height:1;margin-bottom:9px;transition:color var(--ease)}
.val-card:hover .val-n{color:var(--green-a)}
.val-t{font-family:var(--fh);font-size:17px;font-weight:700;margin-bottom:9px}
.val-d{font-size:13px;color:var(--muted);line-height:1.75}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:36px}
@media(min-width:768px){.team-grid{grid-template-columns:repeat(2,1fr);gap:20px}}
@media(min-width:1100px){.team-grid{grid-template-columns:repeat(4,1fr);gap:22px}}
.team-card{background:var(--black-card);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:var(--ease)}
.team-card:hover{border-color:var(--bgreen);transform:translateY(-4px)}
.team-img{aspect-ratio:3/4;background:linear-gradient(135deg,var(--black-soft),var(--green) 200%);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:44px;color:rgba(255,255,255,.15)}
.team-inf{padding:14px}
.team-nm{font-family:var(--fh);font-weight:700;font-size:14px;margin-bottom:3px}
.team-rl{font-size:10px;color:var(--green-a);letter-spacing:1.5px;text-transform:uppercase;font-weight:600}

/* =====================================================================
   CONTACT / ENQUIRY
   ===================================================================== */
.cph{padding:95px 20px 44px;background:var(--black-soft);position:relative;overflow:hidden}
@media(min-width:768px){.cph{padding:110px 40px 52px}}
@media(min-width:1100px){.cph{padding:130px 60px 64px}}
.cph::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 75% 50%,rgba(26,107,60,.14) 0%,transparent 65%);pointer-events:none}

.enq-wrap{padding:44px 20px 60px;display:flex;flex-direction:column;gap:36px}
@media(min-width:768px){.enq-wrap{padding:60px 40px 80px}}
@media(min-width:1100px){.enq-wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:60px;padding:80px 60px;align-items:start}}

.enq-info{padding-top:4px}
@media(min-width:1100px){.enq-info{position:sticky;top:110px}}
.enq-info h2{font-family:var(--fd);font-size:clamp(32px,6vw,56px);text-transform:uppercase;line-height:.95;margin-bottom:14px}
.enq-info>p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:28px}

.cc-list{display:flex;flex-direction:column;gap:11px}
.cc{display:flex;align-items:flex-start;gap:13px;padding:15px 16px;background:var(--black-card);border:1px solid var(--border);border-radius:var(--r);transition:var(--ease)}
.cc:hover{border-color:var(--bgreen);transform:translateX(3px)}
.cc-ico{width:37px;height:37px;flex-shrink:0;background:var(--green);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px}
.cc-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green-a);margin-bottom:2px}
.cc-val{font-size:13px;color:var(--white);line-height:1.5}
.cc-val a{color:var(--white);transition:color var(--ease)}
.cc-val a:hover{color:var(--green-a)}
.soc-row{display:flex;gap:9px;margin-top:24px}
.soc-btn{width:42px;height:42px;min-width:44px;min-height:44px;border:1px solid var(--border);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--fh);color:var(--muted);transition:var(--ease);-webkit-tap-highlight-color:transparent}
.soc-btn:hover{border-color:var(--green-a);color:var(--green-a);background:rgba(26,107,60,.1);transform:translateY(-2px)}

/* Enquiry form card */
.enq-card{background:var(--black-card);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden}
.enq-head{padding:22px 22px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(26,107,60,.08),transparent)}
@media(min-width:600px){.enq-head{padding:28px 32px 22px}}
.enq-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;background:rgba(43,189,96,.1);border:1px solid var(--bgreen);border-radius:6px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-a);margin-bottom:10px;font-family:var(--fh);font-weight:700}
.enq-head h3{font-family:var(--fh);font-size:19px;font-weight:800;margin-bottom:4px}
.enq-head p{font-size:12px;color:var(--muted)}
.enq-body{padding:22px}
@media(min-width:600px){.enq-body{padding:28px 32px 32px}}

/* Step tabs */
.step-tabs{display:flex;border-radius:8px;overflow:hidden;border:1px solid var(--border);margin-bottom:22px}
.step-tab{flex:1;padding:9px 4px;text-align:center;font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);background:transparent;border:none;border-right:1px solid var(--border);transition:var(--ease);cursor:pointer;min-height:40px;-webkit-tap-highlight-color:transparent}
.step-tab:last-child{border-right:none}
.step-tab.on{background:var(--green);color:#fff}
.step-tab.done{background:rgba(26,107,60,.2);color:var(--green-a)}
.f-panel{display:none}
.f-panel.on{display:block;animation:fsup .35s ease both}
@keyframes fsup{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* Form elements */
.fg{margin-bottom:15px}
.fl{display:block;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.fl .req{color:var(--green-a);margin-left:2px}
.fi,.fta,.fse{width:100%;padding:12px 14px;background:var(--black-soft);border:1px solid var(--border);border-radius:8px;color:var(--white);font-family:var(--fb);font-size:14px;transition:border-color var(--ease),box-shadow var(--ease);-webkit-appearance:none;appearance:none}
.fi:focus,.fta:focus,.fse:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow)}
.fta{height:100px;resize:vertical}
.fse{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23c0c0c0' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}
.fse option{background:var(--black-card)}
.fi.err,.fta.err,.fse.err{border-color:#e55!important;box-shadow:0 0 0 3px rgba(220,80,80,.15)!important}
.ferr{font-size:11px;color:#e55;margin-top:3px;display:none}
.ferr.on{display:block}
.f2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:400px){.f2col{grid-template-columns:1fr}}
.char-ct{font-size:10px;color:var(--muted);text-align:right;margin-top:3px}
.char-ct.warn{color:#e55}

/* Submit buttons */
.sub-btn{width:100%;padding:14px;background:var(--green);color:#fff;font-family:var(--fh);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:var(--ease);-webkit-tap-highlight-color:transparent;min-height:48px}
.sub-btn:hover{background:var(--green-l);transform:translateY(-2px);box-shadow:0 12px 32px var(--green-glow)}
.sub-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.sub-btn.ghost{background:transparent;border:1px solid var(--border);color:var(--muted);flex:0 0 auto;width:auto;padding:14px 20px}
.sub-btn.ghost:hover{border-color:var(--green-a);color:var(--green-a);box-shadow:none;transform:translateY(-1px)}
.spin{display:none;width:17px;height:17px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* Error banner */
.err-banner{display:none;padding:12px 14px;background:rgba(220,80,80,.12);border:1px solid rgba(220,80,80,.3);border-radius:8px;font-size:13px;color:#ff8080;margin-bottom:16px;line-height:1.5}
.err-banner.on{display:block}

/* Review card */
.review-card{background:var(--black-soft);border:1px solid var(--border);border-radius:11px;padding:16px;margin-bottom:16px}
.r-row{display:flex;gap:10px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:7px;margin-bottom:7px}
.r-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.rk{color:var(--green-a);font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;min-width:72px;flex-shrink:0;padding-top:2px}
.rv{font-size:12px;color:rgba(255,255,255,.75);word-break:break-word}

/* Success state */
.enq-ok{display:none;padding:44px 22px;text-align:center;flex-direction:column;align-items:center;gap:14px}
@media(min-width:600px){.enq-ok{padding:52px 32px}}
.enq-ok.on{display:flex}
.ok-ico{width:70px;height:70px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 0 0 14px rgba(26,107,60,.12);animation:pop .5s cubic-bezier(.34,1.56,.64,1) both}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.ok-t{font-family:var(--fh);font-size:22px;font-weight:800}
.ok-d{font-size:13px;color:var(--muted);max-width:300px;line-height:1.7}
.ok-ref{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;background:rgba(26,107,60,.15);border:1px solid var(--bgreen);border-radius:8px;font-family:var(--fh);font-size:12px;letter-spacing:2px;color:var(--green-a)}
.ok-new{background:none;border:1px solid var(--border);border-radius:8px;padding:9px 20px;color:var(--muted);font-family:var(--fh);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:var(--ease);-webkit-tap-highlight-color:transparent;margin-top:4px}
.ok-new:hover{border-color:var(--green-a);color:var(--green-a)}

/* Map */
.map-sec{padding:0 20px 60px}
@media(min-width:768px){.map-sec{padding:0 40px 80px}}
@media(min-width:1100px){.map-sec{padding:0 60px 100px}}
.map-box{border-radius:var(--rl);overflow:hidden;border:1px solid var(--border);height:260px;background:var(--black-card);position:relative}
@media(min-width:600px){.map-box{height:320px}}
@media(min-width:1100px){.map-box{height:380px}}

/* =====================================================================
   FOOTER
   ===================================================================== */
footer{background:var(--black-soft);border-top:1px solid var(--border);padding:52px 20px 28px}
@media(min-width:768px){footer{padding:60px 40px 32px}}
@media(min-width:1100px){footer{padding:72px 60px 36px}}
.foot-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:36px}
@media(min-width:600px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(min-width:1100px){.foot-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:56px}}
.foot-desc{font-size:13px;color:var(--muted);line-height:1.8;margin-top:12px;max-width:280px}
.foot-ht{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--white);margin-bottom:14px}
.foot-lnks{display:flex;flex-direction:column;gap:9px}
.foot-lnks a{font-size:13px;color:var(--muted);transition:color var(--ease)}
.foot-lnks a:hover{color:var(--green-a)}
.foot-btm{padding-top:22px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
@media(min-width:768px){.foot-btm{flex-direction:row;justify-content:space-between;align-items:center}}
.foot-copy{font-size:11px;color:var(--muted)}
.foot-copy span{color:var(--green-a)}
.soc-links{display:flex;gap:9px;margin-top:18px}
.soc-lnk{width:40px;height:40px;border:1px solid var(--border);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--fh);transition:var(--ease)}
.soc-lnk:hover{border-color:var(--green-a);background:rgba(26,107,60,.12);transform:translateY(-2px)}
