@import url("https://fonts.googleapis.com/css2?family=Mulish:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=IBM+Plex+Sans+Arabic:wght@300;400;500;600;700&display=swap");
/* ============================================================
   Geoland Contracting — refined website design system
   Same identity (teal / graphite), same fonts, same layout —
   elevated: typographic rhythm, depth, motion & micro-detail.
   ============================================================ */
:root{
  /* brand */
  --teal:#35C8D8; --teal-deep:#1FA9B8; --teal-dk:#0E8390; --teal-glow:rgba(53,200,216,.30);
  --steel:#C7CDD1; --graphite:#1B2127; --graphite-2:#222b32;

  /* neutrals */
  --ink:#222a30; --body:#4b545b; --muted:#7d878f; --faint:#9aa3aa;
  --line:#e9ecee; --line-2:#f1f3f5; --bg:#ffffff; --bg-soft:#f8fafb; --white:#fafaf8;

  /* type */
  --hf:"Avenir Next","Avenir","Mulish","Segoe UI",system-ui,sans-serif;
  --ar:"IBM Plex Sans Arabic","Geeza Pro",sans-serif;

  /* scale */
  --max:1200px; --gutter:clamp(20px,4vw,40px);
  --r-sm:12px; --r:18px; --r-lg:24px; --r-xl:30px;

  /* shadows — layered for depth */
  --sh-1:0 1px 2px rgba(18,24,30,.04), 0 4px 12px rgba(18,24,30,.05);
  --sh-2:0 6px 18px rgba(18,24,30,.07), 0 20px 44px rgba(18,24,30,.09);
  --sh-3:0 10px 30px rgba(18,24,30,.10), 0 34px 70px rgba(18,24,30,.14);
  --sh-teal:0 14px 40px rgba(31,169,184,.30);

  --ease:cubic-bezier(.22,.7,.25,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--hf);color:var(--body);background:var(--bg);
  line-height:1.7;font-weight:400;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--teal);color:#06303a}
.ar{font-family:var(--ar);direction:rtl;font-feature-settings:"kern";letter-spacing:0}

/* filmic grain — subtle premium texture over everything */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:soft-light;
}

/* scroll progress bar */
#progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:80;
  background:linear-gradient(90deg,var(--teal-deep),var(--teal));box-shadow:0 0 12px var(--teal-glow);transition:width .12s linear}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
section{position:relative}

/* ---------- typography ---------- */
h1,h2,h3{color:var(--graphite);line-height:1.08;font-weight:600;letter-spacing:-.022em;text-wrap:balance}
h2{font-size:clamp(28px,3.6vw,44px)}
h3{font-size:21px;letter-spacing:-.01em}
p{text-wrap:pretty}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--teal-deep);font-weight:700}
.kicker::before{content:"";width:22px;height:1.5px;background:currentColor;opacity:.6}
.kicker.solo::before{display:none}
.lead{font-size:clamp(17px,1.5vw,20px);color:var(--body);line-height:1.72;font-weight:400}
.muted{color:var(--muted)}
.tick{width:38px;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-deep));border-radius:3px;margin:20px 0 24px}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:14px 30px;border-radius:40px;
  font-size:14px;font-weight:600;letter-spacing:.01em;cursor:pointer;border:1px solid transparent;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s,border-color .3s}
.btn>*{position:relative;z-index:1}
.btn-primary{background:var(--graphite);color:#fff;box-shadow:var(--sh-1)}
.btn-primary:hover{background:#0f1419;transform:translateY(-3px);box-shadow:var(--sh-2)}
.btn-teal{background:var(--teal);color:#06303a;box-shadow:var(--sh-1)}
.btn-teal::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55),transparent 70%);
  transform:translateX(-120%);transition:transform .7s var(--ease)}
.btn-teal:hover{transform:translateY(-3px);box-shadow:var(--sh-teal)}
.btn-teal:hover::before{transform:translateX(120%)}
.btn-ghost{border-color:rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.04);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.7);transform:translateY(-3px)}
.btn-line{border-color:var(--line);color:var(--graphite);background:#fff}
.btn-line:hover{border-color:var(--graphite);transform:translateY(-3px);box-shadow:var(--sh-1)}

/* ---------- header ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:70;transition:background .4s,box-shadow .4s,backdrop-filter .4s}
header.nav .bar{display:flex;align-items:center;justify-content:space-between;height:80px;transition:height .35s}
header.nav.solid .bar{height:68px}
header.nav .brand{display:flex;align-items:center;gap:13px;font-weight:700;color:#fff;font-size:19px;letter-spacing:.01em}
header.nav .brand img{width:68px;height:52px;object-fit:contain;border-radius:0;padding:0;background:transparent;box-shadow:none;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));transition:.35s}
header.nav nav{display:flex;gap:34px;align-items:center}
header.nav nav a:not(.cta){position:relative;font-size:14.5px;color:rgba(255,255,255,.82);font-weight:500;padding:6px 0;transition:color .25s}
header.nav nav a:not(.cta)::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--teal);transition:right .3s var(--ease)}
header.nav nav a:not(.cta):hover,header.nav nav a.active:not(.cta){color:#fff}
header.nav nav a.active:not(.cta)::after,header.nav nav a:not(.cta):hover::after{right:0}
header.nav .cta{padding:11px 22px;border-radius:30px;background:var(--teal);color:#06303a;font-weight:600;font-size:13.5px;
  box-shadow:0 6px 18px rgba(53,200,216,.28);transition:transform .3s var(--ease),box-shadow .3s}
header.nav .cta:hover{transform:translateY(-2px);box-shadow:var(--sh-teal)}
header.nav.solid{background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(20px);box-shadow:0 1px 0 var(--line),0 10px 30px rgba(18,24,30,.06)}
header.nav.solid .brand{color:var(--graphite)}
header.nav.solid nav a:not(.cta){color:#525b62}
header.nav.solid nav a:not(.cta):hover,header.nav.solid nav a.active:not(.cta){color:var(--graphite)}
header.nav.solid .brand img{filter:none}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}
header.nav.solid .menu-btn span{background:var(--graphite)}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;align-items:flex-end;color:#fff;position:relative;overflow:hidden}
.hero .bg{position:absolute;inset:0;will-change:transform}
.hero .bg img{width:100%;height:120%;object-fit:cover;animation:kenburns 22s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero .bg::after{content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 18% 100%,rgba(14,18,23,.92),transparent 60%),
    linear-gradient(180deg,rgba(14,18,23,.55) 0%,rgba(14,18,23,.18) 38%,rgba(14,18,23,.90) 100%)}
.hero .inner{position:relative;padding:0 0 clamp(70px,11vh,118px);max-width:820px}
.hero .ar{color:var(--teal);font-size:clamp(16px,1.5vw,19px);margin-bottom:10px;letter-spacing:.02em;font-weight:500}
.hero h1{color:#fff;font-size:clamp(40px,6.2vw,74px);font-weight:600;letter-spacing:-.03em;line-height:1.02}
.hero p{font-size:clamp(17px,1.6vw,21px);color:#e3e8eb;margin:24px 0 34px;max-width:580px;line-height:1.65;font-weight:300}
.hero .acts{display:flex;gap:14px;flex-wrap:wrap}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:1.5px solid rgba(255,255,255,.5);border-radius:14px;display:grid;place-items:start center;padding-top:8px}
.scroll-cue::before{content:"";width:3px;height:8px;border-radius:3px;background:#fff;animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{opacity:0;transform:translateY(0)}30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translateY(12px)}}

/* ---------- sections ---------- */
.sec{padding:clamp(76px,10vw,128px) 0}
.sec.tight{padding:clamp(60px,7vw,96px) 0}
.sec.soft{background:var(--bg-soft)}
.sec-head{max-width:720px;margin-bottom:clamp(40px,5vw,60px)}
.sec-head h2{margin-top:2px}
.grid{display:grid;gap:24px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,5vw,72px);align-items:center}
.split .media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-3);aspect-ratio:4/3}
.split .media::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 55%,rgba(27,33,39,.20));pointer-events:none}
.split .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.split .media:hover img{transform:scale(1.05)}
.statrow{display:flex;gap:clamp(28px,4vw,52px);margin-top:38px;flex-wrap:wrap}
.statrow .s .n{font-size:clamp(34px,4vw,44px);font-weight:700;line-height:1;letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--teal-deep),var(--teal-dk));-webkit-background-clip:text;background-clip:text;color:transparent}
.statrow .s .l{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:9px;font-weight:600}

/* ---------- cards ---------- */
.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,var(--teal),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s}
.card:hover{transform:translateY(-7px);box-shadow:var(--sh-3);border-color:transparent}
.card:hover::before{opacity:1}
.card .ix{width:50px;height:50px;border-radius:14px;background:linear-gradient(140deg,rgba(53,200,216,.18),rgba(53,200,216,.06));
  color:var(--teal-deep);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;margin-bottom:20px;
  letter-spacing:.02em;box-shadow:inset 0 0 0 1px rgba(53,200,216,.18)}
.card h3{margin-bottom:10px}
.card p{font-size:14.5px;color:var(--body);line-height:1.65}
.card .no{font-size:13px;font-weight:800;color:var(--teal-deep);letter-spacing:.1em;display:block;margin-bottom:6px}

/* ---------- services rows ---------- */
.srow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);align-items:center;padding:clamp(44px,5vw,64px) 0;border-top:1px solid var(--line)}
.srow:first-child{border-top:0}
.srow:nth-child(even) .media{order:2}
.srow .media{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--sh-3)}
.srow .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.srow .media:hover img{transform:scale(1.05)}
.srow h3{font-size:clamp(22px,2.4vw,28px);margin:8px 0 12px}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}
.chips span{font-size:12.5px;padding:8px 16px;border:1px solid var(--line);border-radius:30px;color:#4a5157;background:#fff;
  transition:border-color .3s,color .3s,background .3s}
.chips span:hover{border-color:var(--teal);color:var(--teal-dk);background:rgba(53,200,216,.06)}

/* ---------- projects ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.proj{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--sh-1);transition:box-shadow .4s var(--ease),transform .4s var(--ease)}
.proj:hover{box-shadow:var(--sh-3);transform:translateY(-4px)}
.proj img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.proj:hover img{transform:scale(1.08)}
.proj .cap{position:absolute;inset:auto 0 0 0;padding:26px 22px 22px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(14,18,23,.55) 45%,rgba(14,18,23,.9));transform:translateY(8px);transition:transform .45s var(--ease)}
.proj:hover .cap{transform:none}
.proj .cap .t{font-size:17px;font-weight:600;letter-spacing:-.01em}
.proj .cap .s{font-size:12.5px;color:#bfe9ef;margin-top:3px;letter-spacing:.02em}
.proj .cap .s::before{content:"";display:inline-block;width:14px;height:1px;background:var(--teal);vertical-align:middle;margin-right:7px;opacity:.8}

/* ---------- dark band ---------- */
.band{background:var(--graphite);color:#fff;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;top:-140px;right:-120px;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(53,200,216,.16),transparent 68%);pointer-events:none}
.band h2{color:#fff}.band .kicker{color:#7fe4ef}
.band .card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.09);backdrop-filter:blur(6px)}
.band .card:hover{background:rgba(255,255,255,.06);box-shadow:0 20px 50px rgba(0,0,0,.35)}
.band .card h3{color:#fff}.band .card p{color:#aeb6bc}
.band .card .ix{background:linear-gradient(140deg,rgba(53,200,216,.26),rgba(53,200,216,.08));color:#9fe9f1;box-shadow:inset 0 0 0 1px rgba(53,200,216,.25)}

/* ---------- CTA ---------- */
.cta-band{background:linear-gradient(135deg,#1b2127,#252f37);color:#fff;border-radius:var(--r-xl);padding:clamp(40px,5vw,72px);
  position:relative;overflow:hidden;box-shadow:var(--sh-3)}
.cta-band::after{content:"";position:absolute;right:-90px;top:-90px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(53,200,216,.34),transparent 70%)}
.cta-band::before{content:"";position:absolute;left:-60px;bottom:-100px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(53,200,216,.12),transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band .kicker{color:#7fe4ef}
.cta-band h2{color:#fff;font-size:clamp(26px,3.4vw,38px);margin-top:14px}
.cta-band p{color:#cfd5d9;margin:16px 0 28px;font-size:clamp(16px,1.5vw,18px);max-width:560px}

/* ---------- footer ---------- */
footer{background:#13181d;color:#9aa2a8;padding:clamp(56px,7vw,80px) 0 30px;font-size:14px;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(53,200,216,.45),transparent)}
footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:48px;border-bottom:1px solid #262e36}
footer .brand{display:flex;align-items:center;gap:13px;margin-bottom:18px}
footer .brand img{width:72px;height:56px;object-fit:contain;background:transparent;padding:0;filter:drop-shadow(0 1px 4px rgba(0,0,0,.4))}
footer .brand b{color:#fff;font-size:17px;font-weight:700;letter-spacing:.01em}
footer p{line-height:1.7}
footer h4{color:#fff;font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
footer a{display:block;color:#9aa2a8;padding:6px 0;transition:color .25s,transform .25s var(--ease);width:fit-content}
footer a:hover{color:var(--teal);transform:translateX(3px)}
footer .bot{display:flex;justify-content:space-between;padding-top:26px;color:#6b757c;font-size:12.5px;flex-wrap:wrap;gap:10px;letter-spacing:.01em}

/* ---------- page hero (inner) ---------- */
.phero{padding:clamp(130px,18vh,180px) 0 clamp(56px,8vw,82px);background:linear-gradient(160deg,#1b2127,#232d34);color:#fff;position:relative;overflow:hidden}
.phero::after{content:"";position:absolute;right:-60px;bottom:-140px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(53,200,216,.22),transparent 70%)}
.phero::before{content:"";position:absolute;left:-80px;top:-80px;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(53,200,216,.10),transparent 70%)}
.phero .kicker{color:#7fe4ef}
.phero h1{color:#fff;font-size:clamp(34px,5.2vw,56px);position:relative;letter-spacing:-.03em;margin-top:8px}
.phero p{color:#cfd5d9;font-size:clamp(16px,1.6vw,19px);max-width:640px;margin-top:18px;position:relative;line-height:1.65;font-weight:300}

/* ---------- forms ---------- */
.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .field,.form .row>div,.form>div:has(>label){display:grid;gap:7px}
.form input,.form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:15px;color:var(--ink);background:#fcfdfd;transition:border-color .25s,box-shadow .25s,background .25s}
.form input::placeholder,.form textarea::placeholder{color:#aab2b9}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(53,200,216,.14)}
.form label{font-size:12.5px;font-weight:600;color:var(--graphite);letter-spacing:.01em}
.info-row{display:flex;gap:16px;align-items:center;padding:20px 0;border-bottom:1px solid var(--line)}
.info-row .ic{width:46px;height:46px;border-radius:13px;background:linear-gradient(140deg,rgba(53,200,216,.18),rgba(53,200,216,.06));
  color:var(--teal-deep);display:flex;align-items:center;justify-content:center;font-size:18px;flex:none;box-shadow:inset 0 0 0 1px rgba(53,200,216,.18)}
.info-row .k{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.info-row .v{font-size:16px;font-weight:600;color:var(--graphite);margin-top:2px}
.info-row .v a{transition:color .25s}.info-row .v a:hover{color:var(--teal-dk)}

/* ---------- reveal / motion ---------- */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.js .reveal.in{opacity:1;transform:none}

/* orchestrated hero load */
.js .hero .inner>*,.js .phero .wrap>*{opacity:0;animation:rise .95s var(--ease-out) forwards}
.js .hero .inner>*:nth-child(1),.js .phero .wrap>*:nth-child(1){animation-delay:.12s}
.js .hero .inner>*:nth-child(2),.js .phero .wrap>*:nth-child(2){animation-delay:.22s}
.js .hero .inner>*:nth-child(3),.js .phero .wrap>*:nth-child(3){animation-delay:.32s}
.js .hero .inner>*:nth-child(4),.js .phero .wrap>*:nth-child(4){animation-delay:.42s}
.js .hero .inner>*:nth-child(5){animation-delay:.52s}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

:focus-visible{outline:2px solid var(--teal-deep);outline-offset:3px;border-radius:4px}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
  .hero .bg img{height:100%;animation:none}
  .scroll-cue{display:none}
}

/* ---------- custom scrollbar ---------- */
@media(pointer:fine){
  *{scrollbar-width:thin;scrollbar-color:var(--steel) transparent}
  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-thumb{background:#c5cdd2;border-radius:10px;border:3px solid #fff}
  ::-webkit-scrollbar-thumb:hover{background:var(--teal-deep)}
}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:36px}
  .g3,.g4,.proj-grid{grid-template-columns:1fr 1fr}
  .srow{grid-template-columns:1fr;gap:26px}
  .srow:nth-child(even) .media{order:0}
  footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  header.nav .bar{height:64px}
  header.nav nav{position:fixed;inset:64px 0 auto 0;background:rgba(17,22,27,.97);backdrop-filter:blur(14px);
    flex-direction:column;gap:0;padding:12px 0 20px;transform:translateY(-135%);transition:transform .4s var(--ease);height:auto;
    box-shadow:0 24px 50px rgba(0,0,0,.4)}
  header.nav nav.open{transform:none}
  header.nav nav a:not(.cta){padding:15px 26px;width:100%;color:#fff;font-size:16px}
  header.nav nav a:not(.cta)::after{display:none}
  header.nav .cta{display:none}
  .menu-btn{display:flex}
  .g2,.g3,.g4,.proj-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .hero .inner{padding-bottom:64px}
  .hero h1{font-size:clamp(36px,9vw,52px)}
  .hero p{font-size:17px;margin:16px 0 24px}
  .hero .acts{flex-direction:column;gap:10px}
  .hero .acts .btn{width:100%;justify-content:center}
  .statrow{gap:20px;flex-wrap:wrap}
  .statrow .s{flex:1 1 calc(33% - 20px);text-align:center}
  .sec{padding:56px 0}
  .sec.tight{padding:44px 0}
  .split{gap:28px}
  .cta-band{padding:36px 28px}
  footer .cols{grid-template-columns:1fr;gap:32px}
  footer .cols>div:first-child{padding-bottom:20px;border-bottom:1px solid #262e36}
  .proj-grid{gap:14px}
  .card{padding:24px 20px}
  .sec-head{margin-bottom:32px}
}
@media(max-width:640px){
  .how-grid{grid-template-columns:1fr!important}
}
@media(max-width:400px){
  .hero h1{font-size:32px}
  .btn{padding:13px 22px;font-size:13.5px}
}
