/* Awere Solutions Limited — Corporate Website Styles */

:root {
  --green: #1FA84C;
  --green-dark: #0F5A2A;
  --green-deep: #08361A;
  --green-leaf: #8DC63F;
  --green-50: #ECF7EE;
  --green-100: #D6EEDB;
  --orange: #F58220;
  --orange-dark: #D96A0C;
  --orange-50: #FEF2E5;
  --ink: #15201B;
  --ink-2: #2C3A33;
  --ink-3: #5A6A62;
  --line: #E5E1D6;
  --line-2: #EFECE3;
  --cream: #FAFAF6;
  --cream-2: #F3F0E6;
  --white: #FFFFFF;

  --radius: 14px;
  --radius-lg: 22px;
  --shadow-sm: 0 1px 2px rgba(15, 90, 42, 0.05), 0 2px 8px rgba(15, 90, 42, 0.04);
  --shadow-md: 0 8px 24px rgba(15, 90, 42, 0.08), 0 2px 6px rgba(15, 90, 42, 0.04);
  --shadow-lg: 0 20px 60px rgba(15, 90, 42, 0.12), 0 4px 12px rgba(15, 90, 42, 0.06);

  --font-sans: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif: 'Fraunces', 'Times New Roman', serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 28px;
}

/* ============ HEADER ============ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(250, 250, 246, 0.85);
  backdrop-filter: saturate(140%) blur(18px);
  -webkit-backdrop-filter: saturate(140%) blur(18px);
  border-bottom: 1px solid rgba(229, 225, 214, 0.6);
}
.site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 78px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.brand img {
  height: 46px;
  width: auto;
}
.brand-logo-only img {
  height: 72px;
}
.site-header-inner { height: 92px; }
@media (max-width: 960px) {
  .brand-logo-only img { height: 56px; }
  .site-header-inner { height: 78px; }
}
.footer-logo-img {
  background: rgba(255,255,255,0.96);
  padding: 10px 14px;
  border-radius: 10px;
  height: 64px !important;
  filter: none !important;
}
.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.brand-text .b1 {
  font-weight: 800;
  letter-spacing: 0.5px;
  font-size: 15px;
  color: var(--green-dark);
}
.brand-text .b2 {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
}
.nav {
  display: flex;
  align-items: center;
  gap: 36px;
}
.nav a {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink-2);
  position: relative;
  padding: 4px 0;
  transition: color 0.2s;
}
.nav a:hover { color: var(--green-dark); }
.nav a.active { color: var(--green-dark); }
.nav a.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 2px;
  background: var(--orange);
  border-radius: 2px;
}
.header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.menu-btn {
  display: none;
  width: 42px; height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--white);
}
.menu-btn svg { width: 20px; height: 20px; }

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14.5px;
  transition: all 0.2s ease;
  border: 1.5px solid transparent;
  white-space: nowrap;
}
.btn svg { width: 16px; height: 16px; }
.btn-primary {
  background: var(--orange);
  color: var(--white);
  box-shadow: 0 6px 18px rgba(245, 130, 32, 0.28);
}
.btn-primary:hover {
  background: var(--orange-dark);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(245, 130, 32, 0.35);
}
.btn-secondary {
  background: var(--green-dark);
  color: var(--white);
}
.btn-secondary:hover { background: var(--green-deep); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: var(--green-dark);
  border-color: var(--green-dark);
}
.btn-ghost:hover { background: var(--green-dark); color: var(--white); }
.btn-light {
  background: var(--white);
  color: var(--ink);
  border-color: var(--line);
}
.btn-light:hover { border-color: var(--green); color: var(--green-dark); }
.btn-lg { padding: 14px 26px; font-size: 15px; }

/* ============ HERO ============ */
.hero {
  position: relative;
  padding: 92px 0 80px;
  overflow: hidden;
}
.hero-home {
  background:
    radial-gradient(900px 600px at 88% -10%, rgba(245, 130, 32, 0.10), transparent 60%),
    radial-gradient(800px 500px at -8% 110%, rgba(31, 168, 76, 0.12), transparent 60%),
    var(--cream);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 64px;
  align-items: center;
}
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px 8px 10px;
  background: var(--white);
  border: 1.5px solid var(--line);
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--green-dark);
  box-shadow: 0 2px 16px rgba(15, 90, 42, 0.10), 0 1px 4px rgba(15, 90, 42, 0.06);
}
.eyebrow .dot {
  width: 9px; height: 9px;
  background: var(--orange);
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(245, 130, 32, 0.18);
  animation: pulse 2s infinite;
}
.eyebrow-sep {
  width: 1.5px;
  height: 14px;
  background: var(--line);
  border-radius: 2px;
  flex-shrink: 0;
}
.eyebrow .pill-label {
  background: var(--green-50);
  color: var(--green-dark);
  padding: 4px 11px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border: 1px solid var(--green-100);
}

h1.display {
  font-size: clamp(40px, 5.4vw, 70px);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.025em;
  margin: 20px 0 22px;
  color: var(--ink);
}
h1.display .accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
h1.display .ink-orange { color: var(--orange-dark); }

.hero-lede {
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink-3);
  max-width: 540px;
  margin: 0 0 32px;
}
.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 52px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  max-width: 560px;
}
.stat .n {
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--green-dark);
  line-height: 1;
}
.stat .l {
  font-size: 13px;
  color: var(--ink-3);
  margin-top: 6px;
  font-weight: 500;
}

/* Hero visual */
.hero-visual {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 28px;
  background: linear-gradient(150deg, var(--green-dark), var(--green) 60%, var(--green-leaf));
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.hero-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(141, 198, 63, 0.4), transparent 50%);
}
.hv-pattern {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.06) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.06) 0 1px, transparent 1px 80px);
}
.hv-leaf {
  position: absolute;
  top: -40px; right: -40px;
  width: 60%;
  aspect-ratio: 1;
  background: radial-gradient(circle at 30% 30%, var(--green-leaf), var(--green) 70%);
  border-radius: 50% 12% 50% 50%;
  transform: rotate(35deg);
  opacity: 0.7;
  filter: blur(2px);
}
.hv-badge {
  position: absolute;
  left: 28px; bottom: 28px;
  right: 28px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  border-radius: 18px;
  padding: 22px;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-items: center;
}
.hv-badge .ic {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--orange), #FFAC5C);
  display: flex; align-items: center; justify-content: center;
  color: white;
}
.hv-badge .ic svg { width: 28px; height: 28px; }
.hv-badge h4 { margin: 0 0 4px; font-size: 16px; font-weight: 700; color: var(--ink); }
.hv-badge p { margin: 0; font-size: 13px; color: var(--ink-3); }

.hv-chip {
  position: absolute;
  top: 28px; left: 28px;
  background: rgba(255, 255, 255, 0.95);
  padding: 10px 16px;
  border-radius: 999px;
  display: flex; align-items: center; gap: 10px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--green-deep);
  letter-spacing: 0.04em;
  box-shadow: var(--shadow-md);
}
.hv-chip::before {
  content: '';
  width: 8px; height: 8px;
  background: var(--orange);
  border-radius: 50%;
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245, 130, 32, 0.5); }
  50% { box-shadow: 0 0 0 8px rgba(245, 130, 32, 0); }
}

.hv-cards {
  position: absolute;
  bottom: 110px;
  left: 28px; right: 28px;
  display: flex;
  gap: 10px;
  flex-direction: column;
}
.hv-card {
  background: rgba(255, 255, 255, 0.92);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.hv-card .d {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: var(--green-50);
  display: flex; align-items: center; justify-content: center;
  color: var(--green-dark);
}
.hv-card .d svg { width: 16px; height: 16px; }
.hv-card.orange .d { background: var(--orange-50); color: var(--orange-dark); }

/* ============ SECTIONS ============ */
section { padding: 96px 0; }
.section-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 14px;
}
h2.section-title {
  font-size: clamp(30px, 3.6vw, 46px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.08;
  margin: 0 0 18px;
  max-width: 720px;
  color: var(--ink);
}
h2.section-title .accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.section-lede {
  font-size: 17px;
  color: var(--ink-3);
  max-width: 640px;
  margin: 0 0 56px;
}
.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.section-head > div:first-child { flex: 1; min-width: 280px; }
.section-head .section-lede { margin-bottom: 0; }

/* Who we are - alternating */
.alt-bg { background: var(--white); border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); }
.dark-bg { background: var(--green-deep); color: var(--white); }
.dark-bg h2.section-title { color: var(--white); }
.dark-bg h2.section-title .accent { color: var(--green-leaf); }
.dark-bg .section-lede { color: rgba(255,255,255,0.7); }
.dark-bg .section-eyebrow { color: var(--green-leaf); }

/* Cards */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cards-grid.two-col { grid-template-columns: repeat(2, 1fr); }

.svc-card {
  background: var(--white);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 32px 30px;
  display: flex;
  flex-direction: column;
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}
.svc-card:hover {
  border-color: var(--green-100);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.svc-card .ic-wrap {
  width: 56px; height: 56px;
  border-radius: 16px;
  background: var(--green-50);
  color: var(--green-dark);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 22px;
}
.svc-card .ic-wrap svg { width: 28px; height: 28px; }
.svc-card.orange .ic-wrap { background: var(--orange-50); color: var(--orange-dark); }
.svc-card h3 {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 10px;
  color: var(--ink);
}
.svc-card p {
  margin: 0 0 18px;
  color: var(--ink-3);
  font-size: 14.5px;
  line-height: 1.55;
}
.svc-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex; flex-direction: column;
  gap: 9px;
}
.svc-card ul li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
}
.svc-card ul li::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  margin-top: 8px;
  flex: 0 0 6px;
}
.svc-card.orange ul li::before { background: var(--orange); }

/* Who we are split */
.split-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.split-text h2 { margin-top: 0; }
.split-features {
  margin-top: 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.feature-mini {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.feature-mini .ic {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--green-50);
  color: var(--green-dark);
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 38px;
}
.feature-mini .ic svg { width: 18px; height: 18px; }
.feature-mini h4 { margin: 4px 0 2px; font-size: 14px; font-weight: 700; }
.feature-mini p { margin: 0; font-size: 13px; color: var(--ink-3); }

.split-visual {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--green-deep), var(--green-dark));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.placeholder-img {
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 14px);
}
.placeholder-img .label {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'JetBrains Mono', 'Courier New', monospace;
  color: rgba(255,255,255,0.35);
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* Stats band */
.stats-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--green-deep);
  color: var(--white);
  border-radius: var(--radius-lg);
  padding: 50px 24px;
  position: relative;
  overflow: hidden;
}
.stats-band::before {
  content: '';
  position: absolute;
  top: -40%; right: -10%;
  width: 60%; height: 200%;
  background: radial-gradient(circle, rgba(141, 198, 63, 0.15), transparent 60%);
}
.stats-band .stat-block {
  text-align: center;
  padding: 0 16px;
  border-right: 1px solid rgba(255,255,255,0.08);
  position: relative;
}
.stats-band .stat-block:last-child { border-right: 0; }
.stats-band .n {
  font-size: clamp(36px, 4vw, 54px);
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, var(--white) 30%, var(--green-leaf));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}
.stats-band .l {
  font-size: 14px;
  margin-top: 12px;
  color: rgba(255,255,255,0.7);
  font-weight: 500;
}

/* Why partner */
.why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr) 1.4fr;
  gap: 24px;
}
.why-card {
  background: var(--white);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 34px 30px;
  position: relative;
  overflow: hidden;
}
.why-card .num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 36px;
  color: var(--green-leaf);
  letter-spacing: -0.02em;
}
.why-card h3 {
  margin: 16px 0 10px;
  font-size: 19px;
  font-weight: 700;
  color: var(--ink);
}
.why-card p {
  margin: 0;
  color: var(--ink-3);
  font-size: 14.5px;
}
.why-card.feature {
  background: linear-gradient(160deg, var(--green-deep), var(--green-dark));
  color: var(--white);
  grid-row: span 2;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.why-card.feature .num { color: var(--orange); }
.why-card.feature h3 { color: var(--white); font-size: 26px; line-height: 1.18; }
.why-card.feature p { color: rgba(255,255,255,0.7); margin-bottom: 24px; }
.why-card.feature .ic-big {
  width: 80px; height: 80px;
  border-radius: 20px;
  background: rgba(245, 130, 32, 0.15);
  display: flex; align-items: center; justify-content: center;
  color: var(--orange);
}
.why-card.feature .ic-big svg { width: 36px; height: 36px; }

/* CTA band */
.cta-band {
  border-radius: var(--radius-lg);
  padding: 64px 56px;
  background: linear-gradient(135deg, var(--green-deep), var(--green-dark) 55%, var(--green));
  color: var(--white);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: '';
  position: absolute;
  top: -50%; right: -10%;
  width: 50%; height: 200%;
  background: radial-gradient(circle, rgba(245, 130, 32, 0.18), transparent 60%);
}
.cta-band h2 {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 800;
  margin: 0 0 14px;
  letter-spacing: -0.02em;
}
.cta-band h2 .accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-leaf);
}
.cta-band p { margin: 0; color: rgba(255,255,255,0.8); font-size: 17px; max-width: 480px; }
.cta-band .actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

/* ============ ABOUT PAGE ============ */
.founders-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.founder-card {
  background: var(--white);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  grid-template-columns: 160px 1fr;
}
.founder-photo {
  aspect-ratio: 1;
  background: linear-gradient(150deg, var(--green-dark), var(--green-deep));
  position: relative;
  display: flex; align-items: center; justify-content: center;
  color: var(--green-leaf);
  font-family: var(--font-serif);
  font-size: 56px;
  font-style: italic;
}
.founder-info {
  padding: 28px 28px 28px 26px;
}
.founder-info .role {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 8px;
}
.founder-info h3 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.founder-info p {
  margin: 0;
  font-size: 14px;
  color: var(--ink-3);
  line-height: 1.6;
}
.founder-info .links {
  display: flex; gap: 10px; margin-top: 16px;
}
.founder-info .links a {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--green-50);
  display: flex; align-items: center; justify-content: center;
  color: var(--green-dark);
  transition: all 0.2s;
}
.founder-info .links a:hover { background: var(--green-dark); color: var(--white); }
.founder-info .links svg { width: 16px; height: 16px; }
.founder-photo--img {
  background: var(--green-50);
  font-size: 0;
  aspect-ratio: unset;  /* override the 1:1 lock so it stretches to card height */
  align-self: stretch;
}
.founder-photo--img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* Mission/vision */
.mv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.mv-card {
  padding: 44px 40px;
  border-radius: var(--radius-lg);
  background: var(--white);
  border: 1px solid var(--line-2);
  position: relative;
  overflow: hidden;
}
.mv-card.dark {
  background: linear-gradient(155deg, var(--green-deep), var(--green-dark));
  color: var(--white);
  border-color: transparent;
}
.mv-card .tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 18px;
}
.mv-card.dark .tag { color: var(--green-leaf); }
.mv-card .tag::before { content: ''; width: 20px; height: 2px; background: currentColor; }
.mv-card h3 {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(28px, 2.8vw, 38px);
  line-height: 1.15;
  margin: 0 0 18px;
  letter-spacing: -0.01em;
}
.mv-card.dark h3 { color: var(--white); }
.mv-card p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-3);
  margin: 0;
}
.mv-card.dark p { color: rgba(255,255,255,0.78); }

/* Timeline */
.timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.timeline::before {
  content: '';
  position: absolute;
  top: 50px; left: 0; right: 0;
  height: 2px;
  background: var(--line);
}
.tl-item {
  position: relative;
  padding-right: 32px;
}
.tl-item .year {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 32px;
  font-weight: 400;
  color: var(--green-dark);
  letter-spacing: -0.01em;
  margin-bottom: 12px;
}
.tl-item .dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--orange);
  border: 3px solid var(--cream);
  margin-bottom: 24px;
  box-shadow: 0 0 0 2px var(--orange);
}
.tl-item.active .dot { background: var(--green); box-shadow: 0 0 0 2px var(--green); }
.tl-item h4 {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--ink);
}
.tl-item p {
  font-size: 13.5px;
  color: var(--ink-3);
  margin: 0;
  line-height: 1.55;
}
.dark-bg .timeline::before { background: rgba(255,255,255,0.12); }
.dark-bg .tl-item h4 { color: var(--white); }
.dark-bg .tl-item p { color: rgba(255,255,255,0.65); }
.dark-bg .tl-item .year { color: var(--green-leaf); }
.dark-bg .tl-item .dot { border-color: var(--green-deep); }

/* Partners */
.partners-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
}
.partner {
  aspect-ratio: 5/3;
  display: flex; align-items: center; justify-content: center;
  border-right: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
  padding: 24px;
  color: var(--ink-3);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-align: center;
  transition: all 0.2s;
}
.partner:hover { color: var(--green-dark); background: var(--cream); }
.partner:nth-child(6n) { border-right: 0; }
.partner:nth-last-child(-n+6) { border-bottom: 0; }

/* Values pillars */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.pillar {
  background: var(--white);
  border: 1px solid var(--line-2);
  border-radius: var(--radius);
  padding: 28px 24px;
}
.pillar .ic {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--green-50);
  color: var(--green-dark);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.pillar .ic svg { width: 22px; height: 22px; }
.pillar h4 {
  font-size: 17px; font-weight: 700;
  margin: 0 0 8px;
  color: var(--ink);
}
.pillar p {
  font-size: 14px;
  color: var(--ink-3);
  margin: 0;
  line-height: 1.55;
}

/* ============ SERVICES PAGE ============ */
.service-section {
  padding: 80px 0;
}
.svc-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 40px;
  margin-bottom: 48px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.svc-header-text { flex: 1; min-width: 320px; }
.svc-header-text .section-eyebrow { margin-bottom: 10px; }
.svc-header-text h2 {
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0;
  max-width: 600px;
}
.svc-header-text h2 .accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.svc-header-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 84px;
  line-height: 1;
  color: var(--green-leaf);
  letter-spacing: -0.03em;
}

/* ============ CONTACT ============ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 56px;
  align-items: flex-start;
}
.contact-info-card {
  background: linear-gradient(160deg, var(--green-deep), var(--green-dark));
  color: var(--white);
  border-radius: var(--radius-lg);
  padding: 48px 40px;
  position: relative;
  overflow: hidden;
}
.contact-info-card::before {
  content: '';
  position: absolute;
  bottom: -60%; right: -20%;
  width: 80%; aspect-ratio: 1;
  background: radial-gradient(circle, rgba(141, 198, 63, 0.15), transparent 60%);
}
.contact-info-card h3 {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.contact-info-card .desc {
  color: rgba(255,255,255,0.75);
  font-size: 15px;
  margin: 0 0 36px;
  line-height: 1.6;
}
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
  position: relative;
}
.contact-detail .ic {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: rgba(245, 130, 32, 0.15);
  color: var(--orange);
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 40px;
}
.contact-detail .ic svg { width: 18px; height: 18px; }
.contact-detail .label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--green-leaf);
  margin-bottom: 4px;
}
.contact-detail .value {
  font-size: 15px;
  color: var(--white);
  font-weight: 600;
  line-height: 1.45;
}
.contact-social {
  display: flex;
  gap: 10px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.contact-social a {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: center;
  color: var(--white);
  transition: all 0.2s;
}
.contact-social a:hover { background: var(--orange); }
.contact-social svg { width: 18px; height: 18px; }

.contact-form-card {
  background: var(--white);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 48px 40px;
}
.contact-form-card h3 {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.contact-form-card .sub {
  color: var(--ink-3);
  font-size: 15px;
  margin: 0 0 32px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.field { margin-bottom: 16px; display: flex; flex-direction: column; }
.field label {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--ink-2);
}
.field label .req { color: var(--orange); }
.field input, .field textarea, .field select {
  font: inherit;
  padding: 13px 16px;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  background: var(--cream);
  color: var(--ink);
  transition: all 0.2s;
  font-size: 14.5px;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--green);
  background: var(--white);
  box-shadow: 0 0 0 4px rgba(31, 168, 76, 0.1);
}
.field.error input, .field.error textarea, .field.error select { border-color: #DC2626; }
.field .err-text {
  font-size: 12px;
  color: #DC2626;
  margin-top: 6px;
}
.field textarea { resize: vertical; min-height: 120px; }
.form-success {
  background: var(--green-50);
  border: 1px solid var(--green-100);
  color: var(--green-deep);
  padding: 16px 20px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: 14.5px;
  margin-bottom: 20px;
}
.form-success svg { width: 22px; height: 22px; color: var(--green); flex: 0 0 22px; }

/* Map */
.map-card {
  margin-top: 56px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--white);
}
.map-frame {
  aspect-ratio: 21/8;
  background:
    linear-gradient(135deg, var(--green-50), var(--cream-2));
  position: relative;
  overflow: hidden;
}
.map-pattern {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(15, 90, 42, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 90, 42, 0.06) 1px, transparent 1px);
  background-size: 40px 40px;
}
.map-pin {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -100%);
  display: flex; flex-direction: column; align-items: center;
}
.map-pin .pin-dot {
  width: 60px; height: 60px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  background: var(--orange);
  box-shadow: 0 6px 20px rgba(245, 130, 32, 0.4);
  display: flex; align-items: center; justify-content: center;
}
.map-pin .pin-dot::after {
  content: '';
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--white);
  transform: rotate(45deg);
}
.map-pin .pin-label {
  margin-top: 12px;
  background: var(--white);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  box-shadow: var(--shadow-md);
  white-space: nowrap;
}

/* ============ FOOTER ============ */
.site-footer {
  background: var(--green-deep);
  color: rgba(255,255,255,0.7);
  padding: 80px 0 30px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 56px;
  margin-bottom: 56px;
}
.footer-brand img { height: 56px; width: auto; margin-bottom: 20px; }
.footer-brand p {
  font-size: 14.5px;
  line-height: 1.6;
  max-width: 320px;
  margin: 0 0 24px;
}
.footer-col h5 {
  color: var(--white);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin: 0 0 22px;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.footer-col ul li a {
  font-size: 14.5px;
  transition: color 0.2s;
}
.footer-col ul li a:hover { color: var(--green-leaf); }
.footer-col .contact-item {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 14px; line-height: 1.5;
  margin-bottom: 12px;
}
.footer-col .contact-item svg { width: 16px; height: 16px; margin-top: 3px; color: var(--orange); flex: 0 0 16px; }
.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 13px;
  flex-wrap: wrap;
  gap: 16px;
}
.footer-socials { display: flex; gap: 8px; }
.footer-socials a {
  width: 34px; height: 34px;
  border-radius: 8px;
  background: rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: center;
  color: var(--white);
  transition: all 0.2s;
}
.footer-socials a:hover { background: var(--orange); }
.footer-socials svg { width: 16px; height: 16px; }

/* Newsletter mini */
.newsletter-mini {
  display: flex;
  background: rgba(255,255,255,0.08);
  border-radius: 999px;
  padding: 4px;
  max-width: 300px;
  margin-top: 12px;
}
.newsletter-mini input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: none;
  color: var(--white);
  padding: 8px 14px;
  font: inherit;
  font-size: 13px;
}
.newsletter-mini input::placeholder { color: rgba(255,255,255,0.5); }
.newsletter-mini button {
  background: var(--orange);
  color: var(--white);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 12.5px;
  font-weight: 700;
}

/* Page hero (smaller variant) */
.page-hero {
  padding: 100px 0 70px;
  background:
    radial-gradient(900px 500px at 90% -10%, rgba(245, 130, 32, 0.08), transparent 60%),
    radial-gradient(700px 400px at -10% 110%, rgba(31, 168, 76, 0.10), transparent 60%),
    var(--cream);
  border-bottom: 1px solid var(--line-2);
}
.page-hero .crumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px;
  color: var(--ink-3);
  margin-bottom: 18px;
}
.page-hero .crumb a:hover { color: var(--green-dark); }
.page-hero .crumb svg { width: 14px; height: 14px; opacity: 0.5; }
.page-hero h1 {
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 0 0 22px;
  max-width: 800px;
}
.page-hero h1 .accent {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.page-hero .lede {
  font-size: 18px;
  color: var(--ink-3);
  max-width: 640px;
  margin: 0;
  line-height: 1.55;
}

/* Quote modal */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 32, 27, 0.6);
  backdrop-filter: blur(4px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: fadeIn 0.2s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.modal {
  background: var(--cream);
  border-radius: var(--radius-lg);
  max-width: 580px;
  width: 100%;
  padding: 40px;
  position: relative;
  animation: slideUp 0.25s ease;
  max-height: 90vh;
  overflow-y: auto;
}
.modal-close {
  position: absolute;
  top: 18px; right: 18px;
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--white);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
}
.modal-close:hover { background: var(--line); }
.modal-close svg { width: 16px; height: 16px; }
.modal h3 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.modal .sub {
  color: var(--ink-3);
  margin: 0 0 28px;
  font-size: 15px;
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--cream);
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  animation: fadeIn 0.2s ease;
}
.mobile-menu-head {
  display: flex; align-items: center; justify-content: space-between;
  height: 78px;
}
.mobile-menu nav {
  display: flex; flex-direction: column;
  margin-top: 20px;
  gap: 8px;
}
.mobile-menu nav a {
  font-size: 24px;
  font-weight: 700;
  padding: 14px 0;
  border-bottom: 1px solid var(--line-2);
  color: var(--ink);
}
.mobile-menu nav a.active { color: var(--green-dark); }
.mobile-menu .mob-cta { margin-top: 24px; }

/* Float scroll-top */
.scroll-top {
  position: fixed;
  bottom: 28px; right: 28px;
  width: 48px; height: 48px;
  background: var(--green-dark);
  color: var(--white);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-lg);
  z-index: 90;
  transition: all 0.2s;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
}
.scroll-top.show { opacity: 1; pointer-events: auto; transform: translateY(0); }
.scroll-top:hover { background: var(--green-deep); transform: translateY(-4px); }
.scroll-top svg { width: 18px; height: 18px; }

/* Fade-in animation for route transitions */
.page-enter {
  animation: pageIn 0.4s ease;
}
@keyframes pageIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============ PARTNER MARQUEE ============ */
.marquee {
  position: relative;
  overflow: hidden;
  padding: 56px 0;
  background: var(--white);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee 38s linear infinite;
  gap: 72px;
  align-items: center;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-item {
  flex: 0 0 auto;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  filter: grayscale(0.15);
  opacity: 0.9;
  transition: all 0.25s;
}
.marquee-item:hover { filter: grayscale(0); opacity: 1; }
.marquee-item img { height: 100%; width: auto; max-width: 280px; object-fit: contain; }
.marquee::before, .marquee::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 120px;
  z-index: 2;
  pointer-events: none;
}
.marquee::before { left: 0; background: linear-gradient(90deg, var(--white), transparent); }
.marquee::after { right: 0; background: linear-gradient(270deg, var(--white), transparent); }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (max-width: 640px) {
  .marquee-item { height: 90px; }
  .marquee-track { gap: 56px; animation-duration: 30s; }
}

/* ============ HOME SLIDER ============ */
.slider-section {
  padding: 80px 0 96px;
}
.slider {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--green-deep);
  aspect-ratio: 21/9;
  box-shadow: var(--shadow-lg);
}
.slider-track {
  position: absolute;
  inset: 0;
  display: flex;
  transition: transform 0.7s cubic-bezier(0.65, 0, 0.35, 1);
}
.slider-slide {
  flex: 0 0 100%;
  position: relative;
  overflow: hidden;
}
.slider-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.slider-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 54, 26, 0) 30%, rgba(8, 54, 26, 0.75) 100%);
}
.slide-caption {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 40px 56px;
  color: var(--white);
  z-index: 2;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
}
.slide-caption .tag {
  display: inline-block;
  background: var(--orange);
  color: var(--white);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  margin-bottom: 14px;
}
.slide-caption h3 {
  font-size: clamp(24px, 3vw, 38px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
  max-width: 560px;
  line-height: 1.1;
}
.slide-caption p {
  margin: 0;
  font-size: 15px;
  color: rgba(255,255,255,0.85);
  max-width: 520px;
}
.slide-counter {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 48px;
  line-height: 1;
  color: rgba(255,255,255,0.9);
  letter-spacing: -0.02em;
}
.slider-controls {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  width: 100%;
  padding: 0 24px;
  pointer-events: none;
  z-index: 3;
}
.slider-btn {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  color: var(--green-deep);
  display: flex; align-items: center; justify-content: center;
  pointer-events: auto;
  transition: all 0.2s;
  box-shadow: var(--shadow-md);
}
.slider-btn:hover { background: var(--orange); color: var(--white); }
.slider-btn svg { width: 20px; height: 20px; }
.slider-dots {
  position: absolute;
  top: 24px; right: 24px;
  display: flex;
  gap: 8px;
  z-index: 3;
}
.slider-dot {
  width: 24px; height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.35);
  transition: all 0.3s;
}
.slider-dot.active { background: var(--orange); width: 36px; }

/* ============ GALLERY PAGE (refined) ============ */
.gallery-hero {
  position: relative;
  padding: 100px 0 60px;
  background: linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
  overflow: hidden;
}
.gallery-hero .crumb { margin-bottom: 28px; }
.gallery-hero h1 {
  font-size: clamp(40px, 6vw, 76px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 8px 0 24px;
  color: var(--ink);
  max-width: 14ch;
}
.gallery-hero h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.gallery-hero .lede {
  font-size: 18px;
  color: var(--ink-2);
  max-width: 60ch;
  line-height: 1.6;
}
.gallery-meta {
  display: flex;
  gap: 56px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.gallery-meta-item .num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 44px;
  line-height: 1;
  color: var(--orange);
  display: block;
  margin-bottom: 6px;
}
.gallery-meta-item .lbl {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.gallery-toolbar {
  position: sticky;
  top: 76px;
  z-index: 50;
  background: rgba(248, 245, 239, 0.92);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
  margin-bottom: 48px;
  padding: 18px 0;
}
.gallery-toolbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.gallery-filter {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin: 0;
}
.gallery-filter button {
  padding: 9px 16px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--ink-2);
  font-size: 13.5px;
  font-weight: 600;
  white-space: nowrap;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.gallery-filter button .count {
  font-size: 11px;
  font-weight: 700;
  background: var(--line);
  color: var(--ink-3);
  padding: 2px 7px;
  border-radius: 999px;
  transition: all 0.2s;
}
.gallery-filter button:hover { background: var(--white); color: var(--green-dark); }
.gallery-filter button.active { background: var(--green-dark); color: var(--white); }
.gallery-filter button.active .count { background: rgba(255,255,255,0.18); color: var(--white); }
.gallery-count { font-size: 13px; font-weight: 600; color: var(--ink-3); white-space: nowrap; }
.gallery-count strong { color: var(--ink); font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 17px; margin-right: 4px; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 130px;
  gap: 12px;
  margin-bottom: 96px;
}
.gallery-item {
  position: relative;
  grid-column: span 2;
  grid-row: span 2;
  border-radius: 16px;
  overflow: hidden;
  cursor: zoom-in;
  background: var(--cream-2);
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.35s;
  opacity: 0;
  transform: translateY(20px);
  animation: tileIn 0.55s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}
.gallery-item.tall { grid-row: span 3; }
.gallery-item.wide { grid-column: span 3; }
.gallery-item.big  { grid-column: span 3; grid-row: span 3; }
.gallery-item.hero { grid-column: span 4; grid-row: span 3; }
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.gallery-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 54, 26, 0) 40%, rgba(8, 54, 26, 0.92));
  opacity: 0;
  transition: opacity 0.3s;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px 20px;
  color: var(--white);
}
.gallery-item:hover .overlay { opacity: 1; }
.gallery-item .cap-cat {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 4px;
}
.gallery-item .cap-lbl { font-size: 14.5px; font-weight: 600; line-height: 1.3; }
.gallery-item .zoom-icon {
  position: absolute;
  top: 14px; right: 14px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.95);
  color: var(--green-deep);
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transform: scale(0.8);
  transition: all 0.25s;
}
.gallery-item:hover .zoom-icon { opacity: 1; transform: scale(1); }
.gallery-item .zoom-icon svg { width: 14px; height: 14px; }
@keyframes tileIn { to { opacity: 1; transform: translateY(0); } }

/* Improved Lightbox */
.lightbox {
  position: fixed; inset: 0;
  background: rgba(8, 30, 16, 0.96);
  backdrop-filter: blur(12px);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 24px 100px;
  animation: fadeIn 0.25s ease;
}
.lightbox-img {
  max-width: 88vw;
  max-height: 78vh;
  border-radius: 12px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.6);
  animation: slideUp 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.lightbox-topbar {
  position: absolute;
  top: 0; left: 0; right: 0;
  padding: 24px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--white);
}
.lightbox-meta { display: flex; align-items: center; gap: 14px; }
.lightbox-meta .tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--orange);
  padding: 6px 12px;
  border: 1px solid var(--orange);
  border-radius: 999px;
}
.lightbox-meta .lbl { font-size: 15px; font-weight: 600; color: rgba(255,255,255,0.95); }
.lightbox-close {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.lightbox-close:hover { background: var(--orange); transform: rotate(90deg); }
.lightbox-nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.lightbox-nav:hover { background: var(--orange); }
.lightbox-nav.prev { left: 32px; }
.lightbox-nav.next { right: 32px; }
.lightbox-nav svg, .lightbox-close svg { width: 20px; height: 20px; }
.lightbox-counter {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.7);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.2em;
}
.lightbox-counter strong {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  color: var(--white);
  letter-spacing: 0;
  margin-right: 6px;
}

/* Real partner logos */
.partners-real {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
}
.partner-real {
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  padding: 16px 20px;
  border-right: 1px solid var(--line-2);
  filter: grayscale(0.2);
  opacity: 0.9;
  transition: all 0.25s;
}
.partner-real:last-child { border-right: 0; }
.partner-real:hover { filter: grayscale(0); opacity: 1; transform: scale(1.05); }
.partner-real img { max-width: 100%; max-height: 88%; object-fit: contain; }

@media (max-width: 960px) {
  .gallery-grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 100px; }
  .gallery-item, .gallery-item.tall, .gallery-item.wide, .gallery-item.big, .gallery-item.hero { grid-column: span 2; grid-row: span 2; }
  .gallery-item.wide, .gallery-item.hero { grid-column: span 4; }
  .gallery-item.tall { grid-row: span 3; }
  .gallery-toolbar { top: 64px; }
  .gallery-toolbar-inner { flex-direction: column; align-items: flex-start; }
  .gallery-meta { gap: 32px; }
  .lightbox-nav.prev { left: 12px; }
  .lightbox-nav.next { right: 12px; }
  .slider { aspect-ratio: 4/3; }
  .slide-caption { padding: 24px; flex-direction: column; align-items: flex-start; }
  .slide-counter { font-size: 32px; }
  .partners-real { grid-template-columns: repeat(3, 1fr); }
  .partner-real { border-right: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); }
  .partner-real:nth-child(3n) { border-right: 0; }
}
@media (max-width: 560px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 90px; gap: 8px; }
  .gallery-item, .gallery-item.tall, .gallery-item.wide, .gallery-item.big, .gallery-item.hero { grid-column: span 2; grid-row: span 2; }
  .gallery-item.tall { grid-row: span 3; }
  .partners-real { grid-template-columns: repeat(2, 1fr); }
  .partner-real:nth-child(3n) { border-right: 1px solid var(--line-2); }
  .partner-real:nth-child(2n) { border-right: 0; }
}

/* ============ RESPONSIVE ============ */
@media (max-width: 960px) {
  .nav { display: none; }
  .menu-btn { display: flex; }
  .hero { padding: 60px 0 70px; }
  .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .hero-visual { aspect-ratio: 4/3; }
  .hero-stats { grid-template-columns: repeat(3, 1fr); max-width: 100%; }
  section { padding: 70px 0; }
  .cards-grid { grid-template-columns: 1fr; }
  .cards-grid.two-col { grid-template-columns: 1fr; }
  .split-grid { grid-template-columns: 1fr; gap: 40px; }
  .stats-band { grid-template-columns: 1fr 1fr; padding: 36px 16px; gap: 30px 0; }
  .stats-band .stat-block:nth-child(2) { border-right: 0; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .why-card.feature { grid-row: span 2; grid-column: span 2; }
  .cta-band { grid-template-columns: 1fr; padding: 44px 32px; }
  .cta-band .actions { justify-content: flex-start; }
  .founders-grid { grid-template-columns: 1fr; }
  .mv-grid { grid-template-columns: 1fr; }
  .timeline { grid-template-columns: 1fr 1fr; gap: 32px 24px; }
  .timeline::before { display: none; }
  .partners-grid { grid-template-columns: repeat(3, 1fr); }
  .partner { border-right: 1px solid var(--line-2) !important; border-bottom: 1px solid var(--line-2) !important; }
  .partner:nth-child(3n) { border-right: 0 !important; }
  .pillars-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .form-row { grid-template-columns: 1fr; }
  .svc-header-num { font-size: 56px; }
  .modal { padding: 28px; }
  .brand-text .b1 { font-size: 13px; }
  .brand-text .b2 { font-size: 10px; }
}
@media (max-width: 560px) {
  .why-grid { grid-template-columns: 1fr; }
  .why-card.feature { grid-column: span 1; grid-row: auto; }
  .partners-grid { grid-template-columns: 1fr 1fr; }
  .partner:nth-child(3n) { border-right: 1px solid var(--line-2) !important; }
  .partner:nth-child(2n) { border-right: 0 !important; }
  .pillars-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
  .timeline { grid-template-columns: 1fr; }
  .founder-card { grid-template-columns: 110px 1fr; }
  .founder-photo { font-size: 36px; }
  .hero-stats { gap: 16px; }
  .stat .n { font-size: 28px; }
}

/* ============ WORDPRESS ADDITIONS ============ */
.mobile-menu { display: none; }
.mobile-menu.is-open { display: flex; }
.modal-overlay { display: none; }
.modal-overlay.is-open { display: flex; }
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 0; top: 0; z-index: 9999; padding: 12px 16px; background: var(--green-dark); color: var(--white); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ── Hero visual — real photo ── */
.hv-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  z-index: 0;
}
.hv-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(8, 54, 26, 0.45) 0%,
    rgba(8, 54, 26, 0.10) 45%,
    rgba(8, 54, 26, 0.70) 100%
  );
  z-index: 1;
}
.hv-chip  { z-index: 2; }
.hv-badge { z-index: 2; }

/* ── Split visual — enhanced photo treatment ── */
.sv-enhanced {
  background: var(--green-deep);
}
.sv-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  display: block;
  transition: transform 0.6s ease;
}
.sv-enhanced:hover .sv-photo { transform: scale(1.04); }
.sv-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(8, 54, 26, 0.88) 0%,
    rgba(8, 54, 26, 0.30) 45%,
    rgba(8, 54, 26, 0.05) 100%
  );
  z-index: 1;
}
.sv-badge {
  position: absolute;
  bottom: 22px;
  left: 22px;
  right: 22px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 13px;
  background: rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 12px;
  padding: 14px 16px;
}
.sv-badge-ic {
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: rgba(245, 130, 32, 0.22);
  border: 1px solid rgba(245, 130, 32, 0.30);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--orange);
  flex-shrink: 0;
}
.sv-badge-ic svg { width: 18px; height: 18px; }
.sv-badge-label {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.50);
  margin-bottom: 3px;
}
.sv-badge-val {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--white);
  line-height: 1.3;
}

/* ── Gallery Hero V2 — dual opposing carousels ── */
.gallery-hero-v2 {
  padding: 104px 0 0;
  background: var(--cream);
  overflow: hidden;
}
.ghv2-text {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
  padding: 0 28px 64px;
}
.ghv2-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-dark);
  margin-bottom: 22px;
}
.ghv2-eyebrow::before,
.ghv2-eyebrow::after {
  content: '';
  display: block;
  width: 28px;
  height: 1.5px;
  background: var(--green);
  border-radius: 2px;
}
.ghv2-text h1 {
  font-size: clamp(44px, 6vw, 80px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin: 0 0 24px;
  color: var(--ink);
}
.ghv2-text h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.ghv2-text p {
  font-size: 17px;
  color: var(--ink-3);
  line-height: 1.6;
  margin: 0;
}
.ghv2-carousels {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.ghv2-carousels::before,
.ghv2-carousels::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 280px;
  z-index: 10;
  pointer-events: none;
}
.ghv2-carousels::before {
  left: 0;
  background: linear-gradient(to right, var(--cream) 0%, transparent 100%);
}
.ghv2-carousels::after {
  right: 0;
  background: linear-gradient(to left, var(--cream) 0%, transparent 100%);
}
.ghv2-row {
  display: flex;
  gap: 12px;
  width: max-content;
  will-change: transform;
}
.ghv2-row-1 { animation: ghv2-left 52s linear infinite; }
.ghv2-row-2 { animation: ghv2-right 60s linear infinite; }
@keyframes ghv2-left {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes ghv2-right {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}
.ghv2-item {
  flex: 0 0 auto;
  width: 268px;
  height: 190px;
  border-radius: 14px;
  overflow: hidden;
}
.ghv2-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.ghv2-carousels:hover .ghv2-row { animation-play-state: paused; }
.ghv2-item:hover img { transform: scale(1.05); }

/* ── About Hero V2 — dark full-bleed with stats ── */
.about-hero-v2 {
  position: relative;
  padding: 120px 0 96px;
  background: var(--green-deep);
  overflow: hidden;
}
.about-hero-v2::before {
  content: '';
  position: absolute;
  top: -40%;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 130%;
  background: radial-gradient(ellipse at center, rgba(141,198,63,0.10) 0%, transparent 65%);
  pointer-events: none;
}
.about-hero-v2::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}
.about-hero-inner {
  position: relative;
  z-index: 2;
  text-align: center;
}
.about-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-leaf);
  margin-bottom: 28px;
}
.about-hero-eyebrow .dot {
  width: 8px;
  height: 8px;
  background: var(--green-leaf);
  border-radius: 50%;
  animation: pulse 2s infinite;
  box-shadow: 0 0 0 3px rgba(141,198,63,0.2);
}
.about-hero-inner h1 {
  font-size: clamp(40px, 5.5vw, 72px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--white);
  margin: 0 0 24px;
}
.about-hero-inner h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-leaf);
}
.about-hero-inner > p {
  font-size: 18px;
  color: rgba(255,255,255,0.65);
  max-width: 640px;
  margin: 0 auto 56px;
  line-height: 1.65;
}
.about-hero-stats {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.ahs-chip {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 22px 32px;
  text-align: center;
  min-width: 140px;
}
.ahs-chip .n {
  display: block;
  font-size: 40px;
  font-weight: 800;
  color: var(--white);
  letter-spacing: -0.02em;
  line-height: 1;
}
.ahs-chip .l {
  display: block;
  font-size: 11px;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-top: 8px;
}

/* ── Services Hero V2 — anchored tab strips ── */
.services-hero-v2 {
  position: relative;
  background: var(--cream);
  overflow: hidden;
  padding: 96px 0 0;
}
.services-hero-v2::before {
  content: '3';
  position: absolute;
  right: -1%;
  top: 50%;
  transform: translateY(-55%);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 320px;
  line-height: 1;
  color: rgba(31,168,76,0.04);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.shv2-inner {
  position: relative;
  z-index: 1;
  max-width: 700px;
  padding-bottom: 56px;
}
.shv2-inner .section-eyebrow { margin-bottom: 20px; }
.shv2-inner h1 {
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 22px;
  color: var(--ink);
}
.shv2-inner h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.shv2-lede {
  font-size: 17px;
  color: var(--ink-3);
  line-height: 1.6;
  margin: 0;
  max-width: 560px;
}
.shv2-tabs {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
}
.shv2-tab {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px 24px 36px;
  border-right: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: background 0.22s;
}
.shv2-tab:last-child { border-right: 0; }
.shv2-tab:hover { background: rgba(255,255,255,0.65); }
.shv2-tab:hover .shv2-arrow { opacity: 1; transform: translateX(0); }
.shv2-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 26px;
  font-weight: 400;
  color: var(--green-leaf);
  line-height: 1;
}
.shv2-tab--orange .shv2-num { color: var(--orange); }
.shv2-ic {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: var(--green-50);
  color: var(--green-dark);
  display: flex;
  align-items: center;
  justify-content: center;
}
.shv2-tab--orange .shv2-ic { background: var(--orange-50); color: var(--orange-dark); }
.shv2-ic svg { width: 20px; height: 20px; }
.shv2-info h3 { font-size: 16px; font-weight: 700; margin: 0 0 6px; color: var(--ink); }
.shv2-info p  { font-size: 13px; color: var(--ink-3); margin: 0; line-height: 1.45; }
.shv2-arrow {
  position: absolute;
  bottom: 28px;
  right: 22px;
  opacity: 0;
  transform: translateX(-5px);
  transition: opacity 0.22s, transform 0.22s;
  color: var(--green);
}
.shv2-tab--orange .shv2-arrow { color: var(--orange); }
.shv2-arrow svg { width: 17px; height: 17px; }

/* ── Contact Hero V2 — dark split ── */
.contact-hero-v2 {
  position: relative;
  padding: 104px 0 88px;
  background: linear-gradient(135deg, var(--green-deep) 0%, var(--green-dark) 100%);
  overflow: hidden;
}
.contact-hero-v2::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
.contact-hero-v2::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 52px;
  background: var(--cream);
  clip-path: polygon(0 52px, 100% 0, 100% 52px);
  pointer-events: none;
}
.contact-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 72px;
  align-items: center;
}
.chv2-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--green-leaf);
  margin-bottom: 24px;
}
.chv2-eyebrow .dot {
  width: 8px;
  height: 8px;
  background: var(--green-leaf);
  border-radius: 50%;
  animation: pulse 2s infinite;
  box-shadow: 0 0 0 3px rgba(141,198,63,0.2);
}
.chv2-left h1 {
  font-size: clamp(38px, 5vw, 60px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.06;
  color: var(--white);
  margin: 0 0 20px;
}
.chv2-left h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-leaf);
}
.chv2-left p {
  font-size: 17px;
  color: rgba(255,255,255,0.65);
  margin: 0 0 36px;
  line-height: 1.6;
  max-width: 460px;
}
.chv2-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  background: var(--white);
  color: var(--green-dark) !important;
  border-radius: 999px;
  font-weight: 700;
  font-size: 15px;
  transition: background 0.2s, transform 0.2s;
}
.chv2-cta:hover { background: var(--cream); transform: translateY(-1px); }
.chv2-cta svg { width: 16px; height: 16px; }
.chv2-right { display: flex; flex-direction: column; gap: 10px; }
.chv2-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 16px 20px;
  transition: background 0.2s;
}
.chv2-card:hover { background: rgba(255,255,255,0.11); }
.chv2-ic {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(245,130,32,0.2);
  color: var(--orange);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.chv2-ic svg { width: 18px; height: 18px; }
.chv2-label {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.42);
  margin-bottom: 3px;
}
.chv2-val {
  font-size: 15px;
  font-weight: 600;
  color: var(--white);
  line-height: 1.4;
}

/* ── Responsive: new hero sections ── */
@media (max-width: 960px) {
  .about-hero-v2 { padding: 90px 0 72px; }
  .ahs-chip { padding: 18px 24px; min-width: 120px; }
  .ahs-chip .n { font-size: 32px; }
  .services-hero-v2 { padding: 80px 0 0; }
  .services-hero-v2::before { display: none; }
  .shv2-inner { max-width: 100%; padding-bottom: 40px; }
  .shv2-tabs { grid-template-columns: 1fr; }
  .shv2-tab {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    padding: 20px 24px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    gap: 10px;
  }
  .shv2-tab:last-child { border-bottom: 0; }
  .shv2-num { width: 36px; }
  .shv2-info { flex: 1; }
  .shv2-arrow { position: static; opacity: 1; transform: none; }
  .contact-hero-inner { grid-template-columns: 1fr; gap: 48px; }
  .contact-hero-v2 { padding: 80px 0 64px; }
  .contact-hero-v2::after { display: none; }
  .ghv2-text h1 { font-size: clamp(36px, 7vw, 56px); }
  .ghv2-item { width: 210px; height: 152px; }
}
@media (max-width: 560px) {
  .about-hero-v2 { padding: 72px 0 56px; }
  .about-hero-stats { gap: 8px; }
  .ahs-chip { flex: 1 0 calc(50% - 4px); padding: 16px 20px; }
  .ahs-chip .n { font-size: 28px; }
  .chv2-right { gap: 8px; }
  .ghv2-item { width: 165px; height: 122px; }
}

/* ═══════════════════════════════════════════════
   SERVICES HERO V3 — three full-bleed photo panels
   ═══════════════════════════════════════════════ */

/* Scroll offset so sticky header doesn't cover anchors */
#supply, #professional, #construction {
  scroll-margin-top: 90px;
}

/* ── Header area ── */
.services-hero-v3 {
  background: var(--cream);
}
.shv3-header {
  padding: 100px 0 68px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
/* Dot-grid texture */
.shv3-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(31,168,76,0.09) 1.5px, transparent 1.5px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}
/* Radial green glow from top-centre */
.shv3-header::after {
  content: '';
  position: absolute;
  top: -60%;
  left: 50%;
  transform: translateX(-50%);
  width: 900px;
  height: 900px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(31,168,76,0.11) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
/* Decorative circle rings */
.shv3-header .container::before {
  content: '';
  position: absolute;
  top: -120px;
  left: -160px;
  width: 400px;
  height: 400px;
  border: 1.5px solid rgba(31,168,76,0.10);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.shv3-header .container::after {
  content: '';
  position: absolute;
  bottom: -100px;
  right: -140px;
  width: 320px;
  height: 320px;
  border: 1.5px solid rgba(31,168,76,0.08);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
/* Keep text above the background layers */
.shv3-header .container {
  position: relative;
  z-index: 1;
}
.shv3-header .eyebrow {
  margin-bottom: 28px;
}
.shv3-header h1 {
  font-size: clamp(44px, 6vw, 80px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.02;
  color: var(--ink);
  margin: 0 0 24px;
}
.shv3-header h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green-dark);
}
.shv3-lede {
  font-size: 17px;
  color: var(--ink-3);
  line-height: 1.65;
  max-width: 580px;
  margin: 0 auto;
}

/* ── Panel grid ── */
.shv3-panels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

/* ── Individual panel ── */
.shv3-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 44px 36px 40px;
  min-height: 500px;
  overflow: hidden;
  text-decoration: none;
  color: var(--white);
  background: var(--green-dark);
}

/* Photo layer — zooms in on hover */
.shv3-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.shv3-panel:hover .shv3-photo { transform: scale(1.07); }

/* Color overlay — per panel variant */
.shv3-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    148deg,
    rgba(8, 54, 26, 0.94) 0%,
    rgba(8, 54, 26, 0.80) 55%,
    rgba(8, 54, 26, 0.90) 100%
  );
  transition: opacity 0.45s;
}
.shv3-panel--orange .shv3-overlay {
  background: linear-gradient(
    148deg,
    rgba(160, 68,  0, 0.95) 0%,
    rgba(160, 68,  0, 0.80) 55%,
    rgba(160, 68,  0, 0.92) 100%
  );
}
.shv3-panel--deep .shv3-overlay {
  background: linear-gradient(
    148deg,
    rgba(4,  28, 12, 0.97) 0%,
    rgba(4,  28, 12, 0.84) 55%,
    rgba(4,  28, 12, 0.94) 100%
  );
}
.shv3-panel:hover .shv3-overlay       { opacity: 0.82; }
.shv3-panel--orange:hover .shv3-overlay { opacity: 0.80; }
.shv3-panel--deep:hover .shv3-overlay   { opacity: 0.80; }

/* Vertical separator line between panels */
.shv3-panel:not(:last-child) {
  border-right: 1px solid rgba(255, 255, 255, 0.08);
}

/* Large italic number watermark */
.shv3-num {
  position: absolute;
  top: -16px;
  right: 14px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 164px;
  font-weight: 700;
  line-height: 1;
  color: rgba(255, 255, 255, 0.055);
  pointer-events: none;
  user-select: none;
  z-index: 2;
  transition: color 0.45s;
}
.shv3-panel:hover .shv3-num { color: rgba(255, 255, 255, 0.10); }

/* ── Content wrapper ── */
.shv3-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Icon badge */
.shv3-ic {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.16);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  flex-shrink: 0;
  transition: background 0.3s, transform 0.35s;
}
.shv3-panel:hover .shv3-ic {
  background: rgba(255, 255, 255, 0.18);
  transform: scale(1.07) rotate(-2deg);
}
.shv3-ic svg { width: 24px; height: 24px; }

/* Service heading */
.shv3-content h2 {
  font-size: 23px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.18;
  color: var(--white);
  margin: 0 0 16px;
}

/* Description */
.shv3-content p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.70);
  line-height: 1.65;
  margin: 0 0 28px;
}

/* Bullet list */
.shv3-list {
  list-style: none;
  margin: 0 0 auto;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.shv3-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.35;
}
.shv3-list li svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--green-leaf);
}
.shv3-panel--orange .shv3-list li svg { color: rgba(255, 210, 140, 0.90); }
.shv3-panel--deep   .shv3-list li svg { color: var(--green-leaf); }

/* Explore CTA */
.shv3-cta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 32px;
  padding-top: 22px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.60);
  transition: color 0.25s, gap 0.25s;
}
.shv3-panel:hover .shv3-cta {
  color: rgba(255, 255, 255, 1);
  gap: 14px;
}
.shv3-cta svg { width: 14px; height: 14px; }

/* ── Responsive ── */
@media (max-width: 960px) {
  .shv3-header { padding: 80px 0 52px; }
  .shv3-panels { grid-template-columns: 1fr; }
  .shv3-panel {
    min-height: 340px;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .shv3-panel:last-child { border-bottom: 0; }
  .shv3-num { font-size: 120px; top: -10px; }
}
@media (max-width: 560px) {
  .shv3-header { padding: 64px 0 44px; }
  .shv3-panel { padding: 36px 28px 32px; min-height: 300px; }
  .shv3-num { font-size: 90px; }
  .shv3-content h2 { font-size: 20px; }
}

/* ══════════════════════════════════════════════════════
   MOBILE REFINEMENTS — comprehensive small-screen polish
   ══════════════════════════════════════════════════════ */

/* ── Patch 960px: prevent 1:1 split-visual becoming over-tall when stacked ── */
@media (max-width: 960px) {
  .split-visual { aspect-ratio: 4/3; max-height: 360px; }
  .sv-enhanced  { max-height: 360px; }
}

/* ── Patch 560px: hero stats 2-col, hide slide counter ── */
@media (max-width: 560px) {
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .slide-counter { display: none; }
  .split-visual { max-height: 280px; }
  .sv-enhanced  { max-height: 280px; }
}

/* ── 480px — core small-phone breakpoint (iPhone 14/15 SE, Pixel 7) ── */
@media (max-width: 480px) {
  /* Layout primitives */
  .container { padding: 0 18px; }
  section { padding: 52px 0; }

  /* Site header */
  .mobile-menu { padding: 20px 20px; }
  .mobile-menu nav { margin-top: 14px; }
  .mobile-menu nav a { font-size: 20px; padding: 10px 0; }

  /* Hero */
  .hero { padding: 44px 0 48px; }
  .hero-lede { font-size: 16px; margin-bottom: 24px; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 36px; }
  .stat .n { font-size: 24px; }
  .stat .label { font-size: 11px; }

  /* Hero visual */
  .hero-visual { max-height: 260px; }
  .hv-badge { padding: 14px; gap: 12px; }
  .hv-badge .ic { width: 42px; height: 42px; }

  /* Page hero (sub-page header) */
  .page-hero { padding: 62px 0 44px; }

  /* Split visual */
  .split-visual { max-height: 240px; }
  .sv-enhanced  { max-height: 240px; }

  /* CTA band */
  .cta-band { padding: 32px 22px; }
  .cta-band .actions { flex-direction: column; }
  .cta-band .actions .btn { width: 100%; justify-content: center; }

  /* Stats band */
  .stats-band { padding: 28px 12px; gap: 20px 0; }

  /* Newsletter */
  .newsletter-mini { max-width: 100%; }

  /* Slider */
  .slide-caption { padding: 16px; gap: 8px; }
  .slide-caption h3 { font-size: 18px; }
  .slide-counter { display: none; }

  /* Gallery hero v2 */
  .ghv2-text { padding: 0 0 44px; }
  .ghv2-item { width: 130px; height: 96px; }

  /* Contact hero v2 cards */
  .chv2-card { padding: 12px 14px; gap: 12px; }
  .chv2-val { font-size: 13.5px; }
  .chv2-ic { width: 34px; height: 34px; }

  /* About hero */
  .about-hero-v2 { padding: 60px 0 44px; }

  /* Services hero v3 */
  .shv3-header { padding: 48px 0 30px; }
  .shv3-panel { padding: 28px 20px 24px; min-height: 240px; }
  .shv3-content h2 { font-size: 17px; }
  .shv3-num { font-size: 72px; }

  /* Modal */
  .modal { padding: 22px 18px; }
  .svc-header-num { font-size: 44px; }

  /* Footer */
  .footer-bottom { gap: 10px; }
}
