/* =====================================================================
   PPM General Trading LLC — Corporate Website
   Design system & components.  Pure CSS, no frameworks.
   Palette: deep green · ink black · warm white · brass accent
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --green-950:#04201A;
  --green-900:#06291E;
  --green-800:#0B3D2E;
  --green-700:#114F3B;
  --green-600:#19684C;
  --green-500:#21845E;
  --green-400:#3FA47B;
  --green-300:#7FC9A8;
  --green-tint:#EAF3EE;

  --gold-600:#B68A35;
  --gold-500:#C9A24B;
  --gold-400:#DDBE74;
  --gold-300:#ECD7A1;
  --gold-text:#7D5E1A;   /* small brass text on light — clears AA 4.5:1 */
  --gold-strong:#9A7522; /* large brass text on light — clears 3:1 */

  --ink:#0B0B0C;
  --charcoal:#191C1A;
  --paper:#FBFBF9;
  --paper-2:#F4F4EF;
  --paper-3:#ECEDE6;
  --line:#E4E5DD;
  --line-dark:rgba(255,255,255,.12);
  --muted:#586059;
  --muted-light:#9DA8A0;

  --maxw:1180px;
  --gutter:clamp(20px,5vw,40px);
  --section-y:clamp(72px,9vw,130px);
  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;

  --shadow-sm:0 1px 2px rgba(8,30,22,.05),0 4px 14px rgba(8,30,22,.05);
  --shadow-md:0 10px 30px -12px rgba(8,30,22,.18),0 6px 14px -8px rgba(8,30,22,.10);
  --shadow-lg:0 30px 70px -28px rgba(6,32,24,.42);

  --ff-display:'Sora','Segoe UI',Arial,sans-serif;
  --ff-body:'Inter','Segoe UI',Arial,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--green-500);color:#fff}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.4vw,4.3rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem);letter-spacing:-.01em}
h4{font-size:1.05rem;letter-spacing:-.01em}
p{color:var(--muted)}
strong{color:var(--ink);font-weight:600}

.display{font-family:var(--ff-display)}
.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);line-height:1.6;color:var(--muted)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(56px,7vw,90px)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-display);
  font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--green-600);
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--gold-500);display:inline-block}
.eyebrow--center{justify-content:center}
.on-dark .eyebrow,.eyebrow--light{color:var(--gold-400)}

.section-head{max-width:680px}
.section-head--center{margin-inline:auto;text-align:center}
.section-head h2{margin:.5em 0 .55em}
.section-head .lead{margin-top:.2em}

.grid{display:grid;gap:clamp(16px,2vw,26px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green-800);--fg:#fff;--bd:var(--green-800);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.92em 1.5em;border-radius:999px;
  font-family:var(--ff-display);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .25s,color .25s,border-color .25s;
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(11,61,46,.5)}
.btn:hover svg{transform:translateX(3px)}
.btn--gold{--bg:var(--gold-500);--bd:var(--gold-500);--fg:var(--ink)}
.btn--gold:hover{--bg:var(--gold-400);--bd:var(--gold-400);box-shadow:0 14px 28px -12px rgba(201,162,75,.55)}
.btn--ghost{--bg:transparent;--fg:var(--ink);--bd:var(--line)}
.btn--ghost:hover{--bd:var(--green-700);--fg:var(--green-800);box-shadow:none}
.btn--outline-light{--bg:transparent;--fg:#fff;--bd:rgba(255,255,255,.35)}
.btn--outline-light:hover{--bd:#fff;--bg:rgba(255,255,255,.08);box-shadow:none}
.btn--sm{padding:.7em 1.2em;font-size:.86rem}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

.textlink{display:inline-flex;align-items:center;gap:.5em;font-family:var(--ff-display);font-weight:600;font-size:.95rem;color:var(--green-700)}
.textlink svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.textlink:hover svg{transform:translateX(4px)}
.on-dark .textlink{color:var(--gold-400)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px}
.site-header.scrolled{
  background:rgba(251,251,249,.82);backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(6,32,24,.4);
}

/* logo (supplied brandmark image — recoloured via filter per context) */
.brand{display:inline-flex;align-items:center;gap:11px;flex-shrink:0}
.brand__logo{height:50px;width:auto;display:block;filter:brightness(0) invert(1);transition:filter .4s var(--ease)}
.site-header.scrolled .brand__logo{filter:brightness(0) invert(0)}
.footer .brand__logo{height:60px}

/* ---------- Accessibility: skip link + focus ---------- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:300;background:var(--green-900);color:#fff;
  padding:.7em 1.2em;border-radius:0 0 10px 0;font-family:var(--ff-display);font-weight:600;font-size:.9rem}
.skip-link:focus{left:0}
main:focus{outline:none}
:where(a,button,[tabindex]):focus-visible{outline:3px solid var(--gold-400);outline-offset:2px;border-radius:6px}

/* nav */
.nav{display:flex;align-items:center;gap:6px}
.nav a:not(.nav__cta){
  position:relative;padding:.55em .85em;border-radius:8px;
  font-family:var(--ff-display);font-weight:500;font-size:.93rem;
  color:rgba(255,255,255,.82);transition:color .25s;
}
.nav a:not(.nav__cta)::after{content:"";position:absolute;left:.85em;right:.85em;bottom:.32em;height:1.5px;background:var(--gold-400);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav a:not(.nav__cta):hover,.nav a:not(.nav__cta).active,.nav a:not(.nav__cta):focus-visible{color:#fff}
.nav a:not(.nav__cta):hover::after,.nav a:not(.nav__cta).active::after,.nav a:not(.nav__cta):focus-visible::after{transform:scaleX(1)}
.scrolled .nav a:not(.nav__cta){color:var(--muted)}
.scrolled .nav a:not(.nav__cta):hover,.scrolled .nav a:not(.nav__cta).active,.scrolled .nav a:not(.nav__cta):focus-visible{color:var(--green-800)}
.scrolled .nav a:not(.nav__cta)::after{background:var(--green-600)}

.header-actions{display:flex;align-items:center;gap:14px}
.nav__cta{display:none}

/* hamburger */
.nav-toggle{display:none;width:46px;height:46px;border-radius:10px;align-items:center;justify-content:center;color:#fff}
.scrolled .nav-toggle{color:var(--ink)}
.nav-toggle span{position:relative;width:22px;height:2px;background:currentColor;border-radius:2px;transition:.3s var(--ease)}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:currentColor;border-radius:2px;transition:.3s var(--ease)}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
body.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--green-900);color:#fff;overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 78% 8%,rgba(33,132,94,.55),transparent 55%),
    radial-gradient(90% 80% at 5% 100%,rgba(17,79,59,.65),transparent 60%),
    linear-gradient(160deg,#073226 0%,#06291E 45%,#04201A 100%);
}
.hero__grid{position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(120% 120% at 70% 0%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(120% 120% at 70% 0%,#000 30%,transparent 80%);}
.hero__glow{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(60px);z-index:-1;
  background:radial-gradient(circle,rgba(201,162,75,.22),transparent 70%);top:-120px;right:-80px}

.hero__inner{position:relative;padding-top:clamp(130px,17vw,180px);padding-bottom:clamp(70px,10vw,120px)}
.hero h1{color:#fff;max-width:14ch}
.hero h1 em{font-style:normal;color:var(--gold-400)}
.hero__lead{margin:1.4rem 0 2.2rem;max-width:54ch;color:rgba(255,255,255,.78);font-size:clamp(1.05rem,1.5vw,1.24rem)}
.hero .btn-row{margin-bottom:clamp(40px,6vw,64px)}

.hero__pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.pill{display:inline-flex;align-items:center;gap:.5em;padding:.5em 1em;border-radius:999px;
  font-size:.82rem;font-weight:500;color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(6px)}
.pill svg{width:15px;height:15px;color:var(--gold-400)}

/* hero stat strip */
.hero__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  border-top:1px solid rgba(255,255,255,.14);padding-top:32px}
.hero__stats .stat__num{color:#fff}
.hero__stats .stat__label{color:rgba(255,255,255,.6)}

.tagline-strip{font-family:var(--ff-display);font-weight:500;letter-spacing:.04em;
  color:rgba(255,255,255,.55);font-size:.82rem;text-transform:uppercase;
  display:flex;gap:1.2em;flex-wrap:wrap;align-items:center;margin-bottom:1.6rem}
.tagline-strip span{display:inline-flex;align-items:center;gap:1.2em}
.tagline-strip span::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold-500)}
.tagline-strip span:last-child::after{display:none}

/* ---------- Stats ---------- */
.stat__num{font-family:var(--ff-display);font-weight:700;font-size:clamp(2rem,3.4vw,2.9rem);line-height:1;letter-spacing:-.03em;color:var(--green-800)}
.stat__num .suffix{color:var(--gold-strong)}
.on-dark .suffix,.hero .suffix,.partner-feature .suffix{color:var(--gold-400)}
.stat__label{font-size:.84rem;font-weight:500;color:var(--muted);margin-top:.55em;line-height:1.35}

.stats-band{background:var(--green-tint);border-block:1px solid var(--line)}
.stats-band .grid{align-items:start}

/* ---------- Section bg variants ---------- */
.bg-paper-2{background:var(--paper-2)}
.bg-tint{background:var(--green-tint)}
.on-dark,.bg-dark{background:var(--green-900);color:#fff;position:relative;isolation:isolate}
.on-dark h1,.on-dark h2,.on-dark h3,.on-dark h4{color:#fff}
.on-dark p{color:rgba(255,255,255,.72)}
.on-dark .section-head .lead{color:rgba(255,255,255,.74)}

/* ---------- Cards ---------- */
.card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s;
  overflow:hidden;height:100%;
}
.card::after{content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--green-600),var(--gold-500));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.card:hover::after{transform:scaleX(1)}
.card h3{margin-bottom:.5em}
.card p{font-size:.95rem}

.card__icon{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:22px;
  background:var(--green-tint);color:var(--green-700);transition:background .45s var(--ease),color .45s var(--ease);
}
.card__icon svg{width:26px;height:26px;stroke-width:1.6}
.card:hover .card__icon{background:var(--green-800);color:var(--gold-400)}

.card__index{position:absolute;top:24px;right:26px;font-family:var(--ff-display);font-weight:700;
  font-size:1rem;color:var(--paper-3);letter-spacing:.02em;transition:color .45s}
.card:hover .card__index{color:var(--gold-500)}

.card--list ul{margin-top:14px;display:flex;flex-direction:column;gap:9px}
.card--list li{position:relative;padding-left:22px;font-size:.92rem;color:var(--muted);line-height:1.45}
.card--list li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:2px;
  background:var(--green-500);transform:rotate(45deg)}

/* dark card */
.on-dark .card{background:rgba(255,255,255,.035);border-color:rgba(255,255,255,.1)}
.on-dark .card:hover{background:rgba(255,255,255,.06)}
.on-dark .card__icon{background:rgba(255,255,255,.08);color:var(--gold-400)}
.on-dark .card:hover .card__icon{background:var(--gold-500);color:var(--green-900)}
.on-dark .card--list li{color:rgba(255,255,255,.72)}
.on-dark .card__index{color:rgba(255,255,255,.14)}

/* ---------- Feature / split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}
.media-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:42px 38px;color:#fff;
  background:linear-gradient(155deg,#0B3D2E,#06291E);box-shadow:var(--shadow-lg);min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;isolation:isolate}
.media-card__deco{position:absolute;inset:0;z-index:-1;opacity:.9}
.media-card h3{color:#fff}
.media-card p{color:rgba(255,255,255,.78)}

.checklist{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.checklist li{display:flex;gap:13px;align-items:flex-start;font-size:.98rem;color:var(--muted)}
.checklist li strong{display:block;color:var(--ink);font-weight:600;margin-bottom:1px}
.check-ic{flex-shrink:0;width:26px;height:26px;border-radius:8px;background:var(--green-tint);color:var(--green-700);display:grid;place-items:center;margin-top:1px}
.check-ic svg{width:15px;height:15px;stroke-width:2.2}
.on-dark .checklist li{color:rgba(255,255,255,.78)}
.on-dark .check-ic{background:rgba(201,162,75,.18);color:var(--gold-400)}

/* ---------- Ecosystem pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.pillar{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;text-align:center;transition:transform .45s var(--ease),box-shadow .45s}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.pillar__step{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--green-700),var(--green-900));color:var(--gold-400);box-shadow:0 12px 26px -12px rgba(11,61,46,.6)}
.pillar__step svg{width:30px;height:30px;stroke-width:1.6}
.pillar h3{margin-bottom:.45em}
.pillar p{font-size:.95rem}
.pillars__line{position:absolute;top:62px;left:16%;right:16%;height:2px;z-index:0;
  background:repeating-linear-gradient(90deg,var(--green-300) 0 8px,transparent 8px 16px)}

/* ---------- Values ---------- */
.value{padding:30px 26px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);transition:.45s var(--ease)}
.value:hover{border-color:var(--green-600);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.value__num{font-family:var(--ff-display);font-weight:700;color:var(--gold-text);font-size:.85rem;letter-spacing:.1em}
.value h3{margin:.5em 0 .4em}
.value p{font-size:.92rem}

/* ---------- Global reach ---------- */
.reach{position:relative;overflow:hidden}
.worldmap{width:100%;height:auto;opacity:.9}
.reach-stats{display:flex;gap:clamp(24px,5vw,64px);flex-wrap:wrap;margin-top:30px}
.reach-stats .stat__num{color:#fff}
.reach-stats .stat__label{color:rgba(255,255,255,.62)}

.corridor-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.chip{display:inline-flex;align-items:center;gap:.5em;padding:.5em 1em;border-radius:999px;font-size:.86rem;font-weight:500;
  background:#fff;border:1px solid var(--line);color:var(--ink);transition:.3s}
.chip:hover{border-color:var(--green-600);color:var(--green-800)}
.chip svg{width:14px;height:14px;color:var(--green-600)}
.on-dark .chip{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:rgba(255,255,255,.9)}
.on-dark .chip svg{color:var(--gold-400)}

/* ---------- Partner / Road Master feature ---------- */
.partner-feature{position:relative;border-radius:var(--radius-lg);overflow:hidden;color:#fff;isolation:isolate;
  background:linear-gradient(150deg,#0c0f1a 0%,#11182b 55%,#0a1f33 100%);box-shadow:var(--shadow-lg)}
.partner-feature__bg{position:absolute;inset:0;z-index:-1;opacity:.5}
.partner-feature__body{padding:clamp(34px,5vw,60px)}
.partner-badge{display:inline-flex;align-items:center;gap:.6em;padding:.45em 1em;border-radius:999px;
  background:rgba(201,162,75,.16);border:1px solid rgba(201,162,75,.4);color:var(--gold-300);
  font-family:var(--ff-display);font-weight:600;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}
.partner-feature h2,.partner-feature h3{color:#fff}
.partner-feature p{color:rgba(255,255,255,.74)}
.partner-feature .stat__num{color:#fff}
.partner-feature .stat__label{color:rgba(255,255,255,.6)}
.rm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px;
  border-top:1px solid rgba(255,255,255,.14);padding-top:30px}

.logo-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.logo-tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.4s var(--ease)}
.logo-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.logo-tile__role{font-family:var(--ff-display);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-text)}
.logo-tile h3{font-size:1.2rem;margin:.4em 0 .35em}
.logo-tile p{font-size:.9rem}

/* ---------- Product groups ---------- */
.prod-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.4s var(--ease)}
.prod-group:hover{box-shadow:var(--shadow-md)}
.prod-group__head{display:flex;align-items:center;gap:14px;padding:22px 26px;border-bottom:1px solid var(--line);
  background:linear-gradient(120deg,var(--green-tint),transparent)}
.prod-group__head .card__icon{margin:0;width:46px;height:46px;border-radius:11px}
.prod-group__head .card__icon svg{width:22px;height:22px}
.prod-group__head h3{font-size:1.18rem}
.prod-group__body{padding:22px 26px;display:flex;flex-wrap:wrap;gap:8px}
.tag{display:inline-block;padding:.42em .85em;border-radius:8px;font-size:.84rem;font-weight:500;
  background:var(--paper-2);border:1px solid var(--line);color:var(--charcoal);transition:.25s}
.tag:hover{background:var(--green-800);color:#fff;border-color:var(--green-800)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:linear-gradient(150deg,#0B3D2E,#06291E);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(40px,6vw,72px);overflow:hidden;isolation:isolate;text-align:center}
.cta-band__deco{position:absolute;inset:0;z-index:-1;opacity:.6}
.cta-band h2{color:#fff;max-width:18ch;margin-inline:auto}
.cta-band p{color:rgba(255,255,255,.78);max-width:52ch;margin:1rem auto 2rem}
.cta-band .btn-row{justify-content:center}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,4vw,56px);align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(26px,3.5vw,42px);box-shadow:var(--shadow-md)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--ff-display);font-weight:500;font-size:.82rem;color:var(--charcoal);margin-bottom:7px;letter-spacing:.01em}
.field .req{color:var(--gold-text)}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);
  transition:border-color .25s,box-shadow .25s,background .25s;font-size:max(16px,.96rem);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-600);background:#fff;box-shadow:0 0 0 4px rgba(33,132,94,.12)}
.field input.invalid,.field select.invalid,.field textarea.invalid{border-color:#C0392B;background:#fff}
.field input.invalid:focus,.field select.invalid:focus,.field textarea.invalid:focus{box-shadow:0 0 0 4px rgba(192,57,43,.14)}
.field-error{display:block;color:#C0392B;font-size:.78rem;font-weight:500;margin-top:6px}
.field textarea{resize:vertical;min-height:128px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:6px}
.form-status{margin-top:14px;font-size:.92rem;font-weight:500;display:none;line-height:1.5}
.form-status.show{display:block}
.form-status.ok{color:var(--green-600)}
.form-status.err{color:#C0392B}

.contact-info{display:flex;flex-direction:column;gap:14px}
.info-card{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;transition:.4s var(--ease)}
.info-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:transparent}
.info-card__ic{flex-shrink:0;width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  background:var(--green-tint);color:var(--green-700)}
.info-card__ic svg{width:23px;height:23px;stroke-width:1.7}
.info-card h4{margin-bottom:3px}
.info-card a,.info-card p{color:var(--muted);font-size:.95rem}
.info-card a:hover{color:var(--green-700)}

.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);line-height:0}
.map-embed iframe{width:100%;height:300px;border:0;filter:grayscale(.25) contrast(1.02)}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;background:var(--green-900);color:#fff;overflow:hidden;isolation:isolate}
.page-hero__bg{position:absolute;inset:0;z-index:-1}
.page-hero__bg::before{content:"";position:absolute;inset:0;
  background:radial-gradient(100% 120% at 85% 0%,rgba(33,132,94,.45),transparent 55%),linear-gradient(160deg,#073226,#06291E 60%,#04201A);}
.page-hero__bg::after{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:60px 60px;mask-image:radial-gradient(110% 110% at 80% 0%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(110% 110% at 80% 0%,#000,transparent 75%)}
.page-hero__inner{padding-top:clamp(120px,15vw,160px);padding-bottom:clamp(48px,7vw,84px)}
.page-hero h1{color:#fff;max-width:16ch}
.page-hero .lead{color:rgba(255,255,255,.78);margin-top:1.1rem;max-width:58ch}
.breadcrumb{display:flex;gap:.5em;align-items:center;font-size:.84rem;color:rgba(255,255,255,.55);margin-bottom:1.3rem;font-family:var(--ff-display)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:var(--gold-400)}

/* ---------- Footer ---------- */
.footer{background:var(--green-950);color:rgba(255,255,255,.7);position:relative;overflow:hidden}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-block:clamp(54px,7vw,80px)}
.footer__about{margin:20px 0;font-size:.94rem;color:rgba(255,255,255,.6);max-width:34ch;line-height:1.6}
.footer h3{color:#fff;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer ul li{margin-bottom:11px}
.footer ul a{font-size:.94rem;color:rgba(255,255,255,.62);transition:.25s;display:inline-flex;align-items:center;gap:.5em}
.footer ul a:hover{color:var(--gold-400);transform:translateX(2px)}
.footer__contact li{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;font-size:.94rem;color:rgba(255,255,255,.66)}
.footer__contact svg{width:17px;height:17px;color:var(--gold-400);flex-shrink:0;margin-top:3px}
.footer__contact a:hover{color:#fff}
.footer__bottom{border-top:1px solid var(--line-dark);padding-block:24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.86rem;color:rgba(255,255,255,.5)}
.footer__bottom a{color:rgba(255,255,255,.6)}.footer__bottom a:hover{color:#fff}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.7);transition:.3s}
.socials a:hover{background:var(--gold-500);color:var(--green-950);border-color:var(--gold-500);transform:translateY(-3px)}
.socials svg{width:17px;height:17px}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;background:#25D366;color:#fff;box-shadow:0 14px 30px -8px rgba(37,211,102,.5);
  transition:transform .3s var(--ease),box-shadow .3s}
.wa-float:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 18px 36px -8px rgba(37,211,102,.6)}
.wa-float svg{width:30px;height:30px}
.wa-float::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,.4);animation:waPulse 2.4s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.5);opacity:0}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .wa-float::after{animation:none}
}

/* ---------- Utilities ---------- */
.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.6rem}.mt-4{margin-top:2.4rem}
.mb-0{margin-bottom:0}
.divider{height:1px;background:var(--line);border:0;margin:0}
.max-60{max-width:60ch}

/* ---------- Responsive ---------- */
.tag,.chip{max-width:100%}
@media (max-width:1024px){
  .footer__top{grid-template-columns:1fr 1fr}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .nav-toggle{display:flex}
  .nav{position:fixed;inset:76px 0 auto 0;flex-direction:column;align-items:stretch;gap:2px;
    background:rgba(251,251,249,.97);backdrop-filter:blur(18px);padding:14px var(--gutter) 26px;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);
    max-height:calc(100dvh - 76px);overflow-y:auto;overscroll-behavior:contain;
    transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .3s var(--ease),opacity .3s var(--ease),visibility .3s}
  body.nav-open .nav{transform:none;opacity:1;visibility:visible;pointer-events:auto}
  .nav a:not(.nav__cta){color:var(--ink);padding:.85em .4em;border-radius:8px;font-size:1rem;border-bottom:1px solid var(--line)}
  .nav a:not(.nav__cta)::after{display:none}
  .nav a:not(.nav__cta).active{color:var(--green-800)}
  .nav__cta{display:inline-flex;width:100%;margin-top:14px}
  .header-actions .btn{display:none}
  .split{grid-template-columns:1fr;gap:36px}
  .split--reverse .split__media{order:0}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .g-2,.g-3,.g-4,.pillars,.logo-row{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:1fr 1fr;gap:24px 8px}
  .pillars__line{display:none}
  .field-row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr;gap:30px}
  .reach-stats{gap:28px}
}
@media (max-width:560px){
  .footer__top{grid-template-columns:1fr}
  .tagline-strip{font-size:.72rem}
  .rm-grid{grid-template-columns:1fr}
  .socials a{width:44px;height:44px}
  .footer ul a,.footer__contact a{padding-block:6px}
  .tag,.chip{padding-block:.55em}
}
