/* ==========================================================================
   Grants Partner: shared design system
   One stylesheet for every public page. Authority direction:
   deep green + structured grid + confident type. No decorative clutter.
   Font is a single variable (--font) for easy swapping.
   ========================================================================== */

/* Satoshi: self-hosted (Fontshare, ITF Free Font License). Static weights
   400/500/700/900; 600 and 800 round up naturally, as the CDN did. */
@font-face { font-family: "Satoshi"; src: url("/fonts/satoshi-400.woff2") format("woff2"); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: "Satoshi"; src: url("/fonts/satoshi-500.woff2") format("woff2"); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: "Satoshi"; src: url("/fonts/satoshi-700.woff2") format("woff2"); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: "Satoshi"; src: url("/fonts/satoshi-900.woff2") format("woff2"); font-weight: 900; font-style: normal; font-display: swap; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green: #003D2B;
  --green-deep: #00271B;
  --green-bright: #0B6B49;     /* accent: small labels / links, on-brand */
  --sage: #8FA391;
  --ink: #0E1A15;
  --paper: #F4F2EA;
  --paper-2: #ECE9DF;
  --line: rgba(14, 26, 21, 0.16);
  --line-soft: rgba(14, 26, 21, 0.10);
  --muted: rgba(14, 26, 21, 0.62);
  --white: #FBFAF5;

  --success-fg: #1A6B47; --success-bg: #EDF8F1; --success-bd: #AFD9C2;
  --error-fg: #A83324;   --error-bg: #FFF2ED;   --error-bd: #F1B8A9;

  --radius: 6px;
  --header-h: 78px;
  --shell: min(1240px, calc(100% - 56px));
  --font: "Satoshi", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
}

html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 16px); -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
main { flex: 1 0 auto; }
a { color: inherit; }
img { max-width: 100%; display: block; }

.shell { width: var(--shell); margin: 0 auto; }
.label { font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-bright); }

.skip-link { position: absolute; top: -100%; left: 18px; z-index: 999; background: var(--green); color: var(--white); padding: 10px 16px; font-size: 13px; font-weight: 700; text-decoration: none; border-radius: var(--radius); }
.skip-link:focus { top: 14px; }
:focus-visible { outline: 3px solid var(--green-bright); outline-offset: 3px; }
:focus:not(:focus-visible) { outline: none; }

/* ---------- Header ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 40; height: var(--header-h);
  background: rgba(244, 242, 234, 0.9); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  transition: transform 280ms ease;
}
.site-header.is-hidden { transform: translateY(calc(-100% - 2px)); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 100%; }
.brand { display: inline-flex; align-items: center; text-decoration: none; }
.brand-logo { height: 36px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 32px; font-size: 14px; font-weight: 600; }
.nav-links a { color: var(--ink); text-decoration: none; opacity: 0.8; transition: opacity .2s; }
.nav-links a:hover { opacity: 1; }
.nav-links .btn-primary { padding: 10px 20px; color: var(--white); opacity: 1; }
.nav-links .btn-primary:hover { color: var(--white); }

/* Mobile menu toggle (burger); hidden on desktop, shown <=760px */
.nav-toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 46px; height: 40px; padding: 9px 10px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(244,242,234,0.5); cursor: pointer; }
.nav-toggle span { display: block; height: 2px; width: 100%; background: var(--ink); border-radius: 2px; transition: transform .25s ease, opacity .2s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Buttons ---------- */
.btn { font-family: var(--font); font-weight: 700; font-size: 14px; letter-spacing: 0.01em; cursor: pointer; border-radius: var(--radius); text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 12px 22px; border: 1px solid transparent; transition: background .18s, transform .18s, border-color .18s, color .18s, box-shadow .18s; }
.btn-primary { background: var(--green); color: var(--white); }
.btn-primary:hover { background: var(--green-deep); }
.btn-outline { background: transparent; color: var(--green); border-color: var(--line); }
.btn-outline:hover { border-color: var(--green); }
.btn-secondary { background: var(--white); color: var(--green); border-color: var(--line); }
.btn-secondary:hover { border-color: var(--green); transform: translateY(-1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ---------- Home hero (video) ---------- */
.hero { position: relative; min-height: 100vh; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; color: var(--white); background: var(--green-deep); }
.hero video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(175deg, rgba(0,28,19,0.62) 0%, rgba(0,28,19,0.30) 42%, rgba(0,28,19,0.62) 100%); }
/* lower blur + green fade hides the video watermark and blends video into page */
.hero-veil { position: absolute; left: 0; right: 0; bottom: 0; height: 46%; z-index: 1; pointer-events: none;
  background: linear-gradient(to bottom, rgba(0,28,19,0) 0%, rgba(0,28,19,0.40) 30%, rgba(0,28,19,0.88) 68%, var(--green-deep) 100%);
  -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.55) 24%, #000 62%);
  mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.55) 24%, #000 62%); }
.hero-top { position: relative; z-index: 2; padding-top: calc(var(--header-h) + 8px); }
.hero-top .label { color: rgba(251,250,245,0.78); }
.hero-inner { position: relative; z-index: 2; padding: 40px 0 44px; }
.hero h1 { font-size: clamp(48px, 7vw, 104px); line-height: 0.98; font-weight: 800; letter-spacing: -0.03em; max-width: 16ch; text-wrap: balance; }
.hero .lede { max-width: 56ch; margin-top: 26px; font-size: clamp(16px, 1.45vw, 20px); color: rgba(251,250,245,0.9); font-weight: 400; }
.hero-actions { display: flex; gap: 12px; margin-top: 36px; flex-wrap: wrap; }
.hero .btn-primary { background: var(--white); color: var(--green); }
.hero .btn-primary:hover { background: #fff; transform: translateY(-2px); }
.hero .btn-outline { color: var(--white); border-color: rgba(251,250,245,0.4); }
.hero .btn-outline:hover { border-color: #fff; background: rgba(255,255,255,0.08); }

/* credibility strip anchored to bottom of hero */
.hero-creds { position: relative; z-index: 2; padding-bottom: 36px; }
.hero-creds .creds-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(251,250,245,0.24); padding-top: 26px; }
.cred { padding: 0 26px; border-left: 1px solid rgba(251,250,245,0.16); }
.cred:first-child { border-left: none; padding-left: 0; }
.cred strong { display: block; font-size: 15px; font-weight: 700; letter-spacing: -0.01em; color: var(--white); }
.cred span { display: block; font-size: 13.5px; color: rgba(251,250,245,0.7); margin-top: 6px; }

/* ---------- Section scaffolding ---------- */
section { padding: clamp(80px, 11vh, 132px) 0; }
.sec-rule { display: flex; align-items: baseline; gap: 16px; padding-bottom: 22px; border-bottom: 1px solid var(--ink); margin-bottom: 56px; }
.sec-rule .idx { font-size: 13px; font-weight: 700; letter-spacing: 0.1em; }
.sec-rule h2 { font-size: clamp(28px, 3.4vw, 46px); line-height: 1.04; font-weight: 800; letter-spacing: -0.025em; margin-left: auto; max-width: 18ch; text-align: right; }
.sec-intro { max-width: 60ch; color: var(--muted); font-size: clamp(17px,1.5vw,20px); margin: -28px 0 56px; }

/* services grid: text-led blocks, structured borders (no icons) */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.svc { padding: 34px 30px 38px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); transition: background .25s; }
.svc:hover { background: var(--white); }
.svc .n { font-size: 13px; font-weight: 700; color: var(--green-bright); letter-spacing: 0.06em; }
.svc h3 { font-size: 21px; font-weight: 700; letter-spacing: -0.015em; margin-top: 18px; line-height: 1.18; }
.svc p { font-size: 15px; color: var(--muted); margin-top: 12px; }
.svc ul { list-style: none; margin-top: 16px; display: grid; gap: 8px; }
.svc ul li { position: relative; padding-left: 18px; font-size: 14px; color: var(--muted); }
.svc ul li::before { content: ""; position: absolute; left: 0; top: 9px; width: 6px; height: 6px; border-radius: 50%; background: var(--sage); }
.svc-link { display: inline-block; margin-top: 18px; font-size: 13.5px; font-weight: 700; color: var(--green); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 2px; transition: border-color .18s, color .18s; }
.svc-link:hover { color: var(--green-deep); border-color: var(--green); }

/* ---------- Produce grid (outputs) ---------- */
.produce-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(251,250,245,0.22); border-left: 1px solid rgba(251,250,245,0.22); }
.produce { padding: 26px 24px 30px; border-right: 1px solid rgba(251,250,245,0.22); border-bottom: 1px solid rgba(251,250,245,0.22); }
.produce h4 { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; color: var(--white); }
.produce p { font-size: 13.5px; color: rgba(251,250,245,0.72); margin-top: 10px; line-height: 1.55; }

/* ---------- Compliance / independence note ---------- */
.compliance-note { max-width: 92ch; border-left: 3px solid var(--green-bright); padding: 4px 0 4px 22px; }
.compliance-note p { font-size: 15px; color: var(--muted); margin: 0; }

/* service navigation cards (anchor links that look like svc cells) */
.svc-nav { text-decoration: none; color: inherit; }
.svc-nav h3 { transition: color .2s; }
.svc-nav:hover h3 { color: var(--green-bright); }

/* ---------- Inline line icons ---------- */
.ico { width: 24px; height: 24px; display: block; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.svc-ico { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: 13px; background: rgba(11,107,73,0.09); color: var(--green); margin-bottom: 18px; transition: background .22s, color .22s, transform .22s; }
.svc-nav:hover .svc-ico { background: var(--green); color: var(--white); transform: translateY(-2px); }

/* ---------- Lifecycle strip (services hero) ---------- */
.lifecycle { display: grid; grid-template-columns: repeat(6, 1fr); margin-top: 48px; border-top: 1px solid var(--line); }
.life { padding: 24px 16px 0; border-left: 1px solid var(--line-soft); }
.life:first-child { border-left: none; padding-left: 0; }
.life-ico { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; background: rgba(11,107,73,0.09); color: var(--green); }
.life strong { display: block; font-size: 15px; font-weight: 700; margin-top: 14px; letter-spacing: -0.01em; }
.life span { display: block; font-size: 13px; color: var(--muted); margin-top: 5px; line-height: 1.45; }

/* ---------- Services: bento tile grid ---------- */
.svc-bento { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 1fr; gap: 14px; margin-top: 40px; }
.svc-tile {
  position: relative; display: flex; flex-direction: column; isolation: isolate;
  background: var(--white); border: 1px solid var(--line); border-radius: 16px;
  padding: 26px 24px; text-decoration: none; color: inherit; overflow: hidden;
  transition: transform .26s cubic-bezier(.2,.7,.2,1), box-shadow .26s ease, border-color .26s ease;
}
.svc-tile::after { content: ""; position: absolute; left: 0; bottom: 0; height: 3px; width: 100%; background: linear-gradient(90deg, var(--green-bright), var(--sage)); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; z-index: 2; }
.svc-tile:hover { transform: translateY(-6px); box-shadow: 0 20px 46px rgba(0,42,30,0.13); border-color: var(--sage); }
.svc-tile:hover::after { transform: scaleX(1); }
.svc-tile h3 { font-size: 18px; font-weight: 700; letter-spacing: -0.015em; line-height: 1.2; }
.svc-tile p { font-size: 14px; color: var(--muted); margin-top: 10px; }
.svc-tile .go { margin-top: auto; padding-top: 18px; font-size: 13px; font-weight: 700; color: var(--green); display: inline-flex; align-items: center; gap: 7px; }
.svc-tile .go .ico { width: 16px; height: 16px; transition: transform .26s cubic-bezier(.2,.7,.2,1); }
.svc-tile:hover .go .ico { transform: translateX(6px); }
.svc-tile:hover .svc-ico { background: var(--green); color: var(--white); }

/* featured tile: larger anchor, gentle tint (not a heavy colour block) */
.svc-tile.feature { grid-column: span 2; grid-row: span 2; background: rgba(11,107,73,0.045); padding: 36px 34px; }
.svc-tile.feature h3 { font-size: clamp(24px, 2.6vw, 34px); margin-top: 4px; }
.svc-tile.feature p { font-size: 16px; max-width: 38ch; }
.svc-tile.feature .svc-ico { width: 58px; height: 58px; }
.svc-tile.feature .svc-ico .ico { width: 28px; height: 28px; }
.svc-tile.feature:hover { box-shadow: 0 22px 52px rgba(0,42,30,0.16); }

/* uniform 6-card overview (no featured tile) */
.svc-bento.uniform { grid-template-columns: repeat(3, 1fr); }

/* services: stage selector cards */
.stage-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 36px; }
.stage-card { display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--line); border-radius: 14px; padding: 22px; text-decoration: none; color: inherit; transition: transform .26s cubic-bezier(.2,.7,.2,1), box-shadow .26s ease, border-color .26s ease; }
.stage-card:hover { transform: translateY(-4px); box-shadow: 0 16px 38px rgba(0,42,30,0.12); border-color: var(--sage); }
.stage-card .eyebrow { margin-bottom: 4px; }
.stage-card h3 { font-size: 17px; font-weight: 700; letter-spacing: -0.015em; line-height: 1.25; }
.stage-card .svc-link { display: inline-flex; align-items: center; gap: 6px; margin-top: auto; padding-top: 14px; border-bottom: none; }
.stage-card .svc-link .ico { width: 15px; height: 15px; }
.stage-card:hover .svc-link { color: var(--green-deep); }

/* comparison table (NGO retainers) */
.table-wrap { overflow-x: auto; margin-top: 30px; -webkit-overflow-scrolling: touch; }
.cmp { width: 100%; border-collapse: collapse; font-size: 15px; min-width: 600px; }
.cmp th, .cmp td { text-align: left; padding: 15px 18px; border-bottom: 1px solid var(--line); vertical-align: top; }
.cmp thead th { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-weight: 700; }
.cmp tbody th { font-weight: 700; color: inherit; }
.cmp tbody tr:last-child th, .cmp tbody tr:last-child td { border-bottom: none; }

/* contact: prominent soft-entry option */
.soft-option { background: rgba(11,107,73,0.06); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; font-size: 14px; line-height: 1.5; color: var(--green-deep); margin-bottom: 22px; }
.soft-option a { font-weight: 700; }

/* process-flow line (How We Work) */
.flow-line { display: flex; flex-wrap: wrap; align-items: center; margin-top: 40px; padding-top: 26px; border-top: 1px solid var(--line); }
.flow-line span { font-size: 14px; font-weight: 700; color: var(--green-deep); }
.flow-line span:not(:last-child)::after { content: "\2192"; color: var(--sage); margin: 0 14px; font-weight: 400; }

/* alternate detail blocks left/right for rhythm */
.svc-detail:nth-child(even) .svc-detail-grid { grid-template-columns: 1fr 1.25fr; }
.svc-detail:nth-child(even) .svc-detail-main { order: 2; }
.svc-detail:nth-child(even) .svc-detail-side { order: 1; border-left: none; border-right: 1px solid var(--line); padding-left: 0; padding-right: clamp(28px, 4vw, 56px); }

/* ---------- Services: detailed service blocks ---------- */
.svc-details { display: grid; gap: 0; counter-reset: svc; }
.svc-detail { position: relative; padding: 66px 0; border-bottom: 1px solid var(--line); counter-increment: svc; }
.svc-detail::before { content: counter(svc, decimal-leading-zero); position: absolute; top: 30px; right: 0; font-size: clamp(84px, 11vw, 150px); font-weight: 800; line-height: 1; letter-spacing: -0.04em; color: rgba(0,61,43,0.05); pointer-events: none; z-index: 0; }
.svc-detail > * { position: relative; z-index: 1; }
.svc-detail:first-child { padding-top: 0; }
.svc-detail:last-child { border-bottom: none; padding-bottom: 0; }
.svc-detail-head { display: flex; align-items: center; gap: 18px; margin-bottom: 28px; }
.svc-detail-ico { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 14px; background: rgba(11,107,73,0.09); color: var(--green); flex-shrink: 0; }
.svc-detail-ico .ico { width: 26px; height: 26px; }
.svc-detail-head .idx { display: block; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-bright); margin-bottom: 4px; }
.svc-detail-head h2 { font-size: clamp(24px, 2.8vw, 36px); font-weight: 800; letter-spacing: -0.025em; line-height: 1.06; }
.svc-detail-grid { display: grid; grid-template-columns: 1.25fr 1fr; gap: clamp(32px, 5vw, 80px); align-items: start; }
.svc-detail-main p { font-size: 16.5px; color: rgba(14,26,21,0.82); margin-bottom: 16px; max-width: 60ch; }
.svc-detail-main .best-for { font-size: 15px; color: var(--muted); border-left: 3px solid var(--green-bright); padding: 2px 0 2px 16px; }
.svc-detail-main .best-for strong { color: var(--ink); font-weight: 700; }
.svc-detail-main .scope-note { font-size: 14px; color: var(--muted); border-left: 3px solid var(--sage); padding-left: 16px; }
/* deliverables: open column with a hairline divider, no card box */
.svc-detail-side { border-left: 1px solid var(--line); padding-left: clamp(28px, 4vw, 56px); }
.svc-detail-side h4 { font-size: 11.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green); margin-bottom: 14px; }
.svc-detail-side h4 + ul { margin-bottom: 28px; }
.svc-detail-side ul { list-style: none; display: grid; gap: 11px; }
.svc-detail-side ul:last-child { margin-bottom: 0; }
.svc-detail-side li { position: relative; padding-left: 28px; font-size: 14.5px; color: rgba(14,26,21,0.82); line-height: 1.5; }
.svc-detail-side li::before { content: ""; position: absolute; left: 0; top: 1px; width: 18px; height: 18px; border-radius: 50%; background: var(--green-bright); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center / 11px no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center / 11px no-repeat; }
.svc-detail-side ul.excl li { color: var(--muted); }
.svc-detail-side ul.excl li::before { background: var(--paper-2); -webkit-mask: none; mask: none; content: "\00d7"; display: grid; place-items: center; font-size: 12px; font-weight: 700; color: var(--muted); top: 1px; }
.boundary-list .step p { color: rgba(251,250,245,0.86); font-size: 15px; margin-top: 16px; }

/* ---------- Green color-block band ---------- */
.band { background: var(--green); color: var(--white); }
.band .sec-rule { border-color: rgba(251,250,245,0.34); }
.band .sec-rule h2 { color: #fff; }
.band .idx { color: rgba(251,250,245,0.7); }
.band .label { color: #7FC2A5; }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); }
.step { padding-right: 36px; border-left: 1px solid rgba(251,250,245,0.18); padding-left: 30px; }
.step:first-child { border-left: none; padding-left: 0; }
.step .big { font-size: clamp(40px, 4.5vw, 64px); font-weight: 800; line-height: 1; letter-spacing: -0.03em; color: rgba(251,250,245,0.32); }
.step h4 { font-size: 18px; font-weight: 700; margin-top: 20px; }
.step p { font-size: 14.5px; color: rgba(251,250,245,0.74); margin-top: 12px; line-height: 1.55; }

/* ---------- Audience / structured list ---------- */
.aud { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 56px; }
.aud-row { display: grid; grid-template-columns: 30px 1fr; gap: 18px; padding: 26px 0; border-bottom: 1px solid var(--line-soft); align-items: baseline; }
.aud-row .n { font-size: 13px; font-weight: 700; color: var(--green-bright); }
.aud-row h4 { font-size: 17px; font-weight: 700; }
.aud-row p { font-size: 14.5px; color: var(--muted); margin-top: 6px; }

/* ---------- CTA / newsletter block ---------- */
.cta { background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: clamp(40px,6vw,68px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,6vw,80px); align-items: center; }
.cta h2 { font-size: clamp(26px,3.2vw,40px); font-weight: 800; letter-spacing: -0.025em; line-height: 1.08; max-width: 14ch; }
.cta p { color: var(--muted); margin-top: 16px; max-width: 44ch; }
.cta .cta-actions { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Forms (shared across .form and .form-shell) ---------- */
.form { display: flex; flex-direction: column; gap: 14px; }
.form label, .field label, .field-block label, fieldset legend { display: block; font-size: 13px; font-weight: 600; color: var(--ink); }

.form input, .form select, .form textarea,
.form-shell input:not([type="checkbox"]), .form-shell select, .form-shell textarea {
  width: 100%; font-family: var(--font); font-size: 15px; padding: 13px 15px;
  border: 1px solid var(--line); background: #fff; border-radius: 8px; color: var(--ink);
  transition: border-color .15s, box-shadow .15s; appearance: none; -webkit-appearance: none;
}
.form textarea, .form-shell textarea { min-height: 140px; resize: vertical; line-height: 1.55; }
.form select, .form-shell select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230E1A15' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 15px center; background-size: 16px; padding-right: 44px; cursor: pointer;
}
.form input::placeholder, .form textarea::placeholder,
.form-shell input::placeholder, .form-shell textarea::placeholder { color: rgba(14,26,21,0.40); }
.form input:focus, .form select:focus, .form textarea:focus,
.form-shell input:focus, .form-shell select:focus, .form-shell textarea:focus {
  outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(0,61,43,0.12);
}
.form input[aria-invalid="true"], .form textarea[aria-invalid="true"], .form select[aria-invalid="true"],
.form-shell input[aria-invalid="true"], .form-shell textarea[aria-invalid="true"], .form-shell select[aria-invalid="true"] {
  border-color: var(--error-fg); box-shadow: 0 0 0 3px rgba(168,51,36,0.10);
}
.form .btn-primary { justify-content: center; padding: 14px; }
.consent { font-size: 12.5px; color: var(--muted); display: flex; gap: 10px; align-items: flex-start; line-height: 1.55; }
.consent a, .data-note a { color: var(--green-bright); text-decoration: underline; text-underline-offset: 2px; font-weight: 600; }
input[type="checkbox"] { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--green); cursor: pointer; }
.field-error, .consent-error { display: none; font-size: 12.5px; font-weight: 600; color: var(--error-fg); margin-top: 4px; }
.field-error:not(:empty), .consent-error:not(:empty) { display: block; }
.form-status { font-size: 14px; font-weight: 600; padding: 12px 14px; border-radius: var(--radius); margin-top: 4px; }
.form-status:empty { display: none; }
.form-status.success { color: var(--success-fg); background: var(--success-bg); border: 1px solid var(--success-bd); }
.form-status.error { color: var(--error-fg); background: var(--error-bg); border: 1px solid var(--error-bd); }
.data-note { font-size: 12.5px; color: var(--muted); line-height: 1.55; margin-top: 16px; }

/* ---------- Inner page hero (no video) ---------- */
.page-hero { padding-top: calc(var(--header-h) + clamp(48px, 8vh, 92px)); padding-bottom: clamp(40px, 6vh, 72px); }
.page-hero .eyebrow { display: inline-block; margin-bottom: 20px; font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-bright); }
.page-hero h1 { font-size: clamp(40px, 5.4vw, 76px); line-height: 1.0; font-weight: 800; letter-spacing: -0.03em; max-width: 18ch; text-wrap: balance; }
.page-hero .hero-lede { max-width: 60ch; margin-top: 24px; font-size: clamp(17px,1.5vw,20px); color: var(--muted); }
.page-hero .hero-actions { display: flex; gap: 12px; margin-top: 32px; flex-wrap: wrap; }

/* signal rows used on About/Services hero */
.signal-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 48px; border-top: 1px solid var(--line); }
.signal-row.cols-4 { grid-template-columns: repeat(4, 1fr); }
.signal-row > div { padding: 24px 24px 0; border-left: 1px solid var(--line-soft); }
.signal-row > div:first-child { border-left: none; padding-left: 0; }
.signal-row .n { font-size: 13px; font-weight: 700; color: var(--green-bright); }
.signal-row strong { display: block; font-size: 16px; font-weight: 700; margin-top: 8px; }
.signal-row span, .signal-row p { display: block; font-size: 14px; color: var(--muted); margin-top: 6px; }

/* ---------- Dual checklist (Work With Us / NGO) ---------- */
.dual-list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 56px; }
.check-list { list-style: none; display: grid; gap: 12px; align-content: start; }
.check-list li { position: relative; padding-left: 30px; font-size: 16px; color: rgba(14,26,21,0.82); line-height: 1.5; }
.check-list li::before { content: ""; position: absolute; left: 0; top: 2px; width: 18px; height: 18px; border-radius: 50%; background: var(--green-bright); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center / 12px no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center / 12px no-repeat; }
.check-list.on-dark li { color: rgba(251,250,245,0.88); }
.check-list.on-dark li::before { background: #7FC2A5; }

/* ---------- Long-form / article prose ---------- */
.prose { max-width: 70ch; }
.prose h2 { font-size: clamp(24px, 3vw, 34px); font-weight: 800; letter-spacing: -0.02em; margin: 40px 0 14px; line-height: 1.12; }
.prose h3 { font-size: 20px; font-weight: 700; margin: 28px 0 10px; }
.prose h1 { font-size: clamp(30px,4vw,44px); font-weight: 800; letter-spacing: -0.025em; margin: 0 0 16px; }
.prose p { margin: 0 0 18px; font-size: 17px; color: rgba(14,26,21,0.82); }
.prose ul { margin: 0 0 18px; padding-left: 22px; }
.prose li { margin-bottom: 8px; font-size: 16.5px; color: rgba(14,26,21,0.82); }
.prose a { color: var(--green-bright); text-decoration: underline; text-underline-offset: 2px; }
.prose code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.9em; background: var(--paper-2); padding: 2px 6px; border-radius: 4px; }
.prose strong { font-weight: 700; }

/* ---------- Blog list ---------- */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.post-card { display: flex; flex-direction: column; gap: 10px; text-decoration: none; color: inherit; background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: 28px; transition: transform .2s, box-shadow .2s, border-color .2s; }
.post-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,42,30,0.10); border-color: var(--line); }
.post-meta { font-size: 12.5px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--green-bright); }
.post-card h2 { font-size: 20px; font-weight: 700; letter-spacing: -0.015em; line-height: 1.2; }
.post-card p { font-size: 14.5px; color: var(--muted); }
.post-card .read-more { margin-top: auto; font-size: 13.5px; font-weight: 700; color: var(--green); }
.empty-state { grid-column: 1 / -1; background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: 40px; color: var(--muted); font-size: 16px; }
.topic-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.topic-row span { font-size: 13px; font-weight: 600; color: var(--green); padding: 7px 14px; border: 1px solid var(--line); border-radius: 999px; }

/* ---------- Contact (multi-step inquiry) ---------- */
.contact-layout { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(40px, 6vw, 88px); align-items: start; padding-top: calc(var(--header-h) + clamp(40px, 7vh, 80px)); padding-bottom: clamp(60px, 9vh, 110px); }
.contact-layout .intro { position: sticky; top: calc(var(--header-h) + 28px); }
.contact-layout .intro h1 { font-size: clamp(34px, 4vw, 56px); line-height: 1.02; font-weight: 800; letter-spacing: -0.03em; margin-top: 16px; }
.contact-layout .intro .lead { margin-top: 22px; font-size: 18px; color: var(--muted); max-width: 42ch; }
.contact-layout .direct { margin-top: 18px; font-size: 15px; }
.contact-layout .direct a { color: var(--green-bright); font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }
.contact-notes { margin-top: 30px; display: grid; gap: 14px; border-top: 1px solid var(--line); padding-top: 24px; }
.contact-notes .note { font-size: 13.5px; color: var(--muted); line-height: 1.55; }

.form-shell { background: var(--white); border: 1px solid var(--line); border-radius: 12px; padding: clamp(26px, 3vw, 40px); }
.form-progress { display: flex; gap: 8px; margin-bottom: 32px; }
.step-tab { flex: 1; display: flex; align-items: center; gap: 10px; padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 13.5px; font-weight: 600; color: var(--muted); }
.step-tab.is-active { border-color: var(--green); color: var(--green); background: var(--paper); }
.step-dot { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; font-weight: 800; background: var(--paper-2); color: var(--ink); }
.step-tab.is-active .step-dot { background: var(--green); color: var(--white); }
.form-step { display: none; }
.form-step.is-active { display: block; }
.form-section { margin-bottom: 30px; }
.form-section-head { display: flex; align-items: baseline; gap: 12px; padding-bottom: 14px; margin-bottom: 20px; border-bottom: 1px solid var(--line-soft); }
.form-section-num { font-size: 12px; font-weight: 700; letter-spacing: 0.06em; color: var(--green-bright); }
.form-section-title { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-grid .field { display: flex; flex-direction: column; gap: 7px; }
.field-span-2 { grid-column: 1 / -1; }
.field-block { display: flex; flex-direction: column; gap: 7px; }
.req { color: var(--error-fg); }
.opt { color: var(--soft, var(--muted)); font-weight: 400; font-size: 0.85em; }
fieldset { border: none; }
fieldset legend { font-size: 13.5px; font-weight: 600; margin-bottom: 14px; }
.check-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.check-chip { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border: 1px solid var(--line); border-radius: var(--radius); font-size: 13.5px; cursor: pointer; transition: border-color .15s, background .15s; }
.check-chip:hover { border-color: var(--sage); }
.check-chip:has(input:checked) { border-color: var(--green); background: var(--paper); }
.check-chip input { width: 16px; height: 16px; }
.form-footer { margin-top: 4px; }
.consent-row { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--muted); line-height: 1.55; margin-bottom: 6px; }
.consent-row a { color: var(--green-bright); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.step-actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 22px; }

/* toast */
.toast { position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 140%); z-index: 60; display: flex; align-items: center; gap: 10px; background: var(--green); color: var(--white); padding: 14px 20px; border-radius: 999px; font-size: 14px; font-weight: 600; box-shadow: 0 18px 50px rgba(0,42,30,0.3); transition: transform .35s ease; max-width: calc(100% - 40px); }
.toast.show { transform: translate(-50%, 0); }

/* ---------- Privacy / legal doc ---------- */
.doc { padding-top: calc(var(--header-h) + clamp(48px, 8vh, 92px)); padding-bottom: clamp(60px, 9vh, 110px); }
.doc .container { max-width: 760px; margin: 0 auto; }
.doc-label { font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-bright); }
.doc h1 { font-size: clamp(36px, 4.4vw, 56px); font-weight: 800; letter-spacing: -0.03em; margin-top: 14px; }
.doc-meta { color: var(--muted); font-size: 14px; margin-top: 14px; }
.doc hr { border: none; border-top: 1px solid var(--line); margin: 32px 0; }
.doc .section { margin-bottom: 34px; }
.doc .section h2 { font-size: 20px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 12px; }
.doc .section p { font-size: 16px; color: rgba(14,26,21,0.82); margin-bottom: 12px; line-height: 1.62; }
.doc .section ul { padding-left: 22px; margin-bottom: 12px; }
.doc .section li { font-size: 16px; color: rgba(14,26,21,0.82); margin-bottom: 8px; line-height: 1.55; }
.doc .section a { color: var(--green-bright); text-decoration: underline; text-underline-offset: 2px; font-weight: 600; }

/* ---------- Footer ---------- */
.site-footer { flex-shrink: 0; padding: 48px 0; border-top: 1px solid var(--line); }
.foot { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; font-size: 14px; color: var(--muted); }
.foot nav { display: flex; flex-wrap: wrap; gap: 22px; }
.foot a { color: var(--muted); text-decoration: none; }
.foot a:hover { color: var(--ink); }
.foot-legal { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line-soft); font-size: 12.5px; color: var(--muted); line-height: 1.55; max-width: 80ch; }

/* ---------- Reveal on scroll ---------- */
[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
[data-reveal].is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  .hero video { display: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .produce-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-bento { grid-template-columns: repeat(2, 1fr); }
  .svc-bento.uniform { grid-template-columns: repeat(2, 1fr); }
  .stage-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-tile.feature { grid-column: span 2; grid-row: span 1; }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-layout .intro { position: static; }
}
@media (max-width: 760px) {
  :root { --shell: calc(100% - 40px); }
  .nav-toggle { display: inline-flex; }
  .nav-links {
    position: absolute; top: 100%; left: 0; right: 0;
    display: none; flex-direction: column; align-items: stretch; gap: 0;
    background: rgba(244,242,234,0.98); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--line); box-shadow: 0 18px 44px rgba(0,42,30,0.14);
    padding: 8px 0; font-size: 15px;
  }
  .nav-links.is-open { display: flex; }
  .nav-links a { opacity: 1; padding: 14px 24px; border-bottom: 1px solid var(--line-soft); }
  .nav-links a:not(.btn):hover { background: var(--paper-2); }
  .nav-links .btn-primary { margin: 12px 24px 8px; padding: 14px; justify-content: center; border-radius: var(--radius); }
  .hero-creds .creds-grid { grid-template-columns: repeat(2, 1fr); row-gap: 22px; }
  .cred:nth-child(3) { border-left: none; padding-left: 0; }
  .svc-grid { grid-template-columns: 1fr; }
  .produce-grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; gap: 36px; }
  .step { border-left: none; padding-left: 0; }
  .aud { grid-template-columns: 1fr; gap: 0; }
  .cta { grid-template-columns: 1fr; }
  .sec-rule { flex-direction: column; align-items: flex-start; gap: 10px; }
  .sec-rule h2 { margin-left: 0; text-align: left; }
  .signal-row, .signal-row.cols-4 { grid-template-columns: 1fr 1fr; }
  .signal-row > div:nth-child(odd) { border-left: none; padding-left: 0; }
  .post-grid { grid-template-columns: 1fr; }
  .form-grid, .check-grid { grid-template-columns: 1fr; }
  .svc-detail-grid { grid-template-columns: 1fr; gap: 28px; }
  .svc-detail::before { display: none; }
  .svc-detail-side, .svc-detail:nth-child(even) .svc-detail-side { border-left: none; border-right: none; padding-left: 0; padding-right: 0; }
  .boundary-list { grid-template-columns: 1fr; gap: 28px; }
  .dual-list { grid-template-columns: 1fr; gap: 12px; }
  .lifecycle { grid-template-columns: repeat(3, 1fr); row-gap: 28px; }
  .life:nth-child(3n+1) { border-left: none; padding-left: 0; }
  .svc-bento { grid-template-columns: 1fr; }
  .svc-bento.uniform { grid-template-columns: 1fr; }
  .svc-tile.feature { grid-column: span 1; }
  .svc-detail:nth-child(even) .svc-detail-main,
  .svc-detail:nth-child(even) .svc-detail-side { order: 0; }
}
@media (max-width: 480px) {
  .stage-grid { grid-template-columns: 1fr; }
  .lifecycle { grid-template-columns: repeat(2, 1fr); }
  .life:nth-child(3n+1) { border-left: 1px solid var(--line-soft); padding-left: 16px; }
  .life:nth-child(odd) { border-left: none; padding-left: 0; }
}
/* (mobile navigation is handled by the burger menu in the 760px breakpoint) */
