/* ================================================================
   ePower Network — Complete Design System
   Modern rebuild: dark, electric, professional.
   ================================================================ */

/* --- Google Fonts are loaded in HTML head --- */

/* ---- Design Tokens ---- */
:root {
  --bg:          #1B2D3C;
  --bg-alt:      #EEF4EF;
  --bg-card:     #243748;
  --bg-card-h:   #2C4258;
  --border:      #2C4255;
  --border-h:    #52A87A;

  --blue:        #52A87A;
  --blue-bright: #74C48E;
  --blue-dim:    #367A56;
  --blue-glow:   rgba(82,168,122,0.18);
  --blue-glow2:  rgba(82,168,122,0.35);
  --indigo:      #6A8FA8;

  --text:        #C5DAD0;
  --text-2:      #7A9C8C;
  --text-3:      #3C5E50;
  --white:       #FFFFFF;

  --grad-hero:   linear-gradient(135deg,#1B2D3C 0%,#1E3244 60%,#182A38 100%);
  --grad-accent: linear-gradient(135deg,#367A56 0%,#74C48E 100%);
  --grad-card:   linear-gradient(145deg,#243748 0%,#283E54 100%);

  --shadow-sm:   0 2px 8px rgba(0,0,0,.20);
  --shadow-md:   0 8px 32px rgba(0,0,0,.28);
  --shadow-lg:   0 20px 60px rgba(0,0,0,.32);
  --shadow-glow: 0 0 40px var(--blue-glow);
  --shadow-glow2:0 0 70px var(--blue-glow2);

  --ff-head: 'Poppins', system-ui, sans-serif;
  --ff-body: 'Inter',   system-ui, sans-serif;

  --r-xs: 4px;  --r-sm: 8px;  --r-md: 14px;
  --r-lg: 22px; --r-xl: 36px; --r-full: 9999px;

  --nav-h: 80px;
  --ease:  cubic-bezier(.4,0,.2,1);
  --t:     .3s var(--ease);
  --ts:    .6s var(--ease);

  --pad: clamp(64px,9vw,112px);
  --max: 1280px;
}

/* ---- Reset ---- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--ff-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width:100%; display:block; }
a  { color:inherit; text-decoration:none; }
ul { list-style:none; }
address { font-style:normal; }
button { cursor:pointer; font-family:inherit; }
h1,h2,h3,h4,h5 { font-family:var(--ff-head); line-height:1.2; color:var(--white); }

/* ---- Utility ---- */
.container { width:90%; max-width:var(--max); margin-inline:auto; }
.text-center { text-align:center; }
.text-accent { color:var(--blue); }
.sr-only { position:absolute;width:1px;height:1px;clip:rect(0,0,0,0);overflow:hidden; }

.section-tag {
  display:inline-block;
  font-family:var(--ff-head);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--blue);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.25);
  padding:.35em 1em;
  border-radius:var(--r-full);
  margin-bottom:1rem;
}

.section-title {
  font-size:clamp(1.75rem,3.5vw,2.75rem);
  font-weight:700;
  margin-bottom:1rem;
}
.section-subtitle {
  font-size:1.05rem;
  color:var(--text-2);
  max-width:600px;
  margin-inline:auto;
  line-height:1.7;
}

/* ---- Buttons ---- */
.btn {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--ff-head);
  font-size:.9rem;
  font-weight:600;
  padding:.7em 1.75em;
  border-radius:var(--r-full);
  border:2px solid transparent;
  transition:var(--t);
  white-space:nowrap;
}
.btn--lg { font-size:1rem; padding:.85em 2.2em; }
.btn--sm { font-size:.8rem; padding:.5em 1.25em; }

.btn--primary {
  background:var(--blue);
  color:var(--white);
  border-color:var(--blue);
}
.btn--primary:hover {
  background:var(--blue-bright);
  border-color:var(--blue-bright);
  box-shadow:var(--shadow-glow);
  transform:translateY(-2px);
}
.btn--outline {
  background:transparent;
  color:var(--blue);
  border-color:var(--blue);
}
.btn--outline:hover {
  background:var(--blue);
  color:var(--white);
  box-shadow:var(--shadow-glow);
  transform:translateY(-2px);
}
.btn--ghost {
  background:transparent;
  color:var(--text);
  border-color:var(--border);
}
.btn--ghost:hover {
  border-color:var(--blue);
  color:var(--blue);
  transform:translateY(-2px);
}

/* ================================================================
   NAVIGATION
   ================================================================ */
.nav {
  position:fixed;
  top:0; left:0; right:0;
  z-index:1000;
  height:var(--nav-h);
  display:flex;
  align-items:center;
  transition:background var(--t), box-shadow var(--t);
}
.nav.scrolled {
  background:rgba(27,45,60,.96);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 2px 30px rgba(0,0,0,.35);
}

.nav__inner {
  display:flex;
  align-items:center;
  gap:2rem;
  width:100%;
}

.nav__logo {
  display:flex;
  align-items:center;
  flex-shrink:0;
  padding:6px 0;
}
.nav__logo-img {
  height:93px;
  width:auto;
  display:block;
}
.nav__logo .e  { color:var(--blue); font-size:1.6rem; font-weight:800; line-height:1; }
.nav__logo .pow { color:var(--white); }
.nav__logo .net { color:var(--text-2); font-size:.85rem; font-weight:500; letter-spacing:.06em; }

.nav__links {
  display:flex;
  align-items:center;
  gap:.25rem;
  margin-left:auto;
}
.nav__links > li { position:relative; }
.nav__links > li > a {
  display:block;
  padding:.5rem .9rem;
  font-size:.875rem;
  font-weight:500;
  color:var(--text-2);
  border-radius:var(--r-sm);
  transition:color var(--t);
}
.nav__links > li > a:hover,
.nav__links > li.active > a { color:var(--white); }

/* Dropdown — top:100% with no gap so hover stays continuous */
.dropdown {
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%) translateY(6px);
  min-width:200px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:.5rem .5rem .5rem;
  opacity:0;
  pointer-events:none;
  transition:opacity var(--t), transform var(--t);
  box-shadow:var(--shadow-lg);
}
/* Transparent bridge: extends hover zone between nav item and dropdown */
.has-dropdown::after {
  content:'';
  position:absolute;
  top:100%;
  left:0; right:0;
  height:8px;
  background:transparent;
}
.nav__links > li:hover .dropdown {
  opacity:1;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.dropdown a {
  display:block;
  padding:.55rem 1rem;
  font-size:.85rem;
  color:var(--text-2);
  border-radius:var(--r-sm);
  transition:background var(--t), color var(--t);
}
.dropdown a:hover {
  background:rgba(82,168,122,.1);
  color:var(--blue);
}

.nav__cta { margin-left:1rem; }

.nav__toggle {
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  width:40px; height:40px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  margin-left:auto;
}
.nav__toggle span {
  display:block;
  width:20px; height:2px;
  background:var(--text);
  border-radius:2px;
  transition:var(--t);
}
.nav__toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav__toggle.open span:nth-child(2) { opacity:0; }
.nav__toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ================================================================
   HERO SLIDER
   ================================================================ */
.hero {
  position:relative;
  height:100vh;
  min-height:620px;
  overflow:hidden;
}

/* Circuit pattern overlay */
.hero::after {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M10 40 h20 v-20 h20 M50 40 h20 M40 10 v20 M40 60 v10' stroke='%2352A87A' stroke-width='.6' fill='none' opacity='.4'/%3E%3Ccircle cx='40' cy='40' r='2' fill='%2352A87A' opacity='.4'/%3E%3Ccircle cx='10' cy='40' r='1.5' fill='%2352A87A' opacity='.3'/%3E%3Ccircle cx='70' cy='40' r='1.5' fill='%2352A87A' opacity='.3'/%3E%3C/svg%3E");
  opacity:.04;
  z-index:1;
  pointer-events:none;
}

.hero__slider { position:relative; width:100%; height:100%; }

.hero__slide {
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  opacity:0;
  transition:opacity .9s var(--ease);
  z-index:0;
}
.hero__slide.active { opacity:1; z-index:2; }
.hero__slide.prev   { opacity:0; z-index:1; }

.hero__slide-bg {
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
}
.hero__slide-bg::after {
  content:'';
  position:absolute;
  inset:0;
  background:inherit;
}

/* Per-slide color overlays */
.slide-1 .hero__slide-bg { background: linear-gradient(135deg,#1B2D3C 0%,#1E3448 55%,#172A38 100%); }
.slide-2 .hero__slide-bg { background: linear-gradient(135deg,#192B3A 0%,#1C3242 60%,#172638 100%); }
.slide-3 .hero__slide-bg { background: linear-gradient(135deg,#182C34 0%,#1C3440 60%,#162835 100%); }
.slide-4 .hero__slide-bg { background: linear-gradient(135deg,#1E2E40 0%,#223248 60%,#1A2838 100%); }
.slide-5 .hero__slide-bg { background: linear-gradient(135deg,#1A2C3C 0%,#1E3244 60%,#162838 100%); }
.slide-6 .hero__slide-bg { background: linear-gradient(135deg,#1A2E3C 0%,#1E3640 60%,#162C36 100%); }

/* Decorative orb */
.hero__orb {
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  pointer-events:none;
  z-index:1;
}
.hero__orb--1 { width:500px;height:500px; background:rgba(82,168,122,.10); right:-100px; top:-100px; }
.hero__orb--2 { width:300px;height:300px; background:rgba(106,143,168,.07); left:-50px; bottom:-50px; }

.hero__content {
  position:relative;
  z-index:3;
  width:90%;
  max-width:620px;
  margin-inline:0;
  margin-left:max(40px, 7%);
  padding:calc(var(--nav-h) + 2rem) 0 8rem;
}
@media (max-width:1050px){
  .hero__content { max-width:var(--max); margin-inline:auto; }
}
.hero__tag {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--ff-head);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--blue-bright);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.25);
  padding:.35em 1em;
  border-radius:var(--r-full);
  margin-bottom:1.5rem;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .5s var(--ease) .1s, transform .5s var(--ease) .1s;
}
.hero__slide.active .hero__tag {opacity:1;transform:translateY(0);}

.hero__title {
  font-size:clamp(2rem,5.5vw,4rem);
  font-weight:800;
  line-height:1.1;
  color:var(--white);
  max-width:800px;
  margin-bottom:1.25rem;
  opacity:0;
  transform:translateY(25px);
  transition:opacity .5s var(--ease) .25s, transform .5s var(--ease) .25s;
}
.hero__slide.active .hero__title {opacity:1;transform:translateY(0);}
.hero__title span { color:var(--blue-bright); }
.hero__title em { font-style:normal; color:var(--blue); }

.hero__subtitle {
  font-size:clamp(.95rem,1.5vw,1.15rem);
  color:var(--text-2);
  max-width:580px;
  margin-bottom:2.5rem;
  line-height:1.75;
  opacity:0;
  transform:translateY(25px);
  transition:opacity .5s var(--ease) .4s, transform .5s var(--ease) .4s;
}
.hero__slide.active .hero__subtitle {opacity:1;transform:translateY(0);}

.hero__actions {
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .5s var(--ease) .55s, transform .5s var(--ease) .55s;
}
.hero__slide.active .hero__actions {opacity:1;transform:translateY(0);}

/* Hero Controls */
.hero__controls {
  position:absolute;
  bottom:2.5rem; left:0; right:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1rem;
}
.hero__arrow {
  width:42px; height:42px;
  border-radius:50%;
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.3);
  color:var(--blue);
  font-size:.9rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:var(--t);
}
.hero__arrow:hover {
  background:var(--blue);
  color:var(--white);
  box-shadow:var(--shadow-glow);
}
.hero__dots { display:flex; gap:.5rem; align-items:center; }
.hero__dot {
  width:8px; height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.25);
  border:none;
  transition:var(--t);
}
.hero__dot.active {
  background:var(--blue);
  width:28px;
  border-radius:4px;
  box-shadow:0 0 10px var(--blue-glow2);
}

/* Slide Illustration */
.hero__illustration {
  position:absolute;
  right: max(40px, 7%);
  top:50%;
  transform:translateY(-50%) translateX(40px) scale(.96);
  width:min(420px, 38vw);
  opacity:0;
  transition:opacity .8s var(--ease) .55s, transform .8s var(--ease) .55s;
  z-index:2;
  pointer-events:none;
  filter:drop-shadow(0 20px 60px rgba(82,168,122,.25));
}
.hero__slide.active .hero__illustration {
  opacity:1;
  transform:translateY(-50%) translateX(0) scale(1);
}
.hero__illustration svg,
.hero__illustration img {
  width:100%;
  height:auto;
  display:block;
}
@media (max-width:1050px){ .hero__illustration { display:none; } }

/* Scroll indicator */
.hero__scroll {
  position:absolute;
  bottom:3.5rem;
  right:5%;
  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.5rem;
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text-3);
}
.hero__scroll-line {
  width:1px; height:50px;
  background:linear-gradient(to bottom, var(--blue), transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100% { transform:scaleY(1); opacity:1; }
  50%      { transform:scaleY(.6); opacity:.4; }
}

/* ================================================================
   TRUST BAR (below hero)
   ================================================================ */
.trust-bar {
  background:var(--bg-card);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:1.25rem 0;
}
.trust-bar__inner {
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:2.5rem;
}
.trust-item {
  display:flex;
  align-items:center;
  gap:.65rem;
  font-size:.85rem;
  font-weight:500;
  color:var(--text-2);
}
.trust-item i {
  color:var(--blue);
  font-size:1.1rem;
}

/* ================================================================
   SECTION GENERIC
   ================================================================ */
.section { padding:var(--pad) 0; }
.section--alt { background:var(--bg-alt); }
.section-header { margin-bottom:clamp(2.5rem,5vw,4rem); }
.section-header.center { text-align:center; }
.section-header.center .section-subtitle { margin-inline:auto; }

/* ================================================================
   SERVICES GRID (homepage)
   ================================================================ */
.services-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.5rem;
}
.svc-card {
  background:var(--grad-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2rem;
  transition:border-color var(--t), transform var(--t), box-shadow var(--t);
  position:relative;
  overflow:hidden;
}
.svc-card::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(82,168,122,.05) 0%, transparent 60%);
  opacity:0;
  transition:opacity var(--t);
}
.svc-card:hover {
  border-color:var(--border-h);
  transform:translateY(-5px);
  box-shadow:var(--shadow-glow), var(--shadow-md);
}
.svc-card:hover::before { opacity:1; }

.svc-card__icon {
  width:52px; height:52px;
  border-radius:var(--r-md);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.3rem;
  color:var(--blue);
  margin-bottom:1.25rem;
  transition:background var(--t), box-shadow var(--t);
}
.svc-card:hover .svc-card__icon {
  background:var(--blue);
  color:var(--white);
  box-shadow:var(--shadow-glow);
}
.svc-card h3 {
  font-size:1.1rem;
  font-weight:600;
  margin-bottom:.5rem;
  color:var(--white);
}
.svc-card p {
  font-size:.875rem;
  color:var(--text-2);
  line-height:1.65;
  margin-bottom:1.25rem;
}
.svc-card__link {
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.825rem;
  font-weight:600;
  color:var(--blue);
  transition:gap var(--t);
}
.svc-card:hover .svc-card__link { gap:.75rem; }

/* ================================================================
   FEATURES / WHY EPOWER
   ================================================================ */
.features-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1.5rem;
}
.feature-card {
  text-align:center;
  padding:2.25rem 1.5rem;
  border-radius:var(--r-lg);
  border:1px solid var(--border);
  background:var(--bg-card);
  transition:border-color var(--t), transform var(--t);
}
.feature-card:hover {
  border-color:var(--border-h);
  transform:translateY(-4px);
}
.feature-card__icon {
  width:64px; height:64px;
  border-radius:50%;
  background:rgba(82,168,122,.08);
  border:1px solid rgba(82,168,122,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.25rem;
  font-size:1.5rem;
  color:var(--blue);
}
.feature-card h3 {
  font-size:1rem;
  font-weight:600;
  margin-bottom:.5rem;
}
.feature-card p {
  font-size:.855rem;
  color:var(--text-2);
  line-height:1.6;
}

/* ================================================================
   STATS BAR
   ================================================================ */
.stats-bar {
  background: linear-gradient(135deg, #162535 0%, #1C3048 50%, #13202E 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:3.5rem 0;
}
.stats-bar__grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
  text-align:center;
}
.stat-item__num {
  font-family:var(--ff-head);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:800;
  color:var(--blue-bright);
  line-height:1;
  margin-bottom:.35rem;
}
.stat-item__label {
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-2);
}

/* ================================================================
   PRODUCTS GRID (homepage)
   ================================================================ */
.products-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.5rem;
}
.prod-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:border-color var(--t), transform var(--t), box-shadow var(--t);
}
.prod-card:hover {
  border-color:var(--border-h);
  transform:translateY(-5px);
  box-shadow:var(--shadow-glow), var(--shadow-md);
}
.prod-card__thumb {
  height:160px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:3.5rem;
  color:var(--blue);
  position:relative;
  overflow:hidden;
}
.prod-card__thumb-bg {
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(82,168,122,.06) 0%, rgba(99,102,241,.04) 100%);
}
.prod-card__thumb > * { position:relative; z-index:1; }
.prod-card__thumb img {
  width:100%; height:100%;
  object-fit:cover;
  position:absolute;
  inset:0;
  z-index:0;
  opacity:.7;
}

.prod-card__body { padding:1.5rem; }
.prod-card__body h3 {
  font-size:1.05rem;
  font-weight:600;
  margin-bottom:.45rem;
}
.prod-card__body p {
  font-size:.85rem;
  color:var(--text-2);
  margin-bottom:1rem;
  line-height:1.6;
}
.prod-card__link {
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.825rem;
  font-weight:600;
  color:var(--blue);
  transition:gap var(--t);
}
.prod-card:hover .prod-card__link { gap:.75rem; }

/* ================================================================
   CLIENT LOGOS
   ================================================================ */
.clients-section { overflow:hidden; }
.clients-marquee {
  display:flex;
  gap:3rem;
  animation:marquee 30s linear infinite;
  white-space:nowrap;
}
.clients-marquee:hover { animation-play-state:paused; }
.clients-track {
  overflow:hidden;
  mask-image:linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image:linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}
.client-logo {
  flex-shrink:0;
  font-family:var(--ff-head);
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--text-3);
  padding:.5rem 1.5rem;
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  background:var(--bg-card);
  transition:color var(--t), border-color var(--t);
}
.client-logo:hover {
  color:var(--blue);
  border-color:var(--border-h);
}
@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testimonials-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.5rem;
}
.testi-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2rem;
  position:relative;
  transition:border-color var(--t), transform var(--t);
}
.testi-card:hover {
  border-color:var(--border-h);
  transform:translateY(-4px);
}
.testi-card__quote {
  font-size:2.5rem;
  line-height:1;
  color:var(--blue);
  opacity:.4;
  margin-bottom:.75rem;
  font-family:Georgia, serif;
}
.testi-card__text {
  font-size:.9rem;
  color:var(--text-2);
  line-height:1.7;
  margin-bottom:1.5rem;
  font-style:italic;
}
.testi-card__author { display:flex; align-items:center; gap:.75rem; }
.testi-card__avatar {
  width:42px; height:42px;
  border-radius:50%;
  background:var(--grad-accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--ff-head);
  font-size:.85rem;
  font-weight:700;
  color:var(--white);
  flex-shrink:0;
}
.testi-card__name { font-size:.875rem; font-weight:600; color:var(--white); }
.testi-card__role { font-size:.775rem; color:var(--text-2); }

/* Stars */
.testi-card__stars { color:#F59E0B; font-size:.8rem; margin-bottom:.75rem; }

/* ================================================================
   CTA BAND
   ================================================================ */
.cta-band {
  background: linear-gradient(135deg,#1B2D3C 0%,#1E3448 60%,#172838 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  text-align:center;
  padding:var(--pad) 0;
  position:relative;
  overflow:hidden;
}
.cta-band::before {
  content:'';
  position:absolute;
  top:-200px; left:50%;
  transform:translateX(-50%);
  width:600px; height:400px;
  border-radius:50%;
  background:radial-gradient(ellipse, rgba(82,168,122,.14) 0%, transparent 70%);
  pointer-events:none;
}
.cta-band h2 { font-size:clamp(1.5rem,3.5vw,2.5rem); margin-bottom:1rem; }
.cta-band p  { color:var(--text-2); max-width:520px; margin:0 auto 2rem; font-size:1rem; }
.cta-band__actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ================================================================
   FOOTER
   ================================================================ */
.footer {
  background: #162534;
  border-top:1px solid var(--border);
  padding:5rem 0 0;
}
.footer__grid {
  display:grid;
  grid-template-columns:2fr repeat(4,1fr);
  gap:3rem;
  margin-bottom:4rem;
}
.footer__logo {
  font-family:var(--ff-head);
  font-size:1.35rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:1.25rem;
}
.footer__logo img {
  height:108px;
  width:auto;
  display:block;
}
.footer__logo .e  { color:var(--blue); font-size:1.7rem; font-weight:800; }
.footer__tagline {
  font-size:.875rem;
  color:var(--text-2);
  line-height:1.7;
  max-width:280px;
  margin-bottom:1.5rem;
}
.footer__social {
  display:flex;
  gap:.75rem;
}
.footer__social a {
  width:38px; height:38px;
  border-radius:50%;
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-size:.9rem;
  transition:var(--t);
}
.footer__social a:hover {
  background:var(--blue);
  color:var(--white);
  box-shadow:var(--shadow-glow);
}

.footer__col h4 {
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--white);
  margin-bottom:1.25rem;
}
.footer__col ul li + li { margin-top:.6rem; }
.footer__col ul li a {
  font-size:.85rem;
  color:var(--text-2);
  transition:color var(--t);
}
.footer__col ul li a:hover { color:var(--blue); }
.footer__col address {
  font-size:.85rem;
  color:var(--text-2);
  line-height:1.8;
  margin-bottom:.75rem;
}
.footer__col p {
  font-size:.85rem;
  color:var(--text-2);
  margin-bottom:.5rem;
}
.footer__col p a:hover { color:var(--blue); }

.footer__bottom {
  border-top:1px solid var(--border);
  padding:1.5rem 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
  font-size:.8rem;
  color:var(--text-3);
}
.footer__bottom a {
  color:var(--text-3);
  transition:color var(--t);
}
.footer__bottom a:hover { color:var(--blue); }

/* ================================================================
   SECTION SUB-NAV (inner pages — sticky below main nav)
   ================================================================ */
.section-subnav {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: var(--nav-h);
  z-index: 90;
}
.section-subnav__inner {
  display: flex;
  align-items: center;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.section-subnav__inner::-webkit-scrollbar { display: none; }
.section-subnav a {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .8rem 1.1rem;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-2);
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--t), border-color var(--t), background var(--t);
}
.section-subnav a i { font-size: .8rem; }
.section-subnav a:hover { color: var(--text); background: rgba(82,168,122,.05); }
.section-subnav a.active {
  color: var(--blue);
  border-bottom-color: var(--blue);
}
@media (max-width:640px) {
  .section-subnav a { padding: .7rem .85rem; font-size: .72rem; }
  .section-subnav a i { display: none; }
}

/* ================================================================
   PAGE BANNER (inner pages)
   ================================================================ */
.page-banner {
  padding:calc(var(--nav-h) + 4rem) 0 4rem;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}
.page-banner::before {
  content:'';
  position:absolute;
  top:-150px; right:-100px;
  width:500px; height:400px;
  border-radius:50%;
  background:radial-gradient(ellipse, rgba(82,168,122,.08) 0%, transparent 70%);
  pointer-events:none;
}
.page-banner__breadcrumb {
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.8rem;
  color:var(--text-3);
  margin-bottom:1.25rem;
}
.page-banner__breadcrumb a { color:var(--text-2); }
.page-banner__breadcrumb a:hover { color:var(--blue); }
.page-banner__breadcrumb i { font-size:.65rem; }
.page-banner h1 { font-size:clamp(1.75rem,4vw,3rem); margin-bottom:.75rem; }
.page-banner p  { font-size:1rem; color:var(--text-2); max-width:600px; line-height:1.7; }

/* ================================================================
   CONTENT SECTIONS (inner pages)
   ================================================================ */
.content-section { padding:var(--pad) 0; }
.content-section--alt { background:var(--bg-alt); }

.content-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.content-row--flip .content-row__text { order:2; }
.content-row--flip .content-row__visual { order:1; }

.content-row__text h2 {
  font-size:clamp(1.5rem,3vw,2.25rem);
  margin-bottom:1rem;
}
.content-row__text p {
  color:var(--text-2);
  line-height:1.75;
  margin-bottom:1rem;
}
.content-row__text .btn { margin-top:.5rem; }

.content-row__visual {
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
}
.content-row__visual img {
  width:100%; height:auto;
  display:block;
}
.visual-placeholder {
  height:360px;
  background:var(--bg-card);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
  color:var(--text-2);
  font-size:4rem;
  color:var(--blue);
}
.visual-placeholder span {
  font-size:.9rem;
  color:var(--text-2);
}

/* Feature list */
.feature-list {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.25rem;
  margin-top:2rem;
}
.feature-item {
  display:flex;
  gap:1rem;
  padding:1.25rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:border-color var(--t);
}
.feature-item:hover { border-color:var(--border-h); }
.feature-item__icon {
  flex-shrink:0;
  width:38px; height:38px;
  border-radius:var(--r-sm);
  background:rgba(82,168,122,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-size:.95rem;
}
.feature-item h4 { font-size:.9rem; font-weight:600; margin-bottom:.25rem; }
.feature-item p  { font-size:.82rem; color:var(--text-2); line-height:1.6; }

/* Checklist */
.check-list { margin-top:1rem; }
.check-list li {
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  font-size:.9rem;
  color:var(--text-2);
  padding:.5rem 0;
  border-bottom:1px solid var(--border);
}
.check-list li:last-child { border-bottom:none; }
.check-list li i { color:var(--blue); font-size:.85rem; margin-top:.2rem; flex-shrink:0; }

/* ================================================================
   PRODUCT PAGE SPECIFIC
   ================================================================ */
.product-list {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.5rem;
}
.product-item {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:1.75rem;
  transition:border-color var(--t), transform var(--t);
}
.product-item:hover {
  border-color:var(--border-h);
  transform:translateY(-3px);
}
.product-item__type {
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:.75rem;
}
.product-item h3 { font-size:1rem; font-weight:600; margin-bottom:.5rem; }
.product-item p  { font-size:.85rem; color:var(--text-2); }

/* ================================================================
   TEAM / MANAGEMENT
   ================================================================ */
.team-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:2rem;
}
.team-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  text-align:center;
  transition:border-color var(--t), transform var(--t);
}
.team-card:hover {
  border-color:var(--border-h);
  transform:translateY(-5px);
}
.team-card__avatar {
  width:100%; height:220px;
  background: linear-gradient(135deg, #1E3444, #243E54);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--ff-head);
  font-size:3.5rem;
  font-weight:800;
  color:var(--blue);
  position:relative;
  overflow:hidden;
}
.team-card__avatar::after {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 50% 100%, rgba(82,168,122,.18) 0%, transparent 70%);
}
.team-card__body { padding:1.75rem; }
.team-card__name { font-size:1.15rem; font-weight:700; margin-bottom:.25rem; }
.team-card__title {
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:1rem;
}
.team-card__bio { font-size:.85rem; color:var(--text-2); line-height:1.7; }

/* ================================================================
   CLIENTS PAGE GRID
   ================================================================ */
.client-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:1rem;
}
.client-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:1.25rem 1rem;
  text-align:center;
  font-family:var(--ff-head);
  font-size:.85rem;
  font-weight:600;
  color:var(--text-2);
  transition:border-color var(--t), color var(--t), transform var(--t);
}
.client-card:hover {
  border-color:var(--border-h);
  color:var(--blue);
  transform:translateY(-3px);
}

/* ================================================================
   CAREERS
   ================================================================ */
.job-list { display:flex; flex-direction:column; gap:1rem; }
.job-card {
  display:flex;
  align-items:center;
  gap:1.5rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:1.5rem 2rem;
  transition:border-color var(--t), transform var(--t);
}
.job-card:hover {
  border-color:var(--border-h);
  transform:translateX(4px);
}
.job-card__icon {
  flex-shrink:0;
  width:48px; height:48px;
  border-radius:var(--r-md);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-size:1.2rem;
}
.job-card__info { flex:1; }
.job-card__info h3 { font-size:1rem; font-weight:600; margin-bottom:.25rem; }
.job-card__info p  { font-size:.85rem; color:var(--text-2); }
.job-card__dept {
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--blue);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.2);
  padding:.25em .85em;
  border-radius:var(--r-full);
  flex-shrink:0;
}

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-grid {
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:3rem;
}
.contact-info__item {
  display:flex;
  gap:1rem;
  margin-bottom:1.5rem;
}
.contact-info__icon {
  flex-shrink:0;
  width:44px; height:44px;
  border-radius:var(--r-md);
  background:rgba(82,168,122,.1);
  border:1px solid rgba(82,168,122,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
}
.contact-info__label {
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-3);
  margin-bottom:.25rem;
}
.contact-info__value { font-size:.9rem; color:var(--text-2); }
.contact-info__value a { color:var(--text-2); transition:color var(--t); }
.contact-info__value a:hover { color:var(--blue); }

/* Form */
.contact-form {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2.5rem;
}
.contact-form h3 { font-size:1.25rem; margin-bottom:.5rem; }
.contact-form > p { font-size:.875rem; color:var(--text-2); margin-bottom:2rem; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.25rem; }
.form-group.full { grid-column:1/-1; }
.form-group label {
  display:block;
  font-size:.8rem;
  font-weight:600;
  color:var(--text-2);
  margin-bottom:.4rem;
  letter-spacing:.04em;
}
.form-group input,
.form-group select,
.form-group textarea {
  width:100%;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:.7rem 1rem;
  color:var(--text);
  font-family:var(--ff-body);
  font-size:.9rem;
  outline:none;
  transition:border-color var(--t), box-shadow var(--t);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(82,168,122,.15);
}
.form-group select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%238899B5' d='M4 6l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .75rem center; background-size:16px; padding-right:2.5rem; }
.form-group textarea { min-height:130px; resize:vertical; }
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--text-3); }

/* ================================================================
   NEWS
   ================================================================ */
.news-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; }
.news-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:border-color var(--t), transform var(--t);
}
.news-card:hover { border-color:var(--border-h); transform:translateY(-4px); }
.news-card__header {
  height:180px;
  background: linear-gradient(135deg, #1A2E3C, #203648);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-size:3rem;
}
.news-card__body { padding:1.5rem; }
.news-card__date {
  font-size:.75rem;
  font-weight:600;
  color:var(--blue);
  letter-spacing:.06em;
  margin-bottom:.75rem;
}
.news-card h3 { font-size:1rem; font-weight:600; margin-bottom:.5rem; line-height:1.4; }
.news-card p  { font-size:.85rem; color:var(--text-2); line-height:1.65; }

/* ================================================================
   LEGAL
   ================================================================ */
.legal-content {
  max-width:800px;
  margin-inline:auto;
}
.legal-content h2 {
  font-size:1.25rem;
  margin:2rem 0 .75rem;
  padding-top:2rem;
  border-top:1px solid var(--border);
}
.legal-content h2:first-child { border-top:none; padding-top:0; margin-top:0; }
.legal-content p { font-size:.9rem; color:var(--text-2); line-height:1.8; margin-bottom:1rem; }

/* ================================================================
   LIGHT SECTIONS — .section--alt and .content-section--alt
   These use --bg-alt (light sage off-white), so all text/cards need
   dark-on-light overrides.
   ================================================================ */
.section--alt,
.content-section--alt {
  background: var(--bg-alt);
}

/* Typography overrides */
.section--alt h1,.section--alt h2,.section--alt h3,.section--alt h4,.section--alt h5,
.content-section--alt h1,.content-section--alt h2,.content-section--alt h3,
.content-section--alt h4,.content-section--alt h5 {
  color: #1B2D3C;
}
.section--alt p,.section--alt address,
.content-section--alt p,.content-section--alt address {
  color: #3D5E52;
}
.section--alt .section-tag,
.content-section--alt .section-tag {
  color: var(--blue-dim);
  background: rgba(82,168,122,.12);
  border-color: rgba(82,168,122,.3);
}
.section--alt .section-title,.section--alt .section-subtitle,
.content-section--alt .section-title { color: #1B2D3C; }
.section--alt .section-subtitle,
.content-section--alt .section-subtitle { color: #3D5E52; }
.section--alt .text-accent,
.content-section--alt .text-accent { color: var(--blue-dim); }

/* Cards */
.section--alt .svc-card,
.section--alt .feature-card,
.section--alt .feature-item,
.section--alt .product-item,
.section--alt .testi-card,
.section--alt .team-card,
.section--alt .news-card,
.section--alt .job-card,
.section--alt .client-card,
.content-section--alt .svc-card,
.content-section--alt .feature-card,
.content-section--alt .feature-item,
.content-section--alt .product-item,
.content-section--alt .testi-card,
.content-section--alt .team-card,
.content-section--alt .news-card,
.content-section--alt .job-card,
.content-section--alt .client-card,
.content-section--alt .contact-form,
.content-section--alt .visual-placeholder {
  background: #FFFFFF;
  border-color: #C0D4C0;
}
/* Gradient cards (svc-card uses --grad-card) */
.section--alt .svc-card,
.content-section--alt .svc-card { background: #FFFFFF; }

/* Card headings */
.section--alt .svc-card h3,.section--alt .feature-card h3,.section--alt .feature-item h4,
.section--alt .product-item h3,.section--alt .testi-card__name,.section--alt .team-card__name,
.section--alt .news-card h3,.section--alt .job-card__info h3,.section--alt .client-card,
.content-section--alt .svc-card h3,.content-section--alt .feature-card h3,
.content-section--alt .feature-item h4,.content-section--alt .product-item h3,
.content-section--alt .testi-card__name,.content-section--alt .team-card__name,
.content-section--alt .news-card h3,.content-section--alt .job-card__info h3,
.content-section--alt .client-card { color: #1B2D3C; }

/* Card body text */
.section--alt .svc-card p,.section--alt .feature-card p,.section--alt .feature-item p,
.section--alt .product-item p,.section--alt .testi-card__text,.section--alt .testi-card__role,
.section--alt .team-card__bio,.section--alt .news-card p,.section--alt .job-card__info p,
.content-section--alt .svc-card p,.content-section--alt .feature-card p,
.content-section--alt .feature-item p,.content-section--alt .product-item p,
.content-section--alt .testi-card__text,.content-section--alt .testi-card__role,
.content-section--alt .team-card__bio,.content-section--alt .news-card p,
.content-section--alt .job-card__info p,.content-section--alt .content-row__text p {
  color: #3D5E52;
}

/* Checklist */
.section--alt .check-list li,.content-section--alt .check-list li {
  color: #3D5E52;
  border-bottom-color: #C0D4C0;
}

/* Job card dept badge */
.section--alt .job-card__dept,.content-section--alt .job-card__dept {
  background: rgba(82,168,122,.12);
  border-color: rgba(82,168,122,.3);
  color: var(--blue-dim);
}

/* Product type tag */
.section--alt .product-item__type,.content-section--alt .product-item__type { color: var(--blue-dim); }

/* News card header */
.section--alt .news-card__header,.content-section--alt .news-card__header {
  background: linear-gradient(135deg, #C8E0D0, #A8CCB8);
}

/* Team card avatar */
.section--alt .team-card__avatar,.content-section--alt .team-card__avatar {
  background: linear-gradient(135deg, #C8E0D0, #A8CCB8);
}
.section--alt .team-card__avatar::after,.content-section--alt .team-card__avatar::after {
  background:radial-gradient(ellipse at 50% 100%, rgba(82,168,122,.2) 0%, transparent 70%);
}

/* Form in light sections */
.content-section--alt .contact-form h3 { color: #1B2D3C; }
.content-section--alt .contact-form > p { color: #3D5E52; }
.content-section--alt .form-group label { color: #3D5E52; }
.content-section--alt .form-group input,
.content-section--alt .form-group select,
.content-section--alt .form-group textarea {
  background: #F5FAF5;
  border-color: #C0D4C0;
  color: #1B2D3C;
}
.content-section--alt .form-group input::placeholder,
.content-section--alt .form-group textarea::placeholder { color: #7A9C8C; }
.content-section--alt .form-group input:focus,
.content-section--alt .form-group select:focus,
.content-section--alt .form-group textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(82,168,122,.15);
}

/* Contact info in light sections */
.content-section--alt .contact-info__label { color: #3D5E52; }
.content-section--alt .contact-info__value { color: #1B2D3C; }
.content-section--alt .contact-info__value a { color: #1B2D3C; }

/* Visual placeholder */
.content-section--alt .visual-placeholder { background:#EEF5EE; }
.content-section--alt .visual-placeholder span { color: #3D5E52; }

/* Legal content */
.content-section--alt .legal-content h2 { color: #1B2D3C; border-top-color: #C0D4C0; }
.content-section--alt .legal-content p { color: #3D5E52; }

/* Breadcrumb stays light in page banner (which is dark) — no override needed */
/* Border hover still uses accent color */
.section--alt .svc-card:hover,.section--alt .feature-card:hover,.section--alt .feature-item:hover,
.section--alt .product-item:hover,.section--alt .testi-card:hover,.section--alt .team-card:hover,
.section--alt .news-card:hover,.section--alt .job-card:hover,.section--alt .client-card:hover,
.content-section--alt .svc-card:hover,.content-section--alt .feature-card:hover,
.content-section--alt .feature-item:hover,.content-section--alt .product-item:hover,
.content-section--alt .testi-card:hover,.content-section--alt .team-card:hover,
.content-section--alt .news-card:hover,.content-section--alt .job-card:hover,
.content-section--alt .client-card:hover {
  border-color: var(--border-h);
  box-shadow: 0 6px 24px rgba(82,168,122,.12);
}

/* Client logo pill in light sections */
.section--alt .client-logo,
.content-section--alt .client-logo {
  background: #FFFFFF;
  border-color: #C0D4C0;
  color: #3D5E52;
}

/* ================================================================
   SCROLL ANIMATIONS
   ================================================================ */
.reveal {
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s var(--ease), transform .65s var(--ease);
}
.reveal.visible {
  opacity:1;
  transform:none;
}
.reveal-left  { opacity:0; transform:translateX(-28px); transition:opacity .65s var(--ease), transform .65s var(--ease); }
.reveal-right { opacity:0; transform:translateX(28px);  transition:opacity .65s var(--ease), transform .65s var(--ease); }
.reveal-left.visible,
.reveal-right.visible { opacity:1; transform:none; }
.delay-1 { transition-delay:.1s; }
.delay-2 { transition-delay:.2s; }
.delay-3 { transition-delay:.3s; }
.delay-4 { transition-delay:.4s; }
.delay-5 { transition-delay:.5s; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1100px) {
  .footer__grid { grid-template-columns:1fr 1fr 1fr; }
  .footer__brand { grid-column:1/-1; }
}

@media (max-width:900px) {
  .nav__links, .nav__cta.desktop-only-btn { display:none; }
  .nav__toggle { display:flex; }
  .nav__links.open {
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    position:fixed;
    top:var(--nav-h);
    left:0; right:0;
    background:rgba(27,45,60,.97);
    backdrop-filter:blur(20px);
    padding:2rem;
    gap:.25rem;
    border-bottom:1px solid var(--border);
    max-height:calc(100vh - var(--nav-h));
    overflow-y:auto;
  }
  .nav__links.open > li > a { font-size:1rem; padding:.75rem; color:var(--text); }
  .dropdown {
    position:static;
    transform:none;
    opacity:1;
    pointer-events:auto;
    background:rgba(82,168,122,.06);
    border:1px solid var(--border);
    margin-top:.25rem;
    margin-left:1rem;
    display:none;
  }
  .has-dropdown.open .dropdown { display:block; }
  .has-dropdown > a::after { content:' ▾'; font-size:.7em; }

  .stats-bar__grid { grid-template-columns:repeat(2,1fr); }
  .content-row { grid-template-columns:1fr; gap:2.5rem; }
  .content-row--flip .content-row__text { order:0; }
  .content-row--flip .content-row__visual { order:0; }
  .contact-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
}

@media (max-width:640px) {
  .hero__title { font-size:clamp(1.6rem,7vw,2.5rem); }
  .hero__subtitle { font-size:.9rem; }
  .hero__actions { flex-direction:column; }
  .footer__grid { grid-template-columns:1fr 1fr; }
  .footer__brand { grid-column:1/-1; }
  .stats-bar__grid { grid-template-columns:1fr 1fr; }
  .trust-bar__inner { gap:1.5rem; flex-direction:column; align-items:flex-start; }
  .cta-band__actions { flex-direction:column; align-items:center; }
  .job-card { flex-direction:column; align-items:flex-start; gap:1rem; }
  .team-grid { grid-template-columns:1fr; }
}

/* ================================================================
   KEYFRAMES
   ================================================================ */
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-12px); }
}
@keyframes pulse-ring {
  0%   { transform:scale(1); opacity:.4; }
  100% { transform:scale(1.5); opacity:0; }
}
@keyframes glow-pulse {
  0%,100% { box-shadow:var(--shadow-glow); }
  50%      { box-shadow:var(--shadow-glow2); }
}
