/* ═══════════════════════════════════════════════════════════
   Essa Energy Resources — Visual Design System
   Brand: Green #2E7D32 | Lime #7DC628 | Flame #FF8C00 | Dark #081506
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --green-dark:   #1B5E20;
  --green:        #2E7D32;
  --green-mid:    #388E3C;
  --green-light:  #7DC628;
  --green-pale:   #C8E6C9;
  --flame:        #FF8C00;
  --flame-hot:    #FF6D00;
  --flame-glow:   #FFCA28;
  --dark:         #060E05;
  --dark-2:       #0D1F0B;
  --dark-3:       #132610;
  --white:        #FFFFFF;
  --off-white:    #F5FAF4;
  --gray-50:      #F9FBF9;
  --gray-100:     #EEF3ED;
  --gray-200:     #D6E4D5;
  --gray-400:     #8FAF8D;
  --gray-600:     #4A6B47;
  --font:         'Inter', system-ui, sans-serif;
  --r:            10px;
  --r-lg:         20px;
  --r-xl:         28px;
  --sh-sm:        0 2px 8px rgba(0,0,0,.06);
  --sh-md:        0 4px 24px rgba(0,0,0,.1);
  --sh-lg:        0 12px 48px rgba(0,0,0,.15);
  --sh-xl:        0 24px 80px rgba(0,0,0,.22);
  --t:            all .28s cubic-bezier(.4,0,.2,1);
  --max:          1200px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; font-size: 16px; }
body  { font-family: var(--font); color: var(--dark); background: var(--white); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img   { max-width: 100%; display: block; }
a     { color: inherit; text-decoration: none; }
ul    { list-style: none; }

/* ── Scroll reveal ───────────────────────────── */
.r    { opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.rl   { opacity:0; transform:translateX(-36px); transition:opacity .7s ease,transform .7s ease; }
.rr   { opacity:0; transform:translateX(36px);  transition:opacity .7s ease,transform .7s ease; }
.r.on,.rl.on,.rr.on { opacity:1; transform:none; }
.d1   { transition-delay:.1s; }
.d2   { transition-delay:.2s; }
.d3   { transition-delay:.3s; }
.d4   { transition-delay:.4s; }
.d5   { transition-delay:.5s; }

/* ── Layout ──────────────────────────────────── */
.wrap { max-width:var(--max); margin:0 auto; padding:0 28px; }
.sec  { padding:104px 0; }
.sec--off    { background:var(--off-white); }
.sec--dark   { background:var(--dark); color:var(--white); }
.sec--green  { background:var(--green-dark); color:var(--white); }
.sec--flame  { background:var(--flame); }

/* ── Eyebrow / tag ───────────────────────────── */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.75rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--green-light);
  margin-bottom:14px;
}
.eyebrow::before { content:''; width:28px; height:2px; background:var(--green-light); border-radius:2px; display:block; }
.sec--dark .eyebrow  { color:var(--flame); }
.sec--dark .eyebrow::before { background:var(--flame); }
.sec--green .eyebrow { color:var(--flame-glow); }

/* ── Headings ────────────────────────────────── */
.h1 { font-size:clamp(2.5rem,5vw,4.2rem); font-weight:900; line-height:1.08; letter-spacing:-.03em; }
.h2 { font-size:clamp(1.875rem,3.2vw,2.75rem); font-weight:800; line-height:1.12; letter-spacing:-.02em; color:var(--green-dark); }
.h3 { font-size:1.25rem; font-weight:700; color:var(--dark); }
.sec--dark  .h2 { color:var(--white); }
.sec--green .h2 { color:var(--white); }

.lead { font-size:1.0625rem; line-height:1.8; color:var(--gray-600); max-width:600px; }
.sec--dark  .lead { color:rgba(255,255,255,.65); }
.sec--green .lead { color:rgba(255,255,255,.7); }

/* ── Divider ─────────────────────────────────── */
.divider { width:48px; height:4px; background:var(--green-light); border-radius:2px; margin-bottom:24px; }
.sec--dark .divider   { background:var(--flame); }
.sec--green .divider  { background:rgba(255,255,255,.5); }

/* ── Buttons ─────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 30px; border-radius:var(--r);
  font-size:.9375rem; font-weight:700; letter-spacing:.01em;
  border:2px solid transparent; cursor:pointer;
  font-family:var(--font); transition:var(--t); white-space:nowrap;
}
.btn-primary {
  background:var(--flame); color:var(--white); border-color:var(--flame);
}
.btn-primary:hover { background:var(--flame-hot); border-color:var(--flame-hot); transform:translateY(-2px); box-shadow:0 8px 28px rgba(255,140,0,.45); }
.btn-green {
  background:var(--green); color:var(--white); border-color:var(--green);
}
.btn-green:hover { background:var(--green-dark); transform:translateY(-2px); box-shadow:0 8px 28px rgba(46,125,50,.35); }
.btn-outline {
  background:transparent; color:var(--green-dark); border-color:var(--gray-200);
}
.btn-outline:hover { border-color:var(--green); color:var(--green); transform:translateY(-1px); }
.btn-ghost-white {
  background:rgba(255,255,255,.1); color:var(--white); border-color:rgba(255,255,255,.3);
  backdrop-filter:blur(8px);
}
.btn-ghost-white:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.6); }
.btn-lg  { padding:17px 38px; font-size:1.0625rem; }
.btn-sm  { padding:10px 20px; font-size:.875rem; }
.btn-full { width:100%; justify-content:center; }
.btn-arrow::after { content:'→'; font-size:1.1em; transition:transform .2s; }
.btn-arrow:hover::after { transform:translateX(4px); }

/* ═══════════════════════════════════════════════
   ANNOUNCEMENT BAR
═══════════════════════════════════════════════ */
.ann-bar {
  background:linear-gradient(90deg,var(--green-dark),var(--green),var(--green-dark));
  background-size:200% 100%;
  animation:annSlide 6s linear infinite;
  padding:11px 0; text-align:center;
}
@keyframes annSlide { 0%{background-position:0%} 100%{background-position:200%} }
.ann-bar p { font-size:.8125rem; font-weight:600; color:rgba(255,255,255,.9); letter-spacing:.04em; }
.ann-bar a { color:var(--flame-glow); text-decoration:underline; }

/* ═══════════════════════════════════════════════
   NAVBAR — white, clean, readable
═══════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--gray-100);
  transition:var(--t);
}
.nav.scrolled { box-shadow:0 4px 20px rgba(0,0,0,.08); }
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.nav__logo { display:flex; align-items:center; gap:12px; }
.nav__logo img { height:44px; width:auto; }
/* fallback text logo if svg not loaded */
.nav__logo-fallback {
  display:flex; align-items:center; gap:10px;
}
.nav__logo-mark {
  width:42px; height:42px;
  background:linear-gradient(135deg,var(--green-dark),var(--green-light));
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:.875rem; color:var(--white);
}
.nav__logo-text { line-height:1.15; }
.nav__logo-top  { font-size:1rem; font-weight:800; color:var(--green-dark); letter-spacing:-.01em; }
.nav__logo-bot  { font-size:.65rem; font-weight:700; color:var(--flame); letter-spacing:.1em; text-transform:uppercase; }

.nav__links { display:flex; align-items:center; gap:2px; }
.nav__link {
  padding:8px 16px; border-radius:8px;
  font-size:.9rem; font-weight:600; color:var(--gray-600);
  transition:var(--t);
}
.nav__link:hover { color:var(--green-dark); background:var(--gray-100); }
.nav__link.active { color:var(--green-dark); background:var(--gray-100); }

.nav__cta { margin-left:16px; padding:10px 22px; font-size:.875rem; }

.nav__burger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px;
}
.nav__burger span { display:block; width:22px; height:2.5px; background:var(--green-dark); border-radius:2px; transition:var(--t); }
.nav__burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav__burger.open span:nth-child(2) { opacity:0; }
.nav__burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ═══════════════════════════════════════════════
   HERO — cinematic, full-screen
═══════════════════════════════════════════════ */
.hero {
  min-height:100vh;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  background:var(--dark);
  padding-top:72px;
}

/* multi-layer atmospheric background */
.hero__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 100% 80% at 65% 40%, rgba(46,125,50,.28) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 20% 90%, rgba(255,140,0,.15) 0%, transparent 50%),
    radial-gradient(ellipse 70% 60% at 90% 10%, rgba(125,198,40,.08) 0%, transparent 50%),
    linear-gradient(160deg,#010901 0%,#061205 30%,#0A1E08 60%,#111F0E 100%);
}
/* grid overlay */
.hero__bg::after {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(125,198,40,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(125,198,40,.06) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 0%,transparent 100%);
}

.hero__inner {
  position:relative; z-index:2;
  flex:1; display:grid;
  grid-template-columns:1.1fr 1fr;
  align-items:center;
  gap:72px;
  padding:80px 0 60px;
}

/* Left col */
.hero__label {
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(125,198,40,.12);
  border:1px solid rgba(125,198,40,.3);
  color:var(--green-light);
  padding:7px 18px; border-radius:100px;
  font-size:.8125rem; font-weight:700; letter-spacing:.06em;
  margin-bottom:28px;
}
.hero__label-dot {
  width:7px; height:7px; background:var(--green-light); border-radius:50%;
  animation:dotPulse 2s ease-in-out infinite;
  box-shadow:0 0 0 0 rgba(125,198,40,.5);
}
@keyframes dotPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(125,198,40,.5); }
  50%      { box-shadow:0 0 0 8px rgba(125,198,40,0); }
}
.hero__h1 {
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:900;
  line-height:1.06;
  letter-spacing:-.03em;
  color:var(--white);
  margin-bottom:24px;
}
.hero__h1 em { font-style:normal; color:var(--green-light); }
.hero__h1 span { color:var(--flame); }

.hero__p {
  font-size:1.0625rem; color:rgba(255,255,255,.68); line-height:1.8;
  max-width:500px; margin-bottom:44px;
}
.hero__actions { display:flex; gap:14px; flex-wrap:wrap; }

/* Right col — visual panel */
.hero__panel {
  position:relative; display:grid;
  grid-template-rows:auto auto;
  gap:16px;
}
.hero__card-main {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(125,198,40,.25);
  border-radius:var(--r-xl);
  padding:36px 32px;
  backdrop-filter:blur(12px);
  position:relative; overflow:hidden;
}
.hero__card-main::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green-light),var(--flame));
}
.hero__card-main-title { font-size:1.125rem; font-weight:700; color:var(--white); margin-bottom:4px; }
.hero__card-main-sub   { font-size:.875rem; color:rgba(255,255,255,.5); margin-bottom:24px; }
.hero__grade-pills { display:flex; flex-wrap:wrap; gap:10px; }
.grade-pill {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  border-radius:100px; padding:8px 16px;
  font-size:.8125rem; font-weight:600; color:var(--white);
  transition:var(--t);
}
.grade-pill:hover { background:rgba(125,198,40,.15); border-color:var(--green-light); }
.grade-pill__flag { font-size:1.1rem; }
.grade-pill__gcv  { color:var(--green-light); margin-left:4px; font-size:.75rem; }

.hero__mini-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.hero__mini {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg); padding:20px 16px; text-align:center;
  transition:var(--t);
}
.hero__mini:hover { background:rgba(125,198,40,.08); border-color:rgba(125,198,40,.25); transform:translateY(-4px); }
.hero__mini-num   { font-size:1.5rem; font-weight:800; color:var(--flame); line-height:1; }
.hero__mini-label { font-size:.75rem; color:rgba(255,255,255,.5); margin-top:6px; line-height:1.3; }

/* Stats bar at bottom of hero */
.hero__bar {
  position:relative; z-index:2;
  background:rgba(255,255,255,.03);
  border-top:1px solid rgba(255,255,255,.07);
}
.hero__bar-inner {
  display:grid; grid-template-columns:repeat(4,1fr);
  divide-x: 1px solid rgba(255,255,255,.1);
}
.hero__stat {
  padding:28px 32px;
  border-right:1px solid rgba(255,255,255,.07);
  transition:var(--t);
}
.hero__stat:last-child { border-right:none; }
.hero__stat:hover { background:rgba(125,198,40,.06); }
.hero__stat-num {
  font-size:2rem; font-weight:900; color:var(--white);
  letter-spacing:-.02em; line-height:1; display:block;
}
.hero__stat-num .accent { color:var(--green-light); }
.hero__stat-label {
  font-size:.75rem; color:rgba(255,255,255,.45);
  text-transform:uppercase; letter-spacing:.08em;
  margin-top:6px; display:block;
}

/* ═══════════════════════════════════════════════
   TICKER
═══════════════════════════════════════════════ */
.ticker {
  background:var(--green-dark);
  padding:13px 0; overflow:hidden;
  border-top:3px solid var(--flame);
}
.ticker__track {
  display:flex; width:max-content;
  animation:tick 35s linear infinite;
  white-space:nowrap;
}
.ticker__track span {
  font-size:.8125rem; font-weight:600; padding:0 6px;
  color:rgba(255,255,255,.85);
}
.ticker__track span:nth-child(odd) { color:var(--flame-glow); }
@keyframes tick { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ═══════════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════════ */
.sec-head { max-width:640px; }
.sec-head--center { margin:0 auto; text-align:center; }
.sec-head--center .lead { margin:0 auto; }
.sec-head .h2 { margin-bottom:16px; }
.sec-head .lead { margin-bottom:0; }

/* ═══════════════════════════════════════════════
   INDUSTRIES — Visual block layout
═══════════════════════════════════════════════ */
.ind-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  margin-top:64px;
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--sh-lg);
}
.ind-cell {
  position:relative; overflow:hidden;
  padding:40px 32px;
  background:var(--green-dark);
  transition:var(--t);
  cursor:default;
  min-height:200px;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.ind-cell:hover { background:var(--green); z-index:1; }
.ind-cell--alt  { background:var(--dark-2); }
.ind-cell--alt:hover { background:var(--dark-3); }
.ind-cell__num {
  position:absolute; top:20px; right:24px;
  font-size:3.5rem; font-weight:900; color:rgba(255,255,255,.07);
  line-height:1; font-variant-numeric:tabular-nums;
}
.ind-cell__icon { font-size:2rem; margin-bottom:12px; }
.ind-cell__title { font-size:1.0625rem; font-weight:700; color:var(--white); margin-bottom:6px; }
.ind-cell__desc  { font-size:.875rem; color:rgba(255,255,255,.55); line-height:1.6; }
.ind-cell__line  {
  width:0; height:2px; background:var(--flame);
  margin-bottom:16px; transition:width .4s ease;
}
.ind-cell:hover .ind-cell__line { width:40px; }

/* Clients strip */
.clients-strip {
  margin-top:56px;
  background:var(--off-white);
  border:1px solid var(--gray-100);
  border-radius:var(--r-lg);
  padding:28px 36px;
  display:flex; align-items:center; gap:28px; flex-wrap:wrap;
}
.clients-strip__label { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--gray-400); flex-shrink:0; }
.clients-strip__names { display:flex; flex-wrap:wrap; gap:10px; }
.client-chip {
  padding:7px 18px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:100px;
  font-size:.8125rem; font-weight:600; color:var(--green-dark);
  transition:var(--t);
}
.client-chip:hover { border-color:var(--green-light); background:var(--green-pale); }

/* ═══════════════════════════════════════════════
   PRODUCTS — Trading cards
═══════════════════════════════════════════════ */
.products-grid {
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr;
  gap:20px;
  margin-top:64px;
}
.prod-card {
  border-radius:var(--r-xl);
  overflow:hidden;
  transition:var(--t);
  position:relative;
  display:flex; flex-direction:column;
}
.prod-card:hover { transform:translateY(-8px); box-shadow:var(--sh-xl); }
.prod-card--hero {
  background:linear-gradient(160deg,var(--dark) 0%,var(--dark-2) 40%,var(--green-dark) 100%);
  border:1px solid rgba(125,198,40,.2);
  box-shadow:var(--sh-lg);
  grid-row:span 2;
}
.prod-card--light {
  background:var(--white);
  border:1px solid var(--gray-100);
  box-shadow:var(--sh-sm);
}
.prod-card__top {
  padding:32px 28px 24px;
  flex:1;
}
.prod-card__flag { font-size:2.5rem; margin-bottom:16px; display:block; }
.prod-card__origin {
  display:inline-block;
  font-size:.7rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; color:var(--flame); margin-bottom:12px;
}
.prod-card--light .prod-card__origin { color:var(--green-mid); }
.prod-card__title { font-size:1.25rem; font-weight:800; color:var(--white); margin-bottom:10px; line-height:1.2; }
.prod-card--light .prod-card__title { color:var(--green-dark); }
.prod-card__desc  { font-size:.9rem; color:rgba(255,255,255,.6); line-height:1.7; }
.prod-card--light .prod-card__desc { color:var(--gray-600); }

/* GCV badge */
.prod-card__gcv {
  display:inline-flex; align-items:baseline; gap:4px;
  background:rgba(125,198,40,.15);
  border:1px solid rgba(125,198,40,.3);
  border-radius:8px; padding:10px 16px;
  margin:20px 0;
}
.prod-card--light .prod-card__gcv { background:var(--gray-50); border-color:var(--gray-200); }
.prod-card__gcv-val { font-size:1.75rem; font-weight:900; color:var(--green-light); line-height:1; }
.prod-card--light .prod-card__gcv-val { color:var(--green); }
.prod-card__gcv-unit { font-size:.75rem; font-weight:600; color:rgba(255,255,255,.5); }
.prod-card--light .prod-card__gcv-unit { color:var(--gray-400); }

.prod-card__specs { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.prod-spec {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 12px; background:rgba(255,255,255,.05);
  border-radius:8px; font-size:.8125rem;
}
.prod-card--light .prod-spec { background:var(--gray-50); }
.prod-spec__label { color:rgba(255,255,255,.5); }
.prod-card--light .prod-spec__label { color:var(--gray-400); }
.prod-spec__val   { font-weight:700; color:var(--white); }
.prod-card--light .prod-spec__val   { color:var(--green-dark); }

.prod-card__bot {
  padding:20px 28px 28px;
  border-top:1px solid rgba(255,255,255,.07);
}
.prod-card--light .prod-card__bot { border-top-color:var(--gray-100); }

/* ═══════════════════════════════════════════════
   WHY US — Big numbered split
═══════════════════════════════════════════════ */
.why-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:3px; margin-top:64px;
  border-radius:var(--r-lg); overflow:hidden;
}
.why-cell {
  background:var(--off-white);
  padding:48px 44px;
  transition:var(--t);
  position:relative; overflow:hidden;
}
.why-cell:hover { background:var(--green-pale); }
.why-cell:hover .why-cell__num { color:rgba(46,125,50,.15); }
.why-cell__num {
  position:absolute; bottom:-20px; right:24px;
  font-size:7rem; font-weight:900;
  color:rgba(0,0,0,.04); line-height:1;
  pointer-events:none; transition:var(--t);
}
.why-cell__icon {
  width:52px; height:52px;
  background:linear-gradient(135deg,var(--green-dark),var(--green-mid));
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.375rem; margin-bottom:20px;
}
.why-cell__title { font-size:1.125rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.why-cell__desc  { font-size:.9375rem; color:var(--gray-600); line-height:1.75; }

/* ═══════════════════════════════════════════════
   ORIGINS SHOWCASE
═══════════════════════════════════════════════ */
.origins-wrapper { margin-top:64px; }
.origins-tabs {
  display:flex; gap:4px; margin-bottom:28px;
  background:var(--gray-100); padding:4px; border-radius:12px;
  width:fit-content;
}
.origins-tab {
  padding:10px 22px; border-radius:10px;
  font-size:.875rem; font-weight:600; color:var(--gray-600);
  cursor:pointer; transition:var(--t); border:none;
  background:none; font-family:var(--font);
}
.origins-tab.active { background:var(--white); color:var(--green-dark); box-shadow:var(--sh-sm); }
.origins-panel { display:none; }
.origins-panel.active { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.origins-panel__visual {
  background:linear-gradient(135deg,var(--dark),var(--dark-2));
  border-radius:var(--r-xl); padding:40px; min-height:320px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden;
  border:1px solid rgba(125,198,40,.15);
}
.origins-panel__flag { font-size:4rem; margin-bottom:20px; }
.origins-panel__name { font-size:1.5rem; font-weight:800; color:var(--white); margin-bottom:8px; }
.origins-panel__route { font-size:.875rem; color:rgba(255,255,255,.5); margin-bottom:28px; }
.origins-panel__tag {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(125,198,40,.15); border:1px solid rgba(125,198,40,.3);
  color:var(--green-light); border-radius:100px;
  padding:6px 14px; font-size:.75rem; font-weight:700;
}
.origins-specs { display:flex; flex-direction:column; gap:14px; }
.origin-spec-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 20px;
  border:1px solid var(--gray-100);
  border-radius:12px; background:var(--white);
  transition:var(--t);
}
.origin-spec-row:hover { border-color:var(--green-light); background:var(--off-white); }
.origin-spec-row__label { font-size:.875rem; color:var(--gray-600); }
.origin-spec-row__val   { font-size:1rem; font-weight:700; color:var(--green-dark); }
.origin-spec-row__bar   { width:60px; height:4px; background:var(--gray-200); border-radius:2px; overflow:hidden; }
.origin-spec-row__fill  { height:100%; background:linear-gradient(90deg,var(--green),var(--green-light)); border-radius:2px; }

/* ═══════════════════════════════════════════════
   CTA BAND
═══════════════════════════════════════════════ */
.cta-band {
  padding:96px 0;
  background:linear-gradient(135deg,var(--dark) 0%,#071404 50%,var(--green-dark) 100%);
  position:relative; overflow:hidden;
}
.cta-band::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 70% at 80% 50%,rgba(255,140,0,.15) 0%,transparent 60%);
}
.cta-band__inner {
  position:relative; z-index:1;
  display:flex; align-items:center; justify-content:space-between; gap:48px;
}
.cta-band__h { font-size:clamp(1.625rem,3vw,2.5rem); font-weight:900; color:var(--white); line-height:1.15; margin-bottom:12px; letter-spacing:-.02em; }
.cta-band__p { color:rgba(255,255,255,.6); font-size:1rem; max-width:440px; line-height:1.75; }
.cta-band__btns { display:flex; gap:14px; flex-shrink:0; flex-wrap:wrap; }

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
.footer { background:#040904; color:rgba(255,255,255,.6); }
.footer__top { padding:80px 0 64px; }
.footer__grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:52px; }
.footer__brand-logo { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer__brand-logo img { height:38px; width:auto; }
.footer__brand-mark { width:36px; height:36px; background:linear-gradient(135deg,var(--green-dark),var(--green-light)); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.8rem; font-weight:900; color:var(--white); }
.footer__brand-name { font-size:.9375rem; font-weight:800; color:var(--white); }
.footer__brand-sub  { font-size:.65rem; font-weight:600; color:var(--flame); letter-spacing:.08em; text-transform:uppercase; }
.footer__tagline { font-size:.875rem; line-height:1.8; max-width:280px; margin-bottom:24px; }
.footer__contact-inline { display:flex; flex-direction:column; gap:8px; }
.footer__contact-inline a { font-size:.875rem; color:rgba(255,255,255,.5); transition:var(--t); display:flex; align-items:center; gap:8px; }
.footer__contact-inline a:hover { color:var(--green-light); }

.footer__col-title { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--white); margin-bottom:20px; }
.footer__links { display:flex; flex-direction:column; gap:10px; }
.footer__links a { font-size:.875rem; color:rgba(255,255,255,.45); transition:var(--t); }
.footer__links a:hover { color:var(--green-light); padding-left:4px; }
.footer__contact-list { display:flex; flex-direction:column; gap:14px; }
.footer__contact-item { display:flex; gap:12px; align-items:flex-start; }
.footer__contact-item a, .footer__contact-item span { font-size:.875rem; color:rgba(255,255,255,.45); line-height:1.6; }
.footer__contact-item a:hover { color:var(--green-light); }
.footer__icon { font-size:.95rem; flex-shrink:0; margin-top:2px; }

.footer__bottom {
  border-top:1px solid rgba(255,255,255,.06);
  padding:24px 0;
}
.footer__bottom-inner { display:flex; justify-content:space-between; align-items:center; font-size:.8rem; color:rgba(255,255,255,.28); }

/* ═══════════════════════════════════════════════
   PAGE HERO (inner pages)
═══════════════════════════════════════════════ */
.page-hero {
  background:linear-gradient(160deg,var(--dark) 0%,var(--dark-2) 50%,var(--green-dark) 100%);
  padding:152px 0 72px;
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 80% 50%,rgba(125,198,40,.15) 0%,transparent 60%),
    linear-gradient(rgba(125,198,40,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(125,198,40,.04) 1px,transparent 1px);
  background-size:100% 100%,64px 64px,64px 64px;
}
.page-hero__crumb {
  position:relative; z-index:1;
  display:flex; align-items:center; gap:8px;
  font-size:.8rem; color:rgba(255,255,255,.4); margin-bottom:16px;
}
.page-hero__crumb a { color:var(--green-light); transition:var(--t); }
.page-hero__crumb a:hover { color:var(--white); }
.page-hero__title {
  position:relative; z-index:1;
  font-size:clamp(2rem,4vw,3rem); font-weight:900;
  color:var(--white); letter-spacing:-.02em; margin-bottom:16px;
}
.page-hero__sub {
  position:relative; z-index:1;
  font-size:1.0625rem; color:rgba(255,255,255,.6);
  max-width:540px; line-height:1.8;
}

/* ═══════════════════════════════════════════════
   ABOUT PAGE
═══════════════════════════════════════════════ */
.about-split { display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:center; }
.about-visual { position:relative; }
.about-visual__main {
  background:linear-gradient(160deg,var(--dark),var(--green-dark));
  border-radius:var(--r-xl); padding:48px 40px;
  border:1px solid rgba(125,198,40,.2);
  box-shadow:var(--sh-xl);
}
.about-visual__icon { font-size:3.5rem; margin-bottom:20px; }
.about-visual__main h3 { font-size:1.5rem; font-weight:800; color:var(--white); margin-bottom:12px; }
.about-visual__main p  { color:rgba(255,255,255,.6); line-height:1.8; }
.about-stat-card {
  position:absolute; border-radius:var(--r-lg); padding:20px 24px; text-align:center;
  box-shadow:var(--sh-lg);
}
.about-stat-card--a { background:var(--flame); bottom:-20px; right:-20px; animation:flt1 6s ease-in-out infinite; }
.about-stat-card--b { background:var(--green); top:-16px;  right:-16px; animation:flt2 7s ease-in-out infinite; }
@keyframes flt1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes flt2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }
.about-stat-card .num { display:block; font-size:1.875rem; font-weight:900; color:var(--white); }
.about-stat-card .lbl { display:block; font-size:.75rem; font-weight:600; color:rgba(255,255,255,.8); margin-top:4px; }
.about-checks { margin-top:28px; display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.check {
  display:flex; align-items:flex-start; gap:10px;
  font-size:.9rem; color:var(--gray-600); line-height:1.5;
}
.check__dot {
  width:20px; height:20px; flex-shrink:0;
  background:var(--green-pale); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--green-dark); font-size:.7rem; font-weight:800;
  margin-top:1px;
}

/* Values */
.values-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:56px; }
.value-card {
  padding:40px 36px;
  border-radius:var(--r-xl);
  background:var(--white);
  border:1px solid var(--gray-100);
  transition:var(--t); position:relative; overflow:hidden;
}
.value-card:hover { border-color:var(--green-light); box-shadow:var(--sh-lg); transform:translateY(-4px); }
.value-card__bg-num {
  position:absolute; bottom:-16px; right:20px;
  font-size:6rem; font-weight:900; color:var(--gray-100);
  line-height:1; pointer-events:none;
}
.value-card__icon { width:52px; height:52px; background:linear-gradient(135deg,var(--green-dark),var(--green-mid)); border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:20px; }
.value-card__title { font-size:1.125rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.value-card__desc  { font-size:.9375rem; color:var(--gray-600); line-height:1.75; }

/* ═══════════════════════════════════════════════
   SERVICES PAGE — Spec blocks
═══════════════════════════════════════════════ */
.spec-block {
  background:var(--white); border:1px solid var(--gray-100);
  border-radius:var(--r-xl); padding:40px; margin-top:32px;
  transition:var(--t);
}
.spec-block:hover { box-shadow:var(--sh-md); border-color:rgba(125,198,40,.3); }
.spec-block__head {
  display:flex; align-items:flex-start; gap:20px; margin-bottom:20px; flex-wrap:wrap;
}
.spec-block__flag { font-size:2.5rem; flex-shrink:0; }
.spec-block__title  { font-size:1.25rem; font-weight:800; color:var(--green-dark); margin-bottom:4px; }
.spec-block__origin { font-size:.875rem; color:var(--gray-400); }
.spec-block__cta    { margin-left:auto; flex-shrink:0; align-self:center; }
.spec-block__desc   { font-size:.9375rem; color:var(--gray-600); line-height:1.8; margin-bottom:24px; }
.spec-table-wrap { overflow-x:auto; border-radius:var(--r); border:1px solid var(--gray-100); margin-bottom:20px; }
.spec-table { width:100%; border-collapse:collapse; font-size:.875rem; }
.spec-table thead { background:var(--dark); color:var(--white); }
.spec-table thead th { padding:14px 16px; text-align:left; font-weight:600; font-size:.8rem; text-transform:uppercase; letter-spacing:.07em; }
.spec-table tbody tr { border-bottom:1px solid var(--gray-100); transition:background .2s; }
.spec-table tbody tr:last-child { border-bottom:none; }
.spec-table tbody tr:hover { background:var(--off-white); }
.spec-table tbody td { padding:12px 16px; color:var(--gray-600); }
.spec-table tbody td:first-child { font-weight:500; color:var(--dark); }
.spec-tags { display:flex; flex-wrap:wrap; gap:8px; }
.spec-tag {
  padding:5px 14px; background:var(--off-white); border:1px solid var(--gray-200);
  border-radius:100px; font-size:.75rem; font-weight:600; color:var(--green-dark); transition:var(--t);
}
.spec-tag:hover { border-color:var(--green-light); background:var(--green-pale); }

/* Services cards */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.svc-card {
  background:var(--white); border:1px solid var(--gray-100);
  border-radius:var(--r-xl); padding:36px 28px;
  transition:var(--t); position:relative; overflow:hidden;
}
.svc-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-light));
  transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.svc-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); border-color:transparent; }
.svc-card:hover::after { transform:scaleX(1); }
.svc-card__icon { width:52px; height:52px; background:linear-gradient(135deg,var(--green-dark),var(--green-mid)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.375rem; margin-bottom:20px; }
.svc-card__title { font-size:1.0625rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.svc-card__desc  { font-size:.9rem; color:var(--gray-600); line-height:1.75; }

/* Industries dark grid (services page) */
.ind-dark-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:56px; }
.ind-dark-item {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg); padding:28px 20px; text-align:center; transition:var(--t);
}
.ind-dark-item:hover { background:rgba(125,198,40,.1); border-color:rgba(125,198,40,.3); transform:translateY(-4px); }
.ind-dark-item__icon { font-size:2rem; margin-bottom:12px; display:block; }
.ind-dark-item h4 { font-size:.9375rem; font-weight:700; color:var(--white); margin-bottom:4px; }
.ind-dark-item p  { font-size:.8rem; color:rgba(255,255,255,.45); }

/* ═══════════════════════════════════════════════
   CONTACT PAGE
═══════════════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:72px; align-items:flex-start; }
.contact-info__title { font-size:1.625rem; font-weight:800; color:var(--green-dark); margin-bottom:8px; }
.contact-info__sub   { font-size:.9375rem; color:var(--gray-600); margin-bottom:36px; line-height:1.7; }
.c-detail {
  display:flex; gap:16px; align-items:flex-start;
  padding:18px 20px; border-radius:var(--r-lg);
  border:1px solid var(--gray-100); margin-bottom:12px; transition:var(--t);
}
.c-detail:hover { border-color:var(--green-light); background:var(--off-white); transform:translateX(4px); }
.c-detail__icon {
  width:44px; height:44px; flex-shrink:0;
  background:linear-gradient(135deg,var(--green-dark),var(--green-mid));
  border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem;
}
.c-detail h4   { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-400); margin-bottom:4px; }
.c-detail a, .c-detail p { font-size:.9375rem; color:var(--green-dark); font-weight:500; line-height:1.6; }
.c-detail a:hover { color:var(--flame); }

/* Form */
.form-card {
  background:var(--white); border:1px solid var(--gray-100);
  border-radius:var(--r-xl); padding:48px 44px; box-shadow:var(--sh-md);
}
.form-card__title { font-size:1.5rem; font-weight:800; color:var(--green-dark); margin-bottom:6px; }
.form-card__sub   { font-size:.9375rem; color:var(--gray-600); margin-bottom:32px; }
.form-row  { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.form-group label { font-size:.8rem; font-weight:700; color:var(--gray-600); text-transform:uppercase; letter-spacing:.07em; }
.form-group input,
.form-group select,
.form-group textarea {
  padding:13px 16px; border:2px solid var(--gray-100);
  border-radius:var(--r); font-size:.9375rem; font-family:var(--font);
  color:var(--dark); background:var(--white);
  transition:var(--t); outline:none; width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--green); box-shadow:0 0 0 4px rgba(46,125,50,.1);
}
.form-group input.valid   { border-color:var(--green-light); }
.form-group input.invalid { border-color:#ef4444; box-shadow:0 0 0 4px rgba(239,68,68,.1); }
.form-group textarea { resize:vertical; min-height:100px; }
.form-note { font-size:.8rem; color:var(--gray-400); margin-top:12px; text-align:center; }
.form-success {
  display:flex; flex-direction:column; align-items:center;
  text-align:center; padding:56px 24px; gap:14px;
}
.form-success__icon {
  width:72px; height:72px; background:var(--green); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--white); font-size:2rem; font-weight:800;
  animation:popIn .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popIn { 0%{transform:scale(0);opacity:0} 100%{transform:scale(1);opacity:1} }
.form-success h3 { font-size:1.375rem; font-weight:800; color:var(--green-dark); }
.form-success p  { color:var(--gray-600); max-width:320px; line-height:1.7; }

/* Map */
.map-block { display:grid; grid-template-columns:1fr 2fr; gap:40px; align-items:center; }
.map-block__info h3 { font-size:1.25rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.map-block__info p  { color:var(--gray-600); line-height:1.8; }

/* FAQ */
.faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:52px; }
.faq-item {
  background:var(--white); border:1px solid var(--gray-100);
  border-radius:var(--r-xl); padding:28px;
  transition:var(--t);
}
.faq-item:hover { border-color:var(--green-light); box-shadow:var(--sh-sm); }
.faq-item__q { font-size:1rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.faq-item__a { font-size:.9375rem; color:var(--gray-600); line-height:1.75; }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width:1100px) {
  .hero__inner { grid-template-columns:1fr; }
  .hero__panel { display:none; }
  .hero__bar-inner { grid-template-columns:repeat(2,1fr); }
  .products-grid { grid-template-columns:1fr 1fr; }
  .prod-card--hero { grid-column:span 2; grid-row:auto; }
  .why-grid { grid-template-columns:1fr; }
  .origins-panel.active { grid-template-columns:1fr; }
  .about-split { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr 1fr; }
  .cta-band__inner { flex-direction:column; text-align:center; }
  .cta-band__btns  { justify-content:center; }
}
@media (max-width:768px) {
  .sec  { padding:72px 0; }
  .nav__links { display:none; position:fixed; top:72px; left:0; right:0; background:var(--white); flex-direction:column; padding:16px 20px; border-bottom:1px solid var(--gray-100); gap:4px; z-index:800; box-shadow:var(--sh-lg); }
  .nav__links.open { display:flex; }
  .nav__link  { padding:13px 16px; border-radius:var(--r); font-size:1rem; }
  .nav__cta   { display:none; }
  .nav__burger { display:flex; }
  .hero__bar-inner { grid-template-columns:repeat(2,1fr); }
  .ind-grid { grid-template-columns:repeat(2,1fr); }
  .products-grid { grid-template-columns:1fr; }
  .prod-card--hero { grid-column:auto; }
  .ind-dark-grid { grid-template-columns:repeat(2,1fr); }
  .values-grid  { grid-template-columns:1fr; }
  .services-grid { grid-template-columns:1fr; }
  .faq-grid     { grid-template-columns:1fr; }
  .form-row     { grid-template-columns:1fr; }
  .map-block    { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr 1fr; }
  .form-card    { padding:32px 24px; }
}
@media (max-width:480px) {
  .hero__actions { flex-direction:column; }
  .hero__actions .btn { width:100%; justify-content:center; }
  .ind-grid { grid-template-columns:1fr; }
  .hero__bar-inner { grid-template-columns:repeat(2,1fr); }
  .footer__grid { grid-template-columns:1fr; }
  .footer__bottom-inner { flex-direction:column; gap:6px; text-align:center; }
  .clients-strip { flex-direction:column; align-items:flex-start; }
}

/* ═══════════════════════════════════════════════
   COMPATIBILITY ALIASES — inner page class names
═══════════════════════════════════════════════ */
.container { max-width:var(--max); margin:0 auto; padding:0 28px; }
.section   { padding:104px 0; }
.section.section--gray, .section--gray { background:var(--off-white); }
.section.section--dark, .section--dark { background:var(--dark); color:var(--white); }

/* About page visual cards */
.about-visual__card { position:absolute; border-radius:var(--r-lg); padding:28px; transition:var(--t); }
.about-visual__card--main {
  inset:0;
  background:linear-gradient(160deg,var(--dark),var(--green-dark));
  color:var(--white);
  display:flex; flex-direction:column; justify-content:center;
  border:1px solid rgba(125,198,40,.25);
  box-shadow:var(--sh-xl);
  position:absolute;
}
.about-visual__card--main:hover { transform:scale(1.02); }
.about-visual__card--main h3 { font-size:1.375rem; font-weight:800; color:var(--white); margin-bottom:10px; }
.about-visual__card--main p  { color:rgba(255,255,255,.6); font-size:.9rem; line-height:1.7; }
.about-visual__card--stat  { bottom:-16px; right:-16px; background:var(--flame); color:var(--white); text-align:center; box-shadow:var(--sh-lg); animation:flt1 6s ease-in-out infinite; }
.about-visual__card--stat2 { top:-16px; right:-16px; background:var(--green); color:var(--white); text-align:center; box-shadow:var(--sh-lg); animation:flt2 7s ease-in-out infinite; }
.about-stat-num { display:block; font-size:2rem; font-weight:800; line-height:1; }
.about-stat-label { display:block; font-size:.75rem; font-weight:600; margin-top:4px; opacity:.85; }
.about-content  { }

/* About highlights */
.about-highlights { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:32px; }
.about-highlight  { display:flex; align-items:flex-start; gap:10px; font-size:.9rem; color:var(--gray-600); line-height:1.5; }
.about-highlight__icon { color:var(--green); font-weight:700; font-size:1rem; flex-shrink:0; margin-top:1px; }

/* Team card */
.team-grid { display:flex; justify-content:center; margin-top:56px; }
.team-card  { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--r-xl); padding:40px; max-width:480px; text-align:center; transition:var(--t); }
.team-card:hover { box-shadow:var(--sh-lg); transform:translateY(-4px); }
.team-card__avatar { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,var(--green-dark),var(--green-light)); color:var(--white); font-weight:800; font-size:1.25rem; display:flex; align-items:center; justify-content:center; margin:0 auto 20px; }
.team-card__name  { font-size:1.125rem; font-weight:700; color:var(--green-dark); margin-bottom:4px; }
.team-card__role  { font-size:.875rem; font-weight:700; color:var(--flame); text-transform:uppercase; letter-spacing:.08em; margin-bottom:16px; }
.team-card__bio   { font-size:.9375rem; color:var(--gray-600); line-height:1.75; margin-bottom:20px; }
.team-card__contact { display:flex; flex-direction:column; gap:8px; }
.team-card__contact a { font-size:.875rem; color:var(--green-dark); transition:var(--t); }
.team-card__contact a:hover { color:var(--flame); }

/* Services page spec blocks */
.spec-block__header { display:flex; align-items:flex-start; gap:20px; margin-bottom:20px; flex-wrap:wrap; }
.spec-block__flag   { font-size:2.5rem; flex-shrink:0; }
.spec-block__cta    { margin-left:auto; flex-shrink:0; align-self:center; }

/* Service cards alias */
.service-card { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--r-xl); padding:36px 28px; transition:var(--t); position:relative; overflow:hidden; }
.service-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--green),var(--green-light)); transform:scaleX(0); transform-origin:left; transition:transform .35s ease; }
.service-card:hover  { transform:translateY(-6px); box-shadow:var(--sh-lg); border-color:transparent; }
.service-card:hover::after { transform:scaleX(1); }
.service-card__icon  { width:52px; height:52px; background:linear-gradient(135deg,var(--green-dark),var(--green-mid)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.375rem; margin-bottom:20px; }
.service-card__title { font-size:1.0625rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.service-card__desc  { font-size:.9rem; color:var(--gray-600); line-height:1.75; }

/* Industries grid alias */
.industries-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:56px; }
.industry-item   { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:var(--r-lg); padding:28px 20px; text-align:center; transition:var(--t); }
.industry-item:hover { background:rgba(125,198,40,.1); border-color:rgba(125,198,40,.3); transform:translateY(-4px); }
.industry-item__icon { font-size:2rem; margin-bottom:12px; display:block; }
.industry-item h4 { font-size:.9375rem; font-weight:700; color:var(--white); margin-bottom:4px; }
.industry-item p  { font-size:.8rem; color:rgba(255,255,255,.45); }
.named-clients--dark { background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.1); }
.named-client--dark  { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.15); color:rgba(255,255,255,.85); }

/* Contact page aliases */
.contact-form-wrap  { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--r-xl); padding:48px 44px; box-shadow:var(--sh-md); }
.contact-form__title { font-size:1.5rem; font-weight:800; color:var(--green-dark); margin-bottom:6px; }
.contact-form__sub   { font-size:.9375rem; color:var(--gray-600); margin-bottom:32px; }
.contact-detail  { display:flex; gap:16px; align-items:flex-start; padding:18px 20px; border-radius:var(--r-lg); border:1px solid var(--gray-100); margin-bottom:12px; transition:var(--t); }
.contact-detail:hover { border-color:var(--green-light); background:var(--off-white); transform:translateX(4px); }
.contact-detail__icon { width:44px; height:44px; flex-shrink:0; background:linear-gradient(135deg,var(--green-dark),var(--green-mid)); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.contact-detail h4 { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-400); margin-bottom:4px; }
.contact-detail a, .contact-detail p { font-size:.9375rem; color:var(--green-dark); font-weight:500; line-height:1.6; }
.contact-detail a:hover { color:var(--flame); }

/* Map strip alias */
.map-strip { display:grid; grid-template-columns:1fr 2fr; gap:40px; align-items:center; }
.map-strip__info h3 { font-size:1.25rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.map-strip__info p  { color:var(--gray-600); line-height:1.75; }
.map-strip__embed   { }

/* FAQ alias */
.faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:52px; }
.faq-item { background:var(--white); border:1px solid var(--gray-100); border-radius:var(--r-xl); padding:28px; transition:var(--t); }
.faq-item:hover { border-color:var(--green-light); box-shadow:var(--sh-sm); }
.faq-item__q { font-size:1rem; font-weight:700; color:var(--green-dark); margin-bottom:10px; }
.faq-item__a { font-size:.9375rem; color:var(--gray-600); line-height:1.75; }

/* Old-style CTA banner */
.cta-banner { background:linear-gradient(135deg,var(--dark) 0%,#071404 50%,var(--green-dark) 100%); position:relative; overflow:hidden; padding:80px 0; }
.cta-banner::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 70% at 80% 50%,rgba(255,140,0,.15) 0%,transparent 60%); }
.cta-banner__inner  { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.cta-banner__text   { }
.cta-banner__title  { font-size:clamp(1.5rem,2.5vw,2rem); font-weight:900; color:var(--white); margin-bottom:10px; }
.cta-banner__sub    { color:rgba(255,255,255,.65); font-size:1rem; max-width:440px; line-height:1.75; }
.cta-banner__actions { display:flex; gap:14px; flex-shrink:0; flex-wrap:wrap; }

/* Old btn class aliases */
.btn--primary { background:var(--flame); color:var(--white); border-color:var(--flame); }
.btn--primary:hover { background:var(--flame-hot); transform:translateY(-2px); }
.btn--green   { background:var(--green); color:var(--white); border-color:var(--green); }
.btn--white   { background:var(--white); color:var(--green-dark); border-color:var(--white); }
.btn--white:hover { background:var(--off-white); transform:translateY(-2px); }
.btn--outline-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,.45); }
.btn--outline-white:hover { background:rgba(255,255,255,.12); border-color:var(--white); }
.btn--outline { background:transparent; color:var(--green-dark); border-color:var(--gray-200); }
.btn--outline:hover { border-color:var(--green-light); color:var(--green); transform:translateY(-1px); }
.btn--lg { padding:17px 38px; font-size:1.0625rem; }
.btn--sm { padding:10px 20px; font-size:.875rem; }

/* Reveal aliases (old class names) */
.reveal       { opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity:1; transform:none; }
.reveal-left  { opacity:0; transform:translateX(-36px); transition:opacity .7s ease,transform .7s ease; }
.reveal-right { opacity:0; transform:translateX(36px); transition:opacity .7s ease,transform .7s ease; }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }

/* section-sub text */
.section-sub { font-size:1.0625rem; color:var(--gray-600); max-width:580px; line-height:1.75; }
.section--dark .section-sub { color:rgba(255,255,255,.65); }

/* value-card__num alias */
.value-card__num { font-size:3rem; font-weight:900; color:var(--gray-100); line-height:1; margin-bottom:16px; }

/* named-clients */
.named-clients { margin-top:52px; background:var(--off-white); border:1px solid var(--gray-100); border-radius:var(--r-lg); padding:28px 36px; text-align:center; }
.named-clients__label { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--gray-400); margin-bottom:14px; }
.named-clients__logos { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; }
.named-client { display:inline-block; padding:6px 18px; background:var(--white); border:1px solid var(--gray-200); border-radius:100px; font-size:.8125rem; font-weight:600; color:var(--green-dark); transition:var(--t); }
.named-client:hover { border-color:var(--green-light); background:var(--green-pale); }

/* Page hero uses .wrap inside */
.page-hero .container { max-width:var(--max); margin:0 auto; padding:0 28px; }

/* Scroll reveal — handled in script.js */

@media (max-width:768px) {
  .industries-grid { grid-template-columns:repeat(2,1fr); }
  .about-highlights { grid-template-columns:1fr; }
  .map-strip { grid-template-columns:1fr; }
  .faq-grid  { grid-template-columns:1fr; }
  .contact-form-wrap { padding:28px 20px; }
}

/* ── Final fixes ─────────────────────────────── */
:root { --gray-700: #374151; }

/* about-visual needs height for absolute children */
.about-visual {
  position:relative;
  height:380px;
  min-height:280px;
}
.about-visual__icon { font-size:3rem; margin-bottom:16px; }

/* centered sec-head */
.sec-head--center, .sec-head--centered {
  text-align:center;
}
.sec-head--center .lead,
.sec-head--centered .lead { margin:0 auto; }
.sec-head--center .divider,
.sec-head--centered .divider { margin-left:auto; margin-right:auto; }

/* About split layout */
.about-split {
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:80px;
  align-items:center;
}

/* section headings h2 color fix */
.section h2, .sec h2 { color:var(--green-dark); }
.section--dark h2, .sec--dark h2 { color:var(--white); }

/* Ensure page-hero uses wrap */
.page-hero .container,
.page-hero .wrap { max-width:var(--max); margin:0 auto; padding:0 28px; }

@media (max-width:1100px) {
  .about-split { grid-template-columns:1fr; }
  .about-visual { height:280px; }
}
@media (max-width:768px) {
  .about-visual { height:240px; }
  .about-highlights { grid-template-columns:1fr; }
  .cta-banner__inner { flex-direction:column; text-align:center; }
  .cta-banner__actions { justify-content:center; }
}
