/* =====================================================================
   DOUBLE IMPACT PROJECTS (PTY) LTD - shared styles (styles.css)
   Identity: full-truck-load road logistics & supply chain (South Africa).
   Theme: "route map / editorial", dotted route lines, origin/destination
   nodes, station markers and a green-to-blue gradient accent language.
   ===================================================================== */

:root{
  --ink:#0a2552;          /* deep navy (brand dark) */
  --ink-2:#0e2f66;
  --blue:#1f74c4;         /* logo blue */
  --blue-br:#46a0e6;
  --blue-deep:#13548f;
  --blue-soft:#eaf2fb;
  --green:#15a45f;        /* logo green */
  --green-br:#27c279;
  --green-deep:#0c7a45;
  --green-soft:#e7f6ee;
  --steel:#5b6776;
  --mist:#9fb0c2;         /* muted text on navy */
  --mist-2:#c4d0dd;
  --paper:#f4f6f9;
  --paper-2:#e9eef3;
  --line:#dde4ec;
  --ink-text:#15212e;
  --muted:#5d6b7b;
  --white:#fff;

  --disp:'Montserrat', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --body:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
  --hh:74px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 18px 44px rgba(10,24,40,.13);
  --shadow-lg:0 30px 64px rgba(6,18,32,.22);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ font-family:var(--body); color:var(--ink-text); background:var(--white); line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
section{ scroll-margin-top:var(--hh); }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.band{ padding-block:clamp(58px,8vw,108px); position:relative; }
.band--paper{ background:var(--paper); }
.band--paper2{ background:var(--paper-2); }
.band--navy{ background:var(--ink); color:var(--mist-2); }
.band--navy h1,.band--navy h2,.band--navy h3{ color:#fff; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--disp); font-weight:800; line-height:1.05; letter-spacing:-.01em; color:var(--ink); }
.h-xl{ font-size:clamp(38px,6.4vw,76px); font-weight:900; line-height:1.02; }
.h-l{ font-size:clamp(30px,4.4vw,52px); }
.h-m{ font-size:clamp(23px,3vw,34px); }
.lead{ font-size:clamp(16px,1.9vw,19px); color:var(--muted); }
.band--navy .lead{ color:var(--mist); }

/* ---------- eyebrow: route origin node + halo (signature) ---------- */
.kicker{ display:inline-flex; align-items:center; gap:11px; font-family:var(--disp); font-weight:700; font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue-deep); }
.kicker::before{ content:""; width:10px; height:10px; flex:none; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px var(--green-soft); }
.kicker--onnavy{ color:var(--blue-br); }
.kicker--onnavy::before{ background:var(--green-br); box-shadow:0 0 0 4px rgba(39,194,121,.22); }
.kicker--green{ color:var(--green-deep); }

.section-head{ max-width:62ch; margin-bottom:clamp(32px,4.5vw,52px); }
.section-head h2{ margin:14px 0 0; }
.section-head .lead{ margin-top:16px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .kicker{ justify-content:center; }

/* ---------- the route line under section titles (signature) ---------- */
.section-head h2::after,
.split__body h2::after,
.svc__body h2::after,
.info h2::after{
  content:""; display:block; height:12px; width:154px; margin-top:18px;
  background-image:
    repeating-linear-gradient(90deg,var(--line) 0 5px,transparent 5px 13px),
    radial-gradient(circle 6px at 6px 50%,var(--green) 0 5px,transparent 6px),
    radial-gradient(circle 6px at calc(100% - 6px) 50%,#fff 0 3px,var(--blue) 3px 5px,transparent 6px);
  background-repeat:no-repeat;
  background-size:calc(100% - 28px) 2px,12px 12px,12px 12px;
  background-position:center,left center,right center;
}
.section-head.center h2::after{ margin-left:auto; margin-right:auto; }
.band--navy .section-head h2::after,
.band--navy .split__body h2::after{
  background-image:
    repeating-linear-gradient(90deg,rgba(255,255,255,.34) 0 5px,transparent 5px 13px),
    radial-gradient(circle 6px at 6px 50%,var(--green-br) 0 5px,transparent 6px),
    radial-gradient(circle 6px at calc(100% - 6px) 50%,var(--ink) 0 3px,var(--blue-br) 3px 5px,transparent 6px);
}
/* reusable inline route rule (origin filled, destination open) */
.route{ position:relative; height:12px; width:160px; margin:14px 0;
  background-image:
    repeating-linear-gradient(90deg,var(--line) 0 5px,transparent 5px 13px),
    radial-gradient(circle 6px at 6px 50%,var(--green) 0 5px,transparent 6px),
    radial-gradient(circle 6px at calc(100% - 6px) 50%,#fff 0 3px,var(--blue) 3px 5px,transparent 6px);
  background-repeat:no-repeat; background-size:calc(100% - 28px) 2px,12px 12px,12px 12px; background-position:center,left center,right center; }

/* ---------- section transitions / accents ---------- */
.diag-top{ position:relative; }
.diag-top::before{ display:none; }
/* CTA accent reworked into a centered route line */
.accent-bar{ position:relative; display:flex; align-items:center; justify-content:space-between; width:160px; height:12px; overflow:visible; }
.accent-bar::before{ content:""; position:absolute; left:6px; right:6px; top:50%; transform:translateY(-50%); height:2px; background:repeating-linear-gradient(90deg,rgba(255,255,255,.42) 0 5px,transparent 5px 13px); }
.accent-bar i{ position:relative; z-index:1; width:12px; height:12px; border-radius:50%; }
.accent-bar .g{ background:var(--green-br); }
.accent-bar .b{ background:transparent; border:2px solid var(--blue-br); }

/* ---------- buttons (pills) ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--disp); font-weight:700; font-size:14px; letter-spacing:.02em; padding:14px 26px; border-radius:999px; transition:transform .2s var(--ease), background .2s, color .2s, box-shadow .2s, border-color .2s; white-space:nowrap; }
.btn svg{ width:17px; height:17px; }
.btn--green{ background:var(--green); color:#fff; box-shadow:0 12px 26px rgba(21,164,95,.3); }
.btn--green:hover{ background:var(--green-deep); transform:translateY(-2px); }
.btn--blue{ background:var(--blue); color:#fff; box-shadow:0 12px 26px rgba(31,116,196,.3); }
.btn--blue:hover{ background:var(--blue-deep); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.4); }
.btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.1); transform:translateY(-2px); }
.btn--outline{ background:transparent; color:var(--ink); border:1.5px solid var(--line); }
.btn--outline:hover{ border-color:var(--green); color:var(--green-deep); transform:translateY(-2px); }

/* ---------- photo frame (clean rounded, pill tag) ---------- */
.frame{ position:relative; overflow:hidden; background:var(--ink-2); border-radius:12px; }
.frame > img{ width:100%; height:100%; object-fit:cover; }
.frame--tag::after{ content:attr(data-tag); position:absolute; left:12px; bottom:12px; font-family:var(--disp); font-weight:700; font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:#fff; background:var(--blue); padding:6px 12px; border-radius:999px; }
.frame--green.frame--tag::after{ background:var(--green); }

.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- header ---------- */
.hdr{ position:fixed; inset:0 0 auto 0; z-index:100; height:var(--hh); display:flex; align-items:center; background:transparent; transition:background .3s var(--ease), box-shadow .3s var(--ease); }
.hdr.solid{ background:#fff; box-shadow:0 2px 18px rgba(10,24,40,.10); }
.hdr__in{ display:flex; align-items:center; justify-content:space-between; width:100%; gap:20px; }
.brand{ display:flex; align-items:center; gap:11px; }
.brand__logo{ height:46px; width:auto; }
.brand__logo--white{ display:block; }
.brand__logo--colour{ display:none; }
.hdr.solid .brand__logo--white{ display:none; }
.hdr.solid .brand__logo--colour{ display:block; }
.hdr:not(.solid) .nav__links a{ color:rgba(255,255,255,.92); }
.hdr:not(.solid) .nav__tog span{ background:#fff; }

.nav{ display:flex; align-items:center; gap:30px; }
.nav__links{ display:flex; align-items:center; gap:26px; }
.nav__links a{ font-family:var(--disp); font-weight:600; font-size:14.5px; color:var(--ink); position:relative; padding:6px 0; transition:color .2s; }
.nav__links a:not(.btn)::after{ content:""; position:absolute; left:0; bottom:-2px; height:3px; width:0; background:var(--green); border-radius:2px; transition:width .25s var(--ease); }
.nav__links a:not(.btn):hover::after, .nav__links a:not(.btn).active::after{ width:100%; }
.nav__links a.active{ color:var(--blue); }
.hdr:not(.solid) .nav__links a.active{ color:#fff; }
.nav__tog{ display:none; width:44px; height:44px; }
.nav__tog span{ display:block; width:23px; height:2px; background:var(--ink); margin:5px auto; transition:.3s var(--ease); border-radius:2px; }
.nav__tog[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__tog[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__tog[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero (home) ---------- */
.hero{ position:relative; min-height:94svh; display:flex; align-items:center; color:#fff; padding-top:var(--hh); overflow:hidden;
  background:linear-gradient(100deg, rgba(7,20,44,.95) 0%, rgba(7,20,44,.80) 42%, rgba(7,20,44,.40) 100%), var(--hero-img) center/cover no-repeat, var(--ink); }
.hero__route{ position:absolute; inset:0; width:100%; height:100%; z-index:1; pointer-events:none; }
.hero__in{ position:relative; z-index:2; max-width:880px; padding-block:clamp(40px,7vw,80px); }
.hero h1{ color:#fff; margin:18px 0; }
.hero h1 em{ font-style:normal; color:var(--green-br); }
.hero__sub{ font-size:clamp(16px,2vw,20px); color:var(--mist-2); max-width:64ch; line-height:1.6; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:13px; margin-top:30px; }
.hero__strip{ position:absolute; bottom:0; left:0; right:0; z-index:2; background:rgba(7,20,44,.66); backdrop-filter:blur(5px); border-top:1px solid rgba(255,255,255,.12); }
.hero__strip .wrap{ display:flex; flex-wrap:wrap; gap:8px 0; }
.hero__stat{ flex:1 1 auto; min-width:150px; padding:18px 26px 18px 0; margin-right:26px; border-right:1px solid rgba(255,255,255,.14); position:relative; }
.hero__stat::before{ content:""; position:absolute; left:0; top:21px; width:8px; height:8px; border-radius:50%; background:var(--green-br); display:none; }
.hero__stat:last-child{ border-right:none; }
.hero__stat b{ font-family:var(--disp); font-weight:800; font-size:22px; color:#fff; display:block; }
.hero__stat span{ font-size:12px; color:var(--mist); letter-spacing:.02em; }

/* ---------- page hero (interior) ---------- */
.phero{ position:relative; padding-top:calc(var(--hh) + clamp(42px,7vw,80px)); padding-bottom:clamp(42px,7vw,76px); color:#fff; overflow:hidden;
  background:linear-gradient(100deg, rgba(7,20,44,.93), rgba(7,20,44,.66)), var(--phero-img) center/cover no-repeat, var(--ink); }
.phero h1{ color:#fff; margin:14px 0 12px; }
.phero p{ color:var(--mist-2); max-width:62ch; font-size:clamp(15px,1.8vw,18px); }

/* ---------- intro / split ---------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,68px); align-items:center; }
.split--rev .split__media{ order:-1; }
.split__media{ position:relative; }
.split__media .frame{ aspect-ratio:4/5; }
.split__media .frame.wide{ aspect-ratio:5/4; }
.split__body p{ margin-top:14px; color:#3a4757; }
.band--navy .split__body p{ color:var(--mist); }
.split__body .lead{ margin-top:18px; }

/* quote callout */
.pull{ position:relative; padding:30px 30px 30px 40px; background:var(--ink); color:#fff; border-radius:14px; overflow:hidden; }
.pull::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:6px; background:linear-gradient(var(--green),var(--blue)); }
.pull q{ font-family:var(--disp); font-weight:700; font-size:clamp(19px,2.4vw,26px); line-height:1.3; quotes:none; }
.pull q::before{ content:"\201C"; }
.pull q::after{ content:"\201D"; }
.pull cite{ display:block; margin-top:14px; font-style:normal; font-size:13px; letter-spacing:.06em; color:var(--mist); }

/* ---------- grids & cards ---------- */
.grid{ display:grid; gap:20px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.svc-card{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; display:flex; flex-direction:column; transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.svc-card::before{ content:""; position:absolute; left:0; top:26px; width:4px; height:30px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); z-index:1; }
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.svc-card__ico{ width:54px; height:54px; margin:24px 24px 0; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(31,116,196,.1); color:var(--blue); }
.svc-card__ico svg{ width:27px; height:27px; }
.svc-card:nth-child(even) .svc-card__ico{ background:rgba(21,164,95,.12); color:var(--green-deep); }
.svc-card__body{ padding:16px 24px 26px; display:flex; flex-direction:column; flex:1; }
.svc-card__body h3{ font-size:19px; }
.svc-card__no{ font-family:var(--disp); font-weight:800; font-size:12px; letter-spacing:.1em; color:var(--green); margin-bottom:8px; }
.svc-card__body p{ font-size:14px; color:var(--muted); margin-top:8px; line-height:1.6; }

/* detailed service block */
.svc{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,64px); align-items:center; }
.svc:not(:first-of-type){ margin-top:clamp(46px,6vw,84px); }
.svc--rev .svc__media{ order:-1; }
.svc__media .frame{ aspect-ratio:5/4; }
.svc__tag{ font-family:var(--disp); font-weight:800; font-size:13px; letter-spacing:.1em; color:var(--green-deep); text-transform:uppercase; display:inline-flex; align-items:center; gap:9px; }
.svc__tag::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px var(--green-soft); }

/* feature list (node ticks) */
.ticks{ display:flex; flex-direction:column; gap:11px; margin-top:18px; }
.ticks li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--ink-text); line-height:1.5; }
.band--navy .ticks li{ color:var(--mist-2); }
.ticks svg{ width:20px; height:20px; flex:none; margin-top:1px; color:var(--green); background:var(--green-soft); border-radius:50%; padding:3px; }
.band--navy .ticks svg{ color:var(--green-br); background:rgba(39,194,121,.16); }

/* ---------- stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.stat{ position:relative; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.14); border-radius:14px; padding:28px 22px 26px 26px; }
.stat::before{ content:""; position:absolute; left:0; top:28px; width:4px; height:30px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green-br),var(--blue-br)); }
.stat b{ font-family:var(--disp); font-weight:900; font-size:clamp(30px,4vw,44px); color:#fff; line-height:1; display:block; }
.stat b i{ font-style:normal; color:var(--green-br); }
.stat p{ font-size:13px; color:var(--mist); margin-top:10px; line-height:1.5; }

/* ---------- industries ---------- */
.inds{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.ind{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px 20px 22px 24px; transition:transform .2s var(--ease), border-color .2s, box-shadow .2s; }
.ind::before{ content:""; position:absolute; left:0; top:22px; width:4px; height:26px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); }
.ind:hover{ transform:translateY(-4px); border-color:var(--green); box-shadow:var(--shadow); }
.ind__ico{ width:48px; height:48px; margin-bottom:13px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(21,164,95,.12); color:var(--green-deep); }
.ind__ico svg{ width:25px; height:25px; }
.ind h4{ font-size:16px; margin-bottom:6px; }
.ind p{ font-size:13px; color:var(--muted); line-height:1.55; }

/* feature rows / capabilities */
.feat{ display:flex; gap:16px; align-items:flex-start; }
.feat__ico{ width:50px; height:50px; flex:none; border-radius:12px; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--blue),var(--blue-deep)); color:#fff; }
.feat__ico.green{ background:linear-gradient(135deg,var(--green),var(--green-deep)); }
.feat__ico svg{ width:25px; height:25px; }
.feat h4{ font-size:17px; margin-bottom:6px; }
.feat p{ font-size:14px; color:var(--muted); line-height:1.6; }
.band--navy .feat p{ color:var(--mist); }

/* mission/vision blocks */
.mv{ position:relative; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:clamp(24px,3vw,36px); overflow:hidden; }
.mv::after{ content:""; position:absolute; right:-40px; top:-40px; width:150px; height:150px; border-radius:50%; border:2px dotted rgba(255,255,255,.12); }
.mv .feat__ico{ margin-bottom:18px; }
.mv h3{ font-size:21px; margin-bottom:10px; }

/* numbered aims (node card) */
.aims{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:8px; }
.aim{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; padding:24px 20px 24px 24px; }
.aim::before{ content:""; position:absolute; left:0; top:24px; width:4px; height:28px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); }
.aim__n{ font-family:var(--disp); font-weight:800; font-size:13px; letter-spacing:.12em; color:var(--green); }
.aim h4{ font-size:15.5px; margin:6px 0 6px; }
.aim p{ font-size:13.5px; color:var(--muted); line-height:1.55; }

/* core values (node card) */
.vals{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.val{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; padding:24px 22px 24px 26px; transition:transform .2s var(--ease), box-shadow .2s; }
.val::before{ content:""; position:absolute; left:0; top:24px; width:4px; height:30px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); }
.val:nth-child(3n-1)::before{ background:linear-gradient(var(--blue),var(--green)); }
.val:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.val__ico{ width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(31,116,196,.1); color:var(--blue); margin-bottom:14px; }
.val:nth-child(3n-1) .val__ico{ background:rgba(21,164,95,.12); color:var(--green-deep); }
.val__ico svg{ width:24px; height:24px; }
.val h4{ font-size:18px; margin-bottom:7px; }
.val p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* compliance chips (node) */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ font-family:var(--disp); font-weight:700; font-size:12px; letter-spacing:.04em; color:#fff;
  border:1px solid rgba(255,255,255,.28); border-radius:999px; padding:8px 16px; background:rgba(255,255,255,.05); display:inline-flex; align-items:center; gap:8px; }
.chip::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--green-br); flex:none; }
.band--paper .chip{ color:var(--ink); border-color:var(--line); background:#fff; }
.band--paper .chip::before{ background:var(--green); }

/* hubs / network as route stations */
.hubs{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.hubs::before{ content:""; position:absolute; left:26px; right:26px; top:27px; height:2px; z-index:0;
  background:repeating-linear-gradient(90deg,var(--line) 0 5px,transparent 5px 13px); }
.hub{ position:relative; z-index:1; background:#fff; border:1px solid var(--line); border-radius:14px; padding:34px 24px 24px; overflow:hidden; }
.hub::before{ content:""; position:absolute; top:20px; left:24px; width:14px; height:14px; border-radius:50%; background:var(--green); box-shadow:0 0 0 5px var(--green-soft); }
.hub:nth-child(2)::before{ background:var(--blue); box-shadow:0 0 0 5px var(--blue-soft); }
.hub:nth-child(3)::before{ background:#fff; border:2px solid var(--blue); box-shadow:0 0 0 5px var(--blue-soft); }
.hub h4{ font-size:18px; margin-bottom:4px; }
.hub .prov{ font-family:var(--disp); font-weight:700; font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--green-deep); margin-bottom:12px; }
.hub p{ font-size:13.5px; color:var(--muted); line-height:1.6; }
.partners{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:30px; }
.partner{ font-family:var(--disp); font-weight:700; font-size:13px; color:var(--ink); background:#fff; border:1px solid var(--line); border-radius:999px; padding:11px 20px; letter-spacing:.02em; display:inline-flex; align-items:center; gap:9px; }
.partner::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--green); flex:none; }
.band--navy .partner{ color:#fff; background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); }

/* tech & innovation (node card) */
.tech{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tcard{ position:relative; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:26px 22px 26px 26px; transition:transform .2s var(--ease), border-color .2s; }
.tcard::before{ content:""; position:absolute; left:0; top:26px; width:4px; height:28px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green-br),var(--blue-br)); }
.tcard:hover{ transform:translateY(-4px); border-color:var(--green-br); }
.tcard__ico{ width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(39,194,121,.16); color:var(--green-br); margin-bottom:14px; }
.tcard__ico svg{ width:24px; height:24px; }
.tcard h4{ color:#fff; font-size:17px; margin-bottom:7px; }
.tcard p{ font-size:13.5px; color:var(--mist); line-height:1.6; }

/* fleet list (node card) */
.fleet{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.fl{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px 20px 22px 24px; }
.fl::before{ content:""; position:absolute; left:0; top:22px; width:4px; height:26px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); }
.fl__ico{ width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(31,116,196,.1); color:var(--blue); margin-bottom:13px; }
.fl__ico svg{ width:24px; height:24px; }
.fl h4{ font-size:16px; margin-bottom:6px; }
.fl p{ font-size:13.5px; color:var(--muted); line-height:1.55; }

/* sustainability steps as route nodes */
.steps{ display:flex; flex-direction:column; gap:14px; }
.step{ display:flex; gap:18px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px 22px; }
.step__n{ flex:none; width:44px; height:44px; border-radius:50%; background:#fff; border:2px solid var(--green); color:var(--green-deep); font-family:var(--disp); font-weight:800; font-size:15px; display:grid; place-items:center; box-shadow:0 0 0 5px var(--green-soft); }
.step:nth-child(even) .step__n{ border-color:var(--blue); color:var(--blue-deep); box-shadow:0 0 0 5px var(--blue-soft); }
.step h4{ font-size:16.5px; margin-bottom:5px; }
.step p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* certifications strip */
.certs{ display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:center; }
.cert{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px 24px; display:flex; align-items:center; justify-content:center; min-width:150px; min-height:96px; }
.cert img{ max-height:60px; width:auto; }
.cert--text{ flex-direction:column; gap:4px; }
.cert--text b{ font-family:var(--disp); font-weight:800; font-size:17px; color:var(--ink); letter-spacing:.02em; }
.cert--text span{ font-size:11px; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; }

/* strengths cards (why choose) as node cards */
.strength{ position:relative; background:#fff; border:1px solid var(--line); border-radius:14px; padding:26px 22px 26px 26px; text-align:center; transition:transform .2s var(--ease), border-color .2s, box-shadow .2s; }
.strength::before{ content:""; position:absolute; left:0; top:26px; width:4px; height:30px; border-radius:0 4px 4px 0; background:linear-gradient(var(--green),var(--blue)); }
.strength:hover{ transform:translateY(-5px); border-color:var(--green); box-shadow:var(--shadow); }
.strength .feat__ico{ margin:0 0 16px; }
.strength h4{ font-size:17px; margin-bottom:8px; }
.strength p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* ---------- gallery + lightbox ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gitem{ position:relative; overflow:hidden; border-radius:12px; aspect-ratio:1; cursor:pointer; background:var(--ink-2); border:0; padding:0; }
.gitem img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.gitem::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 55%, rgba(7,20,44,.55)); opacity:0; transition:opacity .3s; }
.gitem:hover img{ transform:scale(1.07); }
.gitem:hover::after{ opacity:1; }
.gitem.span2{ grid-column:span 2; aspect-ratio:2/1; }
.lightbox{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; background:rgba(5,14,30,.92); padding:24px; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 30px 80px rgba(0,0,0,.5); }
.lb-btn{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; font-size:26px; display:grid; place-items:center; transition:background .2s; }
.lb-btn:hover{ background:rgba(255,255,255,.24); }
.lb-prev{ left:18px; } .lb-next{ right:18px; }
.lb-close{ position:absolute; top:18px; right:20px; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; font-size:24px; display:grid; place-items:center; }
.lb-close:hover{ background:rgba(255,255,255,.24); }
.lb-cap{ position:absolute; bottom:20px; left:0; right:0; text-align:center; color:#cdd8e4; font-family:var(--disp); font-weight:600; font-size:13px; letter-spacing:.04em; }

/* ---------- CTA band ---------- */
.cta{ position:relative; color:#fff; overflow:hidden; text-align:center;
  background:linear-gradient(rgba(7,20,44,.9),rgba(7,20,44,.93)), var(--cta-img) center/cover no-repeat, var(--ink); }
.cta .accent-bar{ margin:0 auto 14px; }
.cta h2{ color:#fff; margin:14px auto 14px; max-width:22ch; }
.cta p{ color:var(--mist-2); max-width:58ch; margin:0 auto 28px; font-size:17px; }
.cta__cta{ display:flex; gap:13px; justify-content:center; flex-wrap:wrap; }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(30px,5vw,60px); align-items:start; }
.info{ display:flex; flex-direction:column; gap:6px; }
.info__item{ display:grid; grid-template-columns:50px 1fr; gap:15px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line); }
.info__item .ico{ width:50px; height:50px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(31,116,196,.1); color:var(--blue); }
.info__item:nth-child(even) .ico{ background:rgba(21,164,95,.12); color:var(--green-deep); }
.info__item .ico svg{ width:23px; height:23px; }
.info__item .k{ font-family:var(--disp); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--green-deep); }
.info__item .v{ font-size:15.5px; color:var(--ink-text); font-weight:500; line-height:1.5; margin-top:3px; }
.info__item .v a:hover{ color:var(--blue); }

.form{ position:relative; background:#fff; border:1px solid var(--line); border-radius:16px; padding:clamp(22px,3vw,36px); box-shadow:var(--shadow); overflow:hidden; }
.form::before{ content:""; position:absolute; left:0; top:0; right:0; height:5px; background:linear-gradient(90deg,var(--green),var(--blue)); }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fld{ margin-bottom:16px; }
.fld label{ display:block; font-family:var(--disp); font-weight:600; font-size:12.5px; color:#33414f; margin-bottom:7px; }
.fld label .req{ color:var(--green-deep); }
.fld input,.fld select,.fld textarea{ width:100%; font-family:var(--body); font-size:14.5px; color:var(--ink-text); background:var(--paper); border:1.5px solid var(--line); border-radius:10px; padding:12px 14px; transition:border-color .2s, box-shadow .2s, background .2s; outline:none; }
.fld textarea{ resize:vertical; min-height:120px; }
.fld input:focus,.fld select:focus,.fld textarea:focus{ border-color:var(--green); box-shadow:0 0 0 3px rgba(21,164,95,.14); background:#fff; }
.fld input.bad,.fld select.bad,.fld textarea.bad{ border-color:#c0182a; box-shadow:0 0 0 3px rgba(192,24,42,.12); }
.fld .err{ display:none; color:#c0182a; font-size:12px; margin-top:6px; }
.fld.show .err{ display:block; }
.consent{ display:flex; gap:11px; align-items:flex-start; margin:4px 0 18px; }
.consent input{ width:18px; height:18px; flex:none; margin-top:3px; accent-color:var(--green); }
.consent label{ font-size:12.5px; color:var(--muted); line-height:1.5; }
.form__btn{ width:100%; justify-content:center; }
.form__ok{ display:none; text-align:center; padding:18px; background:rgba(21,164,95,.08); border:1px solid rgba(21,164,95,.28); border-radius:12px; color:var(--green-deep); margin-top:16px; font-size:14px; }
.form__ok.show{ display:block; }
.form__ok strong{ display:block; font-size:16px; color:var(--ink-text); margin-bottom:4px; }
.form__bad{ display:none; text-align:center; padding:13px 15px; background:rgba(192,24,42,.08); border:1px solid rgba(192,24,42,.3); border-radius:12px; color:#9c1322; margin-top:14px; font-size:13.5px; }
.form__bad.show{ display:block; }
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; opacity:0; }

/* ---------- footer ---------- */
.ftr{ background:var(--ink); color:var(--mist); position:relative; padding-block:clamp(46px,6vw,72px) 26px; }
.ftr::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--green),var(--blue)); }
.ftr__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:34px; }
.ftr__logo{ height:60px; width:auto; margin-bottom:16px; }
.ftr__about{ font-size:13.5px; line-height:1.7; max-width:36ch; }
.ftr h5{ position:relative; color:#fff; font-family:var(--disp); font-weight:700; font-size:13px; letter-spacing:.06em; margin-bottom:16px; padding-left:16px; }
.ftr h5::before{ content:""; position:absolute; left:0; top:5px; width:8px; height:8px; border-radius:50%; background:var(--green-br); }
.ftr a,.ftr__col p{ display:block; font-size:13.5px; color:var(--mist); margin-bottom:10px; transition:color .2s; line-height:1.5; }
.ftr__col a:hover{ color:#fff; }
.ftr__bot{ margin-top:40px; padding-top:22px; border-top:2px dotted rgba(255,255,255,.18); display:flex; flex-wrap:wrap; gap:8px 22px; justify-content:space-between; font-size:12.5px; color:#7c8da0; }

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .ftr__top{ grid-template-columns:1fr 1fr; }
  .inds,.aims{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .vals,.tech,.hubs,.fleet,.grid-3{ grid-template-columns:repeat(2,1fr); }
  .gallery{ grid-template-columns:repeat(3,1fr); }
  .hubs::before{ display:none; }
}
@media (max-width:860px){
  .nav__links{ display:none; }
  .nav__tog{ display:block; }
  .nav.open .nav__links{ display:flex; flex-direction:column; align-items:flex-start; gap:0; position:fixed; top:var(--hh); left:0; right:0; background:#fff; padding:10px var(--gut) 22px; border-bottom:1px solid var(--line); box-shadow:0 12px 24px rgba(10,24,40,.12); max-height:calc(100svh - var(--hh)); overflow:auto; }
  .nav.open .nav__links a{ color:var(--ink); font-size:16px; padding:14px 0; width:100%; border-bottom:1px solid var(--line); }
  .split,.contact-grid,.svc,.grid-2{ grid-template-columns:1fr; }
  .split--rev .split__media, .svc--rev .svc__media{ order:0; }
  .split__media .frame, .split__media .frame.wide{ aspect-ratio:16/10; }
  .grid-3,.grid-4{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .grid-2,.grid-3,.grid-4,.inds,.stats,.vals,.tech,.hubs,.fleet,.aims,.form__row{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .gitem.span2{ grid-column:span 2; aspect-ratio:2/1; }
  .hero__stat{ border-right:none; margin-right:0; padding:12px 0; }
  .ftr__top{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  *{ transition:none !important; }
}
