
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d2418;
  --bg2:#0a1f14;
  --bg3:#112a1c;
  --green:rgba(48,255,124,0.82);
  --white:#f0f4f2;
  --muted:rgba(240,244,242,0.72);
  --border:rgba(48,255,124,0.12);
  --card:#122b1b;
  --font-display:'Figtree',sans-serif;
  --font-body:'Figtree',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:var(--font-body);font-weight:400;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}



nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;height:70px;background:rgba(10,31,20,0.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(48,255,124,0.12)}
.nav-logo{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:0.02em}
.nav-logo span{color:var(--green)}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-size:0.72rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(240,244,242,0.6);text-decoration:none;transition:color 0.2s}
.nav-links a:hover{color:var(--green)}
.nav-cta{display:inline-block;font-family:var(--font-body);font-size:0.68rem;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;background:transparent;color:var(--green);border:1px solid rgba(48,255,124,0.5);padding:0.65rem 1.4rem;border-radius:2px;text-decoration:none;transition:all 0.2s;white-space:nowrap}
.nav-cta:hover{background:rgba(48,255,124,0.08);border-color:var(--green)}

.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;box-sizing:border-box;}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:180px;background:linear-gradient(to bottom,transparent,var(--bg2));pointer-events:none}

.container{position:relative;z-index:1;max-width:1160px;margin:0 auto;padding:0 2.5rem}
.hero-inner{max-width:680px;text-align:center;margin:0 auto;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;}
.eyebrow{font-size:0.65rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:1.2rem}
h1{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.8rem);font-weight:800;line-height:1.12;color:var(--white);margin-bottom:1.4rem;letter-spacing:0em}
h1 .green{color:var(--green)}
.hero-sub{font-size:1rem;color:rgba(240,244,242,0.68);max-width:500px;line-height:1.6;text-align:center;font-weight:400}
/* ── BUTTONS — unified size/weight, color varies by context ── */
.btn-primary, .btn-outline, .btn-solid {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  padding: 0.72rem 1.8rem;
  border-radius: 2px;
  text-decoration: none;
  transition: all 0.2s;
  cursor: pointer;
}
/* On dark — green outline */
.btn-outline {
  background: transparent;
  color: var(--green);
  border: 1px solid rgba(48,255,124,0.5);
}
.btn-outline:hover { background: rgba(48,255,124,0.08); border-color: var(--green); }
/* Solid green */
.btn-primary {
  background: var(--green);
  color: #0a1f14;
  border: 1px solid var(--green);
}
.btn-primary:hover { opacity: 0.88; }

.section-pad{padding:5.5rem 0}
.dark{background:var(--bg2)}
.darker{background:var(--bg3)}

h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;line-height:1.1;color:var(--white);letter-spacing:-0.01em}
.subline{font-size:0.62rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:rgba(240,244,242,0.65);margin-top:0.75rem;display:block}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
p{font-size:1rem;font-weight:400;color:rgba(240,244,242,0.75);line-height:1.6;max-width:540px}
p+p{margin-top:1rem}

.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);margin-top:2.5rem}
.card{background:var(--card);padding:2rem;border-radius:0}
.card-lbl{font-size:0.6rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:0.55rem;font-family:var(--font-body)}
.card p{color:var(--muted);font-size:1rem;max-width:100%;line-height:1.6}
.foundation{background:rgba(48,255,124,0.05);border:1px solid rgba(48,255,124,0.2);padding:1.4rem 2rem;text-align:center;margin-top:0}
.foundation .card-lbl{margin-bottom:0.4rem}
.foundation p{text-align:center;margin:0 auto;max-width:500px;color:var(--muted)}

.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);margin-top:2.5rem;text-align:center}
.three-col .card{text-align:center}
.three-col .card p{text-align:center;margin:0 auto}

.process-label{font-size:0.6rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:0.4rem;font-family:var(--font-body)}
.process-flow{display:flex;align-items:center;gap:0.5rem;margin-top:1rem;flex-wrap:wrap}
.step{border:1px solid rgba(48,255,124,0.5);padding:0.6rem 1rem;border-radius:2px;display:flex;flex-direction:column;gap:2px;width:100px}
.step-num{font-size:0.55rem;font-weight:600;color:var(--green);letter-spacing:0.12em;font-family:var(--font-body)}
.step-lbl{font-size:0.6rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:0.08em;font-family:var(--font-body)}
.step-arrow{color:var(--green);font-size:0.9rem}

.ongoing-block{border:1px solid rgba(48,255,124,0.5);border-radius:2px;overflow:hidden;margin-top:1rem}
.ongoing-grid{display:grid;grid-template-columns:1fr 1fr 1fr}
.ongoing-cell{padding:1rem 1.2rem}
.ongoing-cell+.ongoing-cell{border-left:1px solid rgba(48,255,124,0.3)}
.ongoing-dot{width:6px;height:6px;border-radius:50%;background:var(--green);margin-bottom:0.5rem}
.ongoing-lbl{font-size:0.62rem;font-weight:700;color:var(--white);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:0.25rem;font-family:var(--font-body)}
.ongoing-sub{font-size:0.6rem;color:rgba(240,244,242,0.6);font-family:var(--font-body);line-height:1.4}
.ongoing-footer{border-top:1px solid rgba(48,255,124,0.2);padding:0.5rem;text-align:center;background:rgba(48,255,124,0.04);font-size:0.58rem;font-weight:700;color:rgba(48,255,124,0.85);letter-spacing:0.12em;text-transform:uppercase;font-family:var(--font-body)}

.green-band{background:rgba(48,255,124,0.07);border-top:1px solid rgba(48,255,124,0.12);border-bottom:1px solid rgba(48,255,124,0.12);padding:5rem 0;text-align:center}
.green-band h2{margin-bottom:1rem}
.green-band p{text-align:center;margin:0 auto;max-width:560px}
.green-band p+p{margin-top:0.8rem}

.bio-name{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--white);margin-bottom:0.2rem;letter-spacing:-0.01em}
.bio-title{font-size:0.58rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:0.75rem;font-family:var(--font-body)}
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border)}
.linkedin{font-size:0.68rem;color:rgba(240,244,242,0.38);font-family:var(--font-body);text-decoration:none;letter-spacing:0.06em;border-bottom:1px solid rgba(240,244,242,0.15);padding-bottom:1px;display:inline-block;margin-top:0.75rem}

.cta-section{padding:6rem 0;text-align:center;background:var(--bg2)}
.cta-section h2{margin-bottom:0.75rem}
.cta-section p{text-align:center;margin:0 auto}

.callout{border-left:2px solid var(--green);padding:0.6rem 1rem;margin-top:1rem}
.callout p{font-size:1rem;color:var(--white);max-width:100%;margin:0;line-height:1.6}

footer{padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.2rem;background:#0a1f14;border-top:1px solid rgba(48,255,124,0.15)}
.footer-name{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--white)}
.footer-name span{color:var(--green)}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{font-size:0.65rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:rgba(240,244,242,0.4);text-decoration:none}
.footer-copy{font-size:0.65rem;color:rgba(240,244,242,0.3);letter-spacing:0.06em}

/* ════════════════════════════════
   SECTION PALETTE
   ════════════════════════════════ */

.bg-deep  { background: #0a1f14; }
.bg-mid   { background: #112a1c; }
.bg-base  { background: #0d2418; }

/* White sections */
.bg-white { background: #ffffff; color: #1a2e20; }
.bg-white h2 { color: #162419; }
.bg-white h3 { color: #162419; }
.bg-white .eyebrow { color: #1a6638; }
.bg-white p { color: #3d5444; }
.bg-white .subline { color: rgba(26,46,32,0.4); }
.bg-white .card-lbl { color: #1a6638; }
.bg-white .feat-label { color: #22844a; }
.bg-white .step-arrow { color: #22844a; }

/* What We Do cards on dark — visible borders */
.card-grid { background: transparent; gap: 0; border: 1px solid rgba(26,46,32,0.15); }
.card { background: var(--card); padding: 2rem; border: 1px solid rgba(48,255,124,0.35); border-radius: 0; }
.foundation { background: rgba(48,255,124,0.06); border: 1px solid rgba(48,255,124,0.4); padding: 1.4rem 2rem; text-align: center; margin-top: 0; }

/* Three col on dark */
.three-col { background: transparent; gap: 0; border: 1px solid rgba(48,255,124,0.35); margin-top: 2.5rem; text-align: center; display: grid; grid-template-columns: 1fr 1fr 1fr; }
.three-col .card { border: none; border-right: 1px solid rgba(48,255,124,0.35); }
.three-col .card:last-child { border-right: none; }

/* What is a System on WHITE */
.bg-white .feat-card { background: #d4e8d8 !important; border: 1px solid #3d9960 !important; padding: 2.5rem 2rem; }
.bg-white .feat-card .feat-label { color: #22844a !important; }
.bg-white .feat-card p { color: #3d5444 !important; text-align: center; }
.bg-white .three-cards { gap: 1.2rem; }

/* AI Moment / white section text */
.bg-white .container > h2 { color: #162419; }

/* ════════════════════════════════
   HERO BACKGROUND
   ════════════════════════════════ */
.hero-bg { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(8,20,12,0.4) 0%, rgba(8,20,12,0.2) 50%, rgba(8,20,12,0.5) 100%); z-index:0; }

/* ════════════════════════════════
   DIAGONAL — How section only
   ════════════════════════════════ */
.has-diagonal {
  background-image: repeating-linear-gradient(135deg, transparent, transparent 60px, rgba(48,255,124,0.022) 60px, rgba(48,255,124,0.022) 61px);
}

/* ════════════════════════════════
   INNER PAGE HERO — centered
   ════════════════════════════════ */
.page-hero { position:relative; min-height:56vh; display:flex; align-items:center; justify-content:center; padding:130px 0 80px; overflow:hidden; border-bottom:1px solid var(--border); text-align:center; }
.page-hero-inner { position:relative; z-index:1; width:100%; max-width:700px; margin:0 auto; display:flex; flex-direction:column; align-items:center; }
.page-hero .eyebrow { margin-bottom:1.2rem; display:block; }
.page-hero h1 { font-size:clamp(2.2rem,4vw,3.4rem); font-weight:700; line-height:1.12; margin-top:0; max-width:620px; letter-spacing:0em; }
.page-hero .hero-sub { margin-top:1.2rem; font-size:1rem; color:var(--muted); max-width:500px; line-height:1.6; text-align:center; }

/* ════════════════════════════════
   HERO BUTTON SPACING
   ════════════════════════════════ */
.hero-inner .btn-outline,
.hero-inner .btn-primary,
.hero-inner .btn-solid { margin-top: 2.5rem; display: inline-block; }

/* ════════════════════════════════
   NAV HAMBURGER
   ════════════════════════════════ */
.nav-hamburger { display:none; }
.mobile-menu { display:none; }
.mobile-menu.open { display:flex; flex-direction:column; position:fixed; top:70px; left:0; right:0; background:var(--bg2); border-bottom:1px solid var(--border); padding:1.5rem 2rem; gap:1rem; z-index:199; }
.mobile-menu a { font-size:0.78rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:rgba(240,244,242,0.6); text-decoration:none; }
.mobile-menu .mobile-cta { color:var(--green); }

/* ════════════════════════════════
   CAREERS
   ════════════════════════════════ */
.criteria-list { display:flex; flex-direction:column; gap:1.2rem; margin-top:1rem; }
.crit-item { border-left:1px solid rgba(48,255,124,0.45); padding-left:1rem; }
.crit-label { font-size:0.6rem; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:var(--green); display:block; margin-bottom:0.3rem; font-family:var(--font-body); }
.crit-item p { font-size:1rem; max-width:100%; line-height:1.6; }

/* ════════════════════════════════
   CONTACT
   ════════════════════════════════ */
.contact-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:4rem; align-items:start; }
.contact-bullets { list-style:none; margin-top:1.2rem; display:flex; flex-direction:column; gap:0.6rem; }
.contact-bullets li { font-size:1rem; color:var(--muted); padding-left:1rem; border-left:1px solid var(--border); font-family:var(--font-body); line-height:1.6; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.fg { display:flex; flex-direction:column; gap:0.4rem; }
.fg.full { grid-column:1/-1; }
label { font-size:0.65rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:rgba(240,244,242,0.5); font-family:var(--font-body); }
input, select, textarea { background:rgba(240,244,242,0.05); border:1px solid rgba(240,244,242,0.2); color:var(--white); padding:0.7rem 0.9rem; font-size:0.85rem; font-family:var(--font-body); outline:none; width:100%; border-radius:0; }
input::placeholder, textarea::placeholder { color:rgba(240,244,242,0.25); }
input:focus, select:focus, textarea:focus { border-color:rgba(48,255,124,0.55); }
textarea { min-height:120px; resize:vertical; }
select option { background:#0d2418; }
.opt { font-size:0.6rem; color:rgba(240,244,242,0.35); }

/* ════════════════════════════════
   RESPONSIVE
   ════════════════════════════════ */
@media (max-width:900px) {
  nav { padding:0 1.5rem; }
  .nav-links { display:none; }
  .nav-cta { display:none; }
  .nav-hamburger { display:flex; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
  .nav-hamburger span { display:block; width:22px; height:2px; background:var(--white); border-radius:1px; }
  .container { padding:0 1.5rem; }
  .two-col, .contact-layout { grid-template-columns:1fr; gap:2.5rem; }
  .three-col { grid-template-columns:1fr; }
  .card-grid { grid-template-columns:1fr; }
  .hero { padding:0 1.5rem; min-height:100vh; align-items:flex-start; justify-content:center; padding-top:30vh; padding-bottom:0; }
  .page-hero { padding:100px 0 50px; }
  .page-hero.bg-hero { background-position: 0% 0%; background-size: cover; }
  .section-pad { padding:3.5rem 0; }
  h1 { font-size:clamp(2rem,7vw,3.2rem); }
  h2 { font-size:clamp(1.5rem,5vw,2.2rem); }
  footer { padding:1.5rem; }
  .bio-grid { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  h1 { font-size:clamp(1.8rem,8vw,2.5rem); }
  h2 { font-size:clamp(1.4rem,6vw,2rem); }
  .form-grid { grid-template-columns:1fr; }
  .ongoing-grid { grid-template-columns:1fr; }
  .ongoing-cell+.ongoing-cell { border-left:none; border-top:1px solid var(--border); }
}


/* What is a System — dark section, original card style */
.dark .feat-card {
  background: var(--card);
  border: 1px solid rgba(48,255,124,0.35);
  padding: 2.5rem 2rem;
}
.dark .feat-card .feat-label { color: var(--green); }
.dark .feat-card p { color: var(--muted); text-align: center; }


/* ════════════════════════════════
   FINAL PALETTE
   ════════════════════════════════ */
.bg-hero  { background: #0a1f14 url("assets/hero-bg.png") center center / cover no-repeat; }
.bg-deep  { background: #0a1f14; }
.bg-base  { background: #0d2418; }
.bg-mid   { background: #112a1c; }

/* Page hero diagonal — matches main hero */
.page-hero.bg-hero {
  background: #0a1f14 url("assets/hero-bg.png") center center / cover no-repeat;
}
.page-hero.bg-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(8,20,12,0.55) 0%, rgba(8,20,12,0.3) 50%, rgba(8,20,12,0.5) 100%);
  pointer-events: none;
  z-index: 0;
}
.page-hero.bg-hero .page-hero-inner {
  position: relative;
  z-index: 1;
}

/* ── What is a System — white section card fix ── */
.bg-white .three-col {
  background: transparent;
  border: 1px solid #3d9960;
  gap: 0;
}
.bg-white .three-col .card {
  background: #d4e8d8 !important;
  border: none;
  border-right: 1px solid #3d9960;
}
.bg-white .three-col .card:last-child {
  border-right: none;
}
.bg-white .three-col .card .card-lbl {
  color: #22844a !important;
}
.bg-white .three-col .card p {
  color: #3d5444 !important;
}

/* CTA section on white */
.cta-section.bg-white h2 { color: #162419; }
.cta-section.bg-white p { color: #3d5444; }
.cta-section.bg-white .eyebrow { color: #1a6638; }

/* CTA section button on white — dark green ghost outline */
.cta-section.bg-white .btn-outline {
  background: transparent;
  color: #0d2418;
  border: 1px solid #0d2418;
  font-weight: 600;
}
.cta-section.bg-white .btn-outline:hover {
  background: rgba(13,36,24,0.06);
}

/* Mobile — PPT card dividers when stacked vertically */
@media (max-width: 900px) {
  .bg-white .three-col .card {
    border-right: none !important;
    border-bottom: 1px solid #3d9960;
  }
  .bg-white .three-col .card:last-child {
    border-bottom: none;
  }
}

/* ════════════════════════════════
   MOBILE AUDIT FIXES
   ════════════════════════════════ */
@media (max-width: 900px) {

  /* Footer links wrap on mobile */
  .footer-links { flex-wrap: wrap; gap: 1rem 1.5rem; justify-content: center; }

  /* What We Do — arrow row stacks */
  .card-grid + div { display: none; } /* hide the ↓ arrows on mobile */

  /* Foundation box full width */
  .foundation { border-radius: 0; }

  /* Ongoing block — already handled but ensure footer spans full */
  .ongoing-footer { text-align: center; }

  /* How We Work — give more breathing room */
  .process-flow { gap: 0.4rem; }
  .step { width: 88px; padding: 0.5rem 0.7rem; }

  /* Page hero centered on mobile */
  .page-hero { text-align: center; align-items: center; }
  .page-hero-inner { align-items: center; }

  /* Hero sub text max-width on mobile */
  .hero-sub { max-width: 100%; }

  /* CTA section padding */
  .cta-section { padding: 3.5rem 0; }

  /* Bio grid gap */
  .bio-grid { gap: 2rem; }

  /* Contact layout gap */
  .contact-layout { gap: 2rem; }

  /* Ongoing block cells stack */
  .ongoing-grid { grid-template-columns: 1fr; }
  .ongoing-cell + .ongoing-cell { border-left: none; border-top: 1px solid var(--border); }
}

@media (max-width: 600px) {

  /* Tighter section padding */
  .section-pad { padding: 3rem 0; }

  /* Smaller eyebrow */
  .eyebrow { font-size: 0.58rem; }

  /* Step boxes wrap tighter */
  .step { width: 80px; }

  /* Nav logo smaller */
  .nav-logo img { height: 38px !important; }

  /* Footer logo smaller */
  .footer-logo img { height: 36px !important; }

  /* Footer links smaller */
  .footer-links a { font-size: 0.6rem; }

  /* Button full width on very small screens */
  .hero-inner .btn-outline { width: 100%; text-align: center; }

  /* Contact bullets smaller */
  .contact-bullets li { font-size: 0.8rem; }
}

/* Hero h1 — ensure 2 lines always respected on mobile */
.hero-inner h1 {
  font-size: clamp(1.1rem, 4.2vw, 3.8rem);
  white-space: normal;
}
@media (max-width: 600px) {
  .hero-inner h1 {
    font-size: clamp(1rem, 6vw, 2.2rem);
  }
  .hero-inner h1 br { display: block; }
  .hero-sub { font-size: 0.88rem; max-width: 100%; }
}

/* Mobile hero — push content down past nav height */
@media (max-width: 900px) {
  .hero-inner {
    padding-top: 70px;
  }
}

/* ── White section text overrides ── */
.bg-white h2 { color: #162419; }
.bg-white h3 { color: #162419; }
.bg-white p { color: #3a4f40; }
.bg-white .eyebrow { color: #1a6638; }
.bg-white .subline { color: rgba(26,46,32,0.6); }
.bg-white .callout { border-left-color: #3d9960; }
.bg-white .callout p { color: #162419; }
.bg-white .callout .text-green { color: #1a6638; }
.bg-white .card { background: #f4f8f4; border-color: rgba(26,46,32,0.15); }
.bg-white .card p { color: #3a4f40; }
.bg-white .card-lbl { color: #1a6638; }
.bg-white .crit-item { border-left: 2px solid #3d9960; padding-left:1rem; }
.bg-white .crit-label { color: #1a6638; }
.bg-white .crit-item p { color: #3a4f40; }
.bg-white .contact-bullets li { color: #3a4f40; border-left: 2px solid #3d9960; }
.bg-white label { color: rgba(26,46,32,0.6); }
.bg-white input,
.bg-white select,
.bg-white textarea { background: #fff; border-color: rgba(26,46,32,0.2); color: #162419; }
.bg-white input::placeholder,
.bg-white textarea::placeholder { color: rgba(26,46,32,0.35); }
.bg-white input:focus,
.bg-white select:focus,
.bg-white textarea:focus { border-color: #3d9960; }
.bg-white select option { background: #fff; color: #162419; }

/* White sections — never use bright green, always dark green */
.bg-white { --green: #1a6638; }

/* ── AI Moment — full bright green ── */
.bg-ai {
  background: #30FF7C;
}
.bg-ai h2 { color: #0a1f14; }
.bg-ai .eyebrow { color: rgba(0,80,40,0.7); }
.bg-ai p { color: rgba(8,30,18,0.72); }

/* CTA on dark — bright green button */
.cta-section.bg-deep .btn-outline {
  color: #30FF7C;
  border-color: rgba(48,255,124,0.5);
  background: transparent;
}
.cta-section.bg-deep .btn-outline:hover {
  background: rgba(48,255,124,0.08);
  border-color: #30FF7C;
}
.cta-section.bg-deep h2 { color: var(--white); }
.cta-section.bg-deep p  { color: rgba(240,244,242,0.72); }
.cta-section.bg-deep .eyebrow { color: rgba(48,255,124,0.82); }

/* About on white — bio name/title */
.bg-white .bio-name  { color: #162419; }
.bg-white .bio-title { color: #1a6638; }
.bg-white .linkedin  { color: rgba(26,46,32,0.45); border-bottom-color: rgba(26,46,32,0.2); }
.bg-white .bio-grid  { border-top-color: rgba(26,46,32,0.12); }

/* Thin divider between white sections */
.bg-white + .bg-white {
  border-top: 1px solid rgba(0,0,0,0.08);
}

/* ── Standardize What We Do cards on white ── */
.bg-white .card {
  background: #f0f7f2;
  border: 1px solid rgba(26,46,32,0.15);
  padding: 2rem;
}
.bg-white .card p {
  font-size: 1rem;
  line-height: 1.6;
  color: #3a4f40;
  max-width: 100%;
}
.bg-white .card-lbl {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: #1a6638;
  margin-bottom: 0.55rem;
}
.bg-white .foundation {
  background: #f0f7f2;
  border: 1px solid rgba(26,46,32,0.15);
}
.bg-white .foundation p {
  font-size: 1rem;
  line-height: 1.6;
  color: #3a4f40;
}
.bg-white .foundation .card-lbl {
  color: #1a6638;
}

/* How We Work — fix legibility on white */
.bg-white .step {
  border-color: rgba(26,46,32,0.25);
}
.bg-white .step-num {
  color: #1a6638;
}
.bg-white .step-lbl {
  color: #162419;
}
.bg-white .step-arrow {
  color: #1a6638;
}
.bg-white .process-label {
  color: #1a6638;
}
.bg-white .process-label + p {
  color: #3a4f40;
}
.bg-white .ongoing-block {
  border-color: rgba(26,46,32,0.25);
}
.bg-white .ongoing-cell {
  border-right-color: rgba(26,46,32,0.15);
}
.bg-white .ongoing-dot {
  background: #1a6638;
}
.bg-white .ongoing-lbl {
  color: #162419;
}
.bg-white .ongoing-sub {
  color: #3a4f40;
}
.bg-white .ongoing-footer {
  color: #1a6638;
  background: rgba(26,46,32,0.04);
  border-top-color: rgba(26,46,32,0.12);
}
.bg-white p[style*="italic"] {
  color: rgba(26,46,32,0.45) !important;
}

/* Ongoing block dividers — match exterior border */
.bg-white .ongoing-cell + .ongoing-cell {
  border-left-color: rgba(26,46,32,0.25);
}

/* PPT cards — lighter fill on dark section */
.dark .feat-card {
  background: #1a3d28;
  border: 1px solid rgba(48,255,124,0.3);
}

/* PPT cards — correct selector */
.dark .three-col .card {
  background: #1a3d28 !important;
  border-right-color: rgba(48,255,124,0.3);
}
.dark .three-col {
  background: transparent;
  border-color: rgba(48,255,124,0.3);
}

/* Anchor offset — account for fixed nav height */
section[id] {
  scroll-margin-top: 75px;
}

/* Mobile — PPT cards horizontal dividers when stacked */
@media (max-width: 900px) {
  .dark .three-col .card {
    border-right: none !important;
    border-bottom: 1px solid rgba(48,255,124,0.3);
  }
  .dark .three-col .card:last-child {
    border-bottom: none;
  }

  /* Execute/Architect/Analyze — horizontal dividers match border */
  .bg-white .ongoing-cell + .ongoing-cell {
    border-left: none;
    border-top: 1px solid rgba(26,46,32,0.25);
  }
  .dark .ongoing-cell + .ongoing-cell {
    border-left: none;
    border-top: 1px solid rgba(48,255,124,0.3);
  }
}

/* AI Moment — paragraph padding on mobile */
@media (max-width: 600px) {
  .bg-ai p {
    padding: 0 1rem;
    max-width: 100%;
  }
}

/* Active nav link */
.nav-links a.active {
  color: rgba(240,244,242,0.95);
  font-weight: 700;
}

/* Active nav link */
.nav-links a.active {
  color: var(--white);
  font-weight: 700;
}

/* Submit button — matches outline style with hover animation */
.btn-submit {
  padding: 0.72rem 1.8rem;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  background: transparent;
  color: #1a6638;
  border: 1px solid rgba(26,46,32,0.35);
  border-radius: 2px;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.btn-submit:hover {
  background: rgba(26,46,32,0.06);
  border-color: rgba(26,46,32,0.6);
  color: #0f3d20;
}

/* Prevent over-scrolling below footer */
html, body {
  overflow-x: hidden;
}


/* ── Final authoritative card/foundation borders on white ── */
.bg-white .card,
.bg-white .card-grid .card,
.bg-white .foundation {
  background: #f0f7f2 !important;
  border: 1px solid rgba(26,46,32,0.15) !important;
}
.bg-white .card-grid {
  border: 1px solid rgba(26,46,32,0.15) !important;
  background: transparent !important;
}

/* Mobile — card borders when stacked */
@media (max-width: 900px) {
  .bg-white .card-grid {
    border: 1px solid rgba(26,46,32,0.15) !important;
    background: transparent !important;
  }
  .bg-white .card-grid .card {
    background: #f0f7f2 !important;
    border: none !important;
    border-bottom: 1px solid rgba(26,46,32,0.15) !important;
  }
  .bg-white .card-grid .card:last-child {
    border-bottom: none !important;
  }
}

/* ── What We Do — unified card system ── */
.card-system {
  margin-top: 2.5rem;
  border: 1px solid rgba(26,46,32,0.15);
  border-radius: 0;
}
.bg-white .card-system { border-color: rgba(26,46,32,0.15); }
.dark .card-system { border-color: rgba(48,255,124,0.35); }

.card-system .card-grid {
  border: none !important;
  margin-top: 0;
  background: transparent !important;
}
.card-system .card-grid .card {
  border: none !important;
  border-right: 1px solid rgba(26,46,32,0.15) !important;
}
.dark .card-system .card-grid .card {
  border-right-color: rgba(48,255,124,0.35) !important;
}
.card-system .card-grid .card:last-child {
  border-right: none !important;
}
.card-arrows {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid rgba(26,46,32,0.15);
  border-bottom: 1px solid rgba(26,46,32,0.15);
}
.dark .card-arrows {
  border-color: rgba(48,255,124,0.35);
}
.card-arrows div {
  text-align: center;
  padding: 0.3rem;
  color: #1a6638;
}
.dark .card-arrows div { color: var(--green); }
.card-arrows div:first-child {
  border-right: 1px solid rgba(26,46,32,0.15);
}
.dark .card-arrows div:first-child {
  border-right-color: rgba(48,255,124,0.35);
}
.card-system .foundation {
  border: none !important;
  margin-top: 0;
}

/* Mobile — hide arrows, stack cards cleanly */
@media (max-width: 900px) {
  .card-arrows { display: none; }
  .card-system .card-grid { grid-template-columns: 1fr; }
  .card-system .card-grid .card {
    border-right: none !important;
    border-bottom: 1px solid rgba(26,46,32,0.15) !important;
  }
  .dark .card-system .card-grid .card {
    border-bottom-color: rgba(48,255,124,0.35) !important;
  }
  .card-system .foundation {
    border-top: 1px solid rgba(26,46,32,0.15) !important;
  }
  .dark .card-system .foundation {
    border-top-color: rgba(48,255,124,0.35) !important;
  }
}

/* ── What We Do — Option B layout ── */
.what-system { margin-top: 2.5rem; }

.what-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 0.5rem;
}
.what-card {
  background: #f0f7f2;
  border: 1px solid rgba(26,46,32,0.15);
  padding: 1.8rem;
}
.what-card p {
  font-size: 1rem;
  color: #3a4f40;
  line-height: 1.6;
  max-width: 100%;
}

.what-arrows {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 0.5rem;
}
.what-arrows div {
  text-align: center;
  color: #3d9960;
  font-size: 1.4rem;
  padding: 0.4rem 0;
  font-weight: 600;
}

.what-foundation {
  background: #f0f7f2;
  border: 1px solid rgba(26,46,32,0.15);
  border-left: 3px solid #3d9960;
  padding: 1.8rem;
  text-align: center;
}
.what-foundation p {
  font-size: 1rem;
  color: #3a4f40;
  line-height: 1.6;
  max-width: 100%;
  margin: 0 auto;
}
.what-foundation .card-lbl {
  color: #1a6638;
  margin-bottom: 0.5rem;
}

/* Mobile */
@media (max-width: 900px) {
  .what-cards { grid-template-columns: 1fr; }
  .what-arrows { grid-template-columns: 1fr 1fr; }
}
