﻿:root {
  --ink: #17263a;
  --muted: #65737e;
  --line: #e3e9e6;
  --green: #0f725c;
  --green-dark: #095344;
  --soft: #f4f7f2;
  --lime: #dceb75;
  --paper: #fff;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; line-height: 1.55; }
a { color: inherit; }
button, input, select, textarea { min-height: 44px; }
:focus-visible { outline: 3px solid rgba(15,114,92,.3); outline-offset: 2px; }
.about-header {
  height: 80px;
  padding: 0 max(28px, calc((100vw - 1160px) / 2));
  display: flex;
  align-items: center;
  gap: 40px;
  border-bottom: 1px solid var(--line);
  background: white;
}
.brand { display: flex; align-items: center; gap: 9px; font: 800 19px "Manrope", sans-serif; text-decoration: none; white-space: nowrap; }
.brand > span:last-child span { color: var(--green); }
.brand small { color: #8d9894; font-size: 13px; }
.brand-mark { width: 35px; height: 35px; position: relative; display: block; border-radius: 50%; background: var(--green); }
.brand-mark i { width: 7px; height: 7px; position: absolute; border: 2px solid white; border-radius: 50%; }
.brand-mark i:nth-child(1) { top: 8px; left: 8px; }
.brand-mark i:nth-child(2) { top: 8px; right: 8px; }
.brand-mark i:nth-child(3) { bottom: 8px; left: 13px; }
.about-header nav { margin-left: auto; display: flex; gap: 27px; }
.about-header nav a { color: #6b7872; font-size: 14px; font-weight: 600; text-decoration: none; }
.about-header nav a.active { color: var(--green); }
.header-cta { padding: 10px 14px; color: white; border-radius: 8px; background: var(--green); font-size: 13px; font-weight: 700; text-decoration: none; }
.header-cta span { margin-left: 5px; }
.about-hero {
  min-height: 510px;
  padding: 80px max(30px, calc((100vw - 1160px) / 2));
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  align-items: center;
  background: var(--soft);
}
.about-hero::before { content: ""; position: absolute; inset: 0; opacity: .18; background-image: radial-gradient(#6c8076 .7px, transparent .7px); background-size: 19px 19px; mask-image: linear-gradient(to right, transparent, black); }
.hero-copy { position: relative; z-index: 2; }
.eyebrow { color: var(--green); font-size: 13px; font-weight: 800; letter-spacing: 1.5px; }
.hero-copy h1 { max-width: 770px; margin: 18px 0; font: 800 clamp(38px, 5vw, 59px)/1.12 "Manrope", sans-serif; letter-spacing: -2.8px; }
.hero-copy > p { max-width: 680px; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.7; }
.hero-values { margin-top: 29px; display: flex; flex-wrap: wrap; gap: 11px; }
.hero-values span { padding: 7px 10px; color: #48675c; border: 1px solid #cfdbd4; border-radius: 20px; background: rgba(255,255,255,.65); font-size: 13px; font-weight: 600; }
.hero-mark { position: relative; z-index: 2; display: grid; place-items: center; }
.network { width: 270px; height: 270px; position: relative; display: grid; place-items: center; border: 1px solid rgba(15,114,92,.18); border-radius: 50%; box-shadow: 0 0 0 45px rgba(15,114,92,.045), 0 0 0 90px rgba(15,114,92,.025); }
.network span { width: 95px; height: 95px; display: grid; place-items: center; color: white; border-radius: 50%; background: var(--green); font: 800 25px "Manrope", sans-serif; box-shadow: 0 18px 40px rgba(15,114,92,.2); }
.network i { width: 22px; height: 22px; position: absolute; border: 5px solid white; border-radius: 50%; background: var(--lime); box-shadow: 0 5px 15px rgba(20,50,42,.12); }
.network i:nth-child(1) { top: 22px; left: 48px; }
.network i:nth-child(2) { top: 38px; right: 36px; background: #e69a6d; }
.network i:nth-child(3) { bottom: 33px; right: 55px; background: #7ca2b2; }
.network i:nth-child(4) { bottom: 50px; left: 30px; background: #b191b2; }
.page-wrap { width: min(1160px, calc(100% - 60px)); margin-inline: auto; }
.origin-section { padding-block: 100px; }
.section-label { margin-bottom: 28px; color: var(--green); font-size: 13px; font-weight: 800; letter-spacing: 1.4px; }
.origin-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; }
.origin-grid h2, .section-heading h2, .founder-copy h2, .vision-inner h2 { margin: 0; font: 800 33px/1.3 "Manrope", sans-serif; letter-spacing: -1.4px; }
.origin-copy p { margin: 0 0 17px; color: var(--muted); font-size: 13px; line-height: 1.8; }
.principles-section { padding-block: 88px; background: #f4f7f2; }
.section-heading { max-width: 650px; margin-bottom: 40px; }
.section-heading h2 { margin-top: 11px; }
.principles-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }
.principles-grid article { min-height: 230px; padding: 26px; border: 1px solid var(--line); border-radius: 14px; background: white; }
.principle-number { color: #bfcbc5; font: 800 25px "Manrope", sans-serif; }
.principles-grid h3 { margin: 25px 0 10px; font: 700 15px "Manrope", sans-serif; }
.principles-grid p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.7; }
.founder-section { padding-block: 105px; display: grid; grid-template-columns: .75fr 1.25fr; align-items: center; gap: 85px; }
.founder-photo-wrap { position: relative; }
.founder-photo-wrap img { width: 100%; max-height: 600px; position: relative; z-index: 2; display: block; object-fit: cover; object-position: center top; border-radius: 18px; box-shadow: 0 28px 70px rgba(25,50,45,.16); }
.photo-accent { position: absolute; inset: 35px -20px -20px 35px; border-radius: 18px; background: var(--green); }
.founder-badge { padding: 13px 17px; position: absolute; right: -25px; bottom: 35px; z-index: 3; color: white; border-radius: 10px; background: var(--green); box-shadow: 0 13px 30px rgba(15,114,92,.24); }
.founder-badge span, .founder-badge strong { display: block; }
.founder-badge span { color: rgba(255,255,255,.68); font-size: 15px; }
.founder-badge strong { margin-top: 3px; font-size: 14px; }
.founder-copy h2 { margin: 12px 0 6px; }
.founder-role { margin: 0 0 23px !important; color: var(--green) !important; font-weight: 700; }
.founder-copy > p { margin: 0 0 15px; color: var(--muted); font-size: 15px; line-height: 1.75; }
.founder-highlights { margin: 25px 0; display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.founder-highlights div { padding: 13px; border-radius: 9px; background: var(--soft); }
.founder-highlights strong, .founder-highlights span { display: block; }
.founder-highlights strong { color: var(--green); font-size: 14px; }
.founder-highlights span { margin-top: 4px; color: var(--muted); font-size: 12px; }
blockquote { margin: 24px 0 0; padding: 17px 20px; color: #43544d; border-left: 3px solid var(--green); background: #f4f8f5; font: 600 13px/1.7 "Manrope", sans-serif; }
.vision-section { padding-block: 90px; color: white; background: var(--green); text-align: center; }
.vision-inner { max-width: 810px; }
.eyebrow.light { color: #b9dbcb; }
.vision-inner h2 { margin: 15px 0 12px; font-size: 35px; }
.vision-inner p { margin: 0 auto 25px; max-width: 700px; color: rgba(255,255,255,.72); font-size: 15px; line-height: 1.7; }
.vision-inner > a { padding: 13px 18px; display: inline-block; color: var(--green); border-radius: 8px; background: white; font-size: 13px; font-weight: 700; text-decoration: none; }
.vision-inner > a span { margin-left: 6px; }
footer { min-height: 100px; padding: 25px max(28px,calc((100vw - 1160px)/2)); display: flex; align-items: center; gap: 35px; color: #89938e; border-top: 1px solid var(--line); }
.footer-brand { font-size: 15px; }
footer p { margin: 0; font-size: 13px; }
footer > div { margin-left: auto; display: flex; gap: 18px; }
footer > div a { font-size: 13px; text-decoration: none; }
@media(max-width:850px) {
  .about-header nav { display: none; }
  .header-cta { margin-left: auto; }
  .about-hero { grid-template-columns: 1fr; text-align: center; }
  .hero-copy > p { margin-inline: auto; }
  .hero-values { justify-content: center; }
  .hero-mark { margin-top: 75px; }
  .origin-grid, .founder-section { grid-template-columns: 1fr; gap: 45px; }
  .founder-photo-wrap { max-width: 480px; margin-inline: auto; }
  .principles-grid { grid-template-columns: 1fr; }
}
@media(max-width:560px) {
  .about-header { height: 70px; padding-inline: 16px; }
  .header-cta { padding: 9px 11px; }
  .about-hero { padding: 60px 18px 80px; }
  .hero-copy h1 { font-size: 37px; letter-spacing: -1.8px; }
  .hero-mark { transform: scale(.75); margin-block: 20px -25px; }
  .page-wrap { width: calc(100% - 32px); }
  .origin-section, .founder-section { padding-block: 70px; }
  .origin-grid h2, .section-heading h2, .founder-copy h2, .vision-inner h2 { font-size: 27px; }
  .founder-highlights { grid-template-columns: 1fr; }
  .founder-badge { right: -5px; }
  footer { align-items: flex-start; flex-direction: column; gap: 12px; }
  footer > div { margin-left: 0; }
}
