/* =============================================================
   YSAT — Youth Social Advocacy Team
   Brand Stylesheet
   Prepared by ThierryDev (thierrydev.me)
   Based on YSAT Extended Colour Palette Guide (April 2026)
   ============================================================= */

/* -------------------------------------------------------------
   Google Fonts Import — Archivo
   ------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,100..900;1,100..900&display=swap');

/* -------------------------------------------------------------
   CSS Custom Properties (Design Tokens)
   ------------------------------------------------------------- */
:root {

  /* --- Primary Colours (Brand-Approved) --- */
  --color-brand-green:   #009444; /* Logo, headings, primary buttons, key accents, hero backgrounds */
  --color-black:         #000000; /* Logo outlines, primary body text, high-contrast headings */
  --color-white:         #FFFFFF; /* Page backgrounds, reversed text on dark surfaces */

  /* --- Secondary Colours (Green Tints & Shades) --- */
  --color-deep-green:    #007A38; /* Hover states for buttons and links, active nav items */
  --color-forest-green:  #005A28; /* Footer background, dark navbar, dark section backgrounds */
  --color-mid-green:     #33A963; /* Secondary buttons, tag pills, icon fills */
  --color-soft-green:    #7FCB9B; /* Badges, highlights, progress bars, decorative chips */
  --color-mint-tint:     #D6F0E2; /* Card backgrounds, success alerts, subtle divider strips */
  --color-pale-green:    #F0FAF4; /* Alternate section backgrounds, page-level washes */

  /* --- Neutral Colours (Grays) --- */
  --color-near-black:    #1A1A1A; /* Primary body text, paragraph copy */
  --color-dark-gray:     #4A4A4A; /* Secondary text, form labels, metadata */
  --color-mid-gray:      #7A7A7A; /* Captions, placeholder text, muted notes */
  --color-light-gray:    #C8C8C8; /* Borders, horizontal rules, table dividers */
  --color-off-white:     #F5F5F5; /* Alternating row fills, card backgrounds, input fields */

  /* --- CTA Accent Colours (Call to Action) --- */
  --color-gold-amber:    #E8A020; /* Primary CTA buttons: Donate Now, Apply, Join Us, Contact */
  --color-gold-amber-dk: #C87D0A; /* Hover and pressed state of Gold Amber buttons */

  /* --- Semantic Colours (Functional UI States Only) --- */
  --color-alert-red:     #C0392B; /* Error states, required field markers, urgent notices */
  --color-link-blue:     #1A6FA8; /* Hyperlinks, informational badges, info alert states */
  --color-warning-amber: #E8A020; /* Warning messages only — same hex as CTA, context determines role */

  /* --- Typography --- */
  --font-primary: 'Archivo', sans-serif;

  --font-size-xs:   0.75rem;    /* 12px */
  --font-size-sm:   0.875rem;   /* 14px */
  --font-size-base: 1rem;       /* 16px */
  --font-size-md:   1.125rem;   /* 18px */
  --font-size-lg:   1.25rem;    /* 20px */
  --font-size-xl:   1.5rem;     /* 24px */
  --font-size-2xl:  1.875rem;   /* 30px */
  --font-size-3xl:  2.25rem;    /* 36px */
  --font-size-4xl:  3rem;       /* 48px */
  --font-size-5xl:  3.75rem;    /* 60px */

  --font-weight-regular:    400;
  --font-weight-medium:     500;
  --font-weight-semibold:   600;
  --font-weight-bold:       700;
  --font-weight-extrabold:  800;
  --font-weight-black:      900;

  --line-height-tight:   1.2;
  --line-height-snug:    1.35;
  --line-height-normal:  1.6;
  --line-height-relaxed: 1.75;

  --letter-spacing-tight:  -0.02em;
  --letter-spacing-normal:  0;
  --letter-spacing-wide:    0.04em;
  --letter-spacing-wider:   0.08em;

  /* --- Spacing Scale --- */
  --space-1:   0.25rem;   /* 4px  */
  --space-2:   0.5rem;    /* 8px  */
  --space-3:   0.75rem;   /* 12px */
  --space-4:   1rem;      /* 16px */
  --space-5:   1.25rem;   /* 20px */
  --space-6:   1.5rem;    /* 24px */
  --space-8:   2rem;      /* 32px */
  --space-10:  2.5rem;    /* 40px */
  --space-12:  3rem;      /* 48px */
  --space-16:  4rem;      /* 64px */
  --space-20:  5rem;      /* 80px */
  --space-24:  6rem;      /* 96px */

  /* --- Border Radius --- */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --radius-full: 9999px;

  /* --- Shadows --- */
  --shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.10);
  --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.12);
  --shadow-lg:  0 8px 24px rgba(0, 0, 0, 0.14);
  --shadow-xl:  0 16px 40px rgba(0, 0, 0, 0.16);

  /* --- Transitions --- */
  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;

  /* --- Layout --- */
  --container-max:     1200px;
  --container-narrow:  800px;
  --container-wide:    1400px;

}

/* =============================================================
   Base Reset & Foundation
   ============================================================= */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--color-near-black);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video, svg {
  display: block;
  max-width: 100%;
}

ul, ol {
  list-style: none;
}

a {
  color: var(--color-link-blue);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-brand-green);
}

/* =============================================================
   Typography
   ============================================================= */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-primary);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-brand-green);
}

h1 { font-size: var(--font-size-4xl); }
h2 { font-size: var(--font-size-3xl); }
h3 { font-size: var(--font-size-2xl); }
h4 { font-size: var(--font-size-xl); }
h5 { font-size: var(--font-size-lg); }
h6 { font-size: var(--font-size-md); }

p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-near-black);
  margin-bottom: var(--space-4);
}

p:last-child {
  margin-bottom: 0;
}

.lead {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-normal);
  color: var(--color-dark-gray);
}

.caption,
small {
  font-size: var(--font-size-sm);
  color: var(--color-mid-gray);
  line-height: var(--line-height-normal);
}

.label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-dark-gray);
}

strong, b {
  font-weight: var(--font-weight-bold);
}

em, i {
  font-style: italic;
}

/* On dark backgrounds — flip heading color */
.bg-dark h1,
.bg-dark h2,
.bg-dark h3,
.bg-dark h4,
.bg-dark h5,
.bg-dark h6,
.bg-forest h1,
.bg-forest h2,
.bg-forest h3,
.bg-forest h4,
.bg-forest h5,
.bg-forest h6 {
  color: var(--color-white);
}

.bg-dark p,
.bg-forest p {
  color: var(--color-mint-tint);
}

/* =============================================================
   Layout Utilities
   ============================================================= */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.container--narrow {
  max-width: var(--container-narrow);
}

.container--wide {
  max-width: var(--container-wide);
}

.section {
  padding-block: var(--space-20);
}

.section--sm {
  padding-block: var(--space-12);
}

.section--lg {
  padding-block: var(--space-24);
}

/* =============================================================
   Background Helpers
   ============================================================= */

.bg-white         { background-color: var(--color-white); }
.bg-off-white     { background-color: var(--color-off-white); }
.bg-pale-green    { background-color: var(--color-pale-green); }
.bg-mint          { background-color: var(--color-mint-tint); }
.bg-brand         { background-color: var(--color-brand-green); color: var(--color-white); }
.bg-forest        { background-color: var(--color-forest-green); color: var(--color-white); }
.bg-dark          { background-color: var(--color-near-black); color: var(--color-white); }

/* =============================================================
   Navbar
   ============================================================= */

.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  background-color: var(--color-forest-green);
  color: var(--color-white);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--shadow-md);
}

.navbar__logo img {
  height: 48px;
  width: auto;
}

.navbar__links {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.navbar__link {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-white);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.navbar__link:hover,
.navbar__link.active {
  color: var(--color-gold-amber);
}

/* =============================================================
   Hero Section
   ============================================================= */

.hero {
  background-color: var(--color-brand-green);
  color: var(--color-white);
  padding-block: var(--space-24);
  text-align: center;
}

.hero__tagline {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-soft-green);
  margin-bottom: var(--space-4);
}

.hero__title {
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-black);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-white);
  margin-bottom: var(--space-6);
}

.hero__subtitle {
  font-size: var(--font-size-lg);
  color: var(--color-mint-tint);
  max-width: 640px;
  margin-inline: auto;
  margin-bottom: var(--space-10);
}

/* =============================================================
   Buttons
   ============================================================= */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-8);
  cursor: pointer;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast),
    transform var(--transition-fast),
    box-shadow var(--transition-fast);
}

.btn:active {
  transform: translateY(1px);
}

/* Primary CTA — Gold Amber (Donate, Apply, Join Us, Contact) */
.btn--cta {
  background-color: var(--color-gold-amber);
  color: var(--color-near-black);
  border-color: var(--color-gold-amber);
}

.btn--cta:hover {
  background-color: var(--color-gold-amber-dk);
  border-color: var(--color-gold-amber-dk);
  color: var(--color-white);
  box-shadow: var(--shadow-md);
}

/* Primary Brand Button */
.btn--primary {
  background-color: var(--color-brand-green);
  color: var(--color-white);
  border-color: var(--color-brand-green);
}

.btn--primary:hover {
  background-color: var(--color-deep-green);
  border-color: var(--color-deep-green);
  box-shadow: var(--shadow-md);
}

/* Secondary Button — White fill on green backgrounds */
.btn--secondary {
  background-color: var(--color-white);
  color: var(--color-brand-green);
  border-color: var(--color-white);
}

.btn--secondary:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-mint-tint);
  color: var(--color-forest-green);
}

/* Outline Button */
.btn--outline {
  background-color: transparent;
  color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

.btn--outline:hover {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

/* Outline White — for use on dark/green backgrounds */
.btn--outline-white {
  background-color: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}

.btn--outline-white:hover {
  background-color: var(--color-white);
  color: var(--color-forest-green);
}

/* Tertiary Button — Black fill, white text, on light backgrounds */
.btn--tertiary {
  background-color: var(--color-near-black);
  color: var(--color-white);
  border-color: var(--color-near-black);
}

.btn--tertiary:hover {
  background-color: var(--color-black);
  border-color: var(--color-black);
}

/* Sizes */
.btn--sm {
  font-size: var(--font-size-xs);
  padding: var(--space-2) var(--space-5);
}

.btn--lg {
  font-size: var(--font-size-md);
  padding: var(--space-4) var(--space-10);
}

/* =============================================================
   Cards
   ============================================================= */

.card {
  background-color: var(--color-mint-tint);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

.card--white {
  background-color: var(--color-white);
  border: 1px solid var(--color-light-gray);
}

.card--pale {
  background-color: var(--color-pale-green);
}

.card--off-white {
  background-color: var(--color-off-white);
}

/* =============================================================
   Tags / Badges / Pills
   ============================================================= */

.tag {
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-3);
  background-color: var(--color-mid-green);
  color: var(--color-white);
}

.tag--soft {
  background-color: var(--color-soft-green);
  color: var(--color-forest-green);
}

.tag--mint {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
}

.tag--amber {
  background-color: var(--color-gold-amber);
  color: var(--color-near-black);
}

/* =============================================================
   Forms
   ============================================================= */

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.form-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-dark-gray);
  letter-spacing: var(--letter-spacing-wide);
}

.form-input,
.form-select,
.form-textarea {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  width: 100%;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-mid-gray);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--color-brand-green);
  box-shadow: 0 0 0 3px rgba(0, 148, 68, 0.15);
  background-color: var(--color-white);
}

/* Validation states */
.form-input--error {
  border-color: var(--color-alert-red);
}

.form-input--error:focus {
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.15);
}

.form-hint {
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
}

.form-error {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-alert-red);
}

.form-required {
  color: var(--color-alert-red);
  margin-left: var(--space-1);
}

/* =============================================================
   Alerts / Notifications
   ============================================================= */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  border-left: 4px solid transparent;
}

.alert--success {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border-left-color: var(--color-brand-green);
}

.alert--error {
  background-color: #fdf2f2;
  color: var(--color-alert-red);
  border-left-color: var(--color-alert-red);
}

.alert--warning {
  background-color: #fdf6e3;
  color: #7a4f00;
  border-left-color: var(--color-warning-amber);
}

.alert--info {
  background-color: #eaf3fb;
  color: var(--color-link-blue);
  border-left-color: var(--color-link-blue);
}

/* =============================================================
   Progress Bars
   ============================================================= */

.progress {
  width: 100%;
  height: 8px;
  background-color: var(--color-off-white);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress__bar {
  height: 100%;
  background-color: var(--color-soft-green);
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
}

.progress__bar--brand {
  background-color: var(--color-brand-green);
}

.progress__bar--amber {
  background-color: var(--color-gold-amber);
}

/* =============================================================
   Tables
   ============================================================= */

.table-wrapper {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-light-gray);
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

thead {
  background-color: var(--color-forest-green);
  color: var(--color-white);
}

thead th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  font-size: var(--font-size-xs);
}

tbody tr {
  border-bottom: 1px solid var(--color-light-gray);
  transition: background-color var(--transition-fast);
}

tbody tr:last-child {
  border-bottom: none;
}

tbody tr:nth-child(even) {
  background-color: var(--color-off-white);
}

tbody tr:hover {
  background-color: var(--color-pale-green);
}

tbody td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-near-black);
}

/* =============================================================
   Dividers
   ============================================================= */

hr {
  border: none;
  border-top: 1px solid var(--color-light-gray);
  margin-block: var(--space-8);
}

.divider--mint {
  border-top-color: var(--color-mint-tint);
}

.divider--green {
  border-top-color: var(--color-brand-green);
}

/* =============================================================
   Footer
   ============================================================= */

.footer {
  background-color: var(--color-forest-green);
  color: var(--color-white);
  padding-block: var(--space-16);
}

.footer__heading {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-soft-green);
  margin-bottom: var(--space-4);
}

.footer__link {
  font-size: var(--font-size-sm);
  color: var(--color-mint-tint);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer__link:hover {
  color: var(--color-gold-amber);
}

.footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding-top: var(--space-6);
  margin-top: var(--space-12);
  font-size: var(--font-size-xs);
  color: var(--color-soft-green);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

/* =============================================================
   Responsive
   ============================================================= */

@media (max-width: 1024px) {
  h1 { font-size: var(--font-size-3xl); }
  h2 { font-size: var(--font-size-2xl); }
  .hero__title { font-size: var(--font-size-4xl); }
}

@media (max-width: 768px) {
  .container { padding-inline: var(--space-4); }
  .section   { padding-block: var(--space-12); }
  h1 { font-size: var(--font-size-2xl); }
  h2 { font-size: var(--font-size-xl); }
  .hero__title { font-size: var(--font-size-3xl); }
  .hero__subtitle { font-size: var(--font-size-base); }
  .navbar__links { display: none; } /* collapsed to hamburger via JS */
}

@media (max-width: 480px) {
  .hero__title { font-size: var(--font-size-2xl); }
  .btn { width: 100%; justify-content: center; }
}

/* =============================================================
   Accessibility
   ============================================================= */

:focus-visible {
  outline: 3px solid var(--color-gold-amber);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}



/* =============================================================
   YSAT HERO SLIDER
   Add this section into ysat-brand.css
   ============================================================= */

.ysat-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 520px;
  max-height: 860px;
  overflow: hidden;
  background-color: var(--color-near-black);
}

/* ---- Slides ---- */
.ysat-hero__slides {
  position: relative;
  width: 100%;
  height: 100%;
}

.ysat-hero__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 1;
}

.ysat-hero__slide.active {
  opacity: 1;
  z-index: 2;
}

/* Slide images */
.ysat-hero__slide:nth-child(1) { background-image: url('../img/hero/DJI_20240916053920_0272_D.jpg'); }
.ysat-hero__slide:nth-child(2) { background-image: url('../img/hero/IMG_6330.jpg'); }
.ysat-hero__slide:nth-child(3) { background-image: url('../img/hero/IMG_6332.jpg'); }
.ysat-hero__slide:nth-child(4) { background-image: url('../img/hero/children-with-tab.jpg'); }
.ysat-hero__slide:nth-child(5) { background-image: url('../img/hero/urri.jpg'); }
.ysat-hero__slide:nth-child(6) { background-image: url('../img/hero/works.jpg'); }
.ysat-hero__slide:nth-child(7) { background-image: url('../img/hero/agric.jpg'); }

/* No overlay — image shows fully clear */
.ysat-hero__overlay {
  display: none;
}

/* ---- Content area ---- */
.ysat-hero__content {
  position: absolute;
  bottom: 90px;
  right: 50px;
  left: auto;
  z-index: 4;
  max-width: 520px;
  padding: 28px 32px;
  background-color: rgba(0, 90, 40, 0.75);
  border: 2px solid rgba(255, 255, 255, 0.25);
  outline: 1px solid rgba(255, 255, 255, 0.12);
  outline-offset: 6px;
}

.ysat-hero__tagline {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s ease 0.2s, transform 0.6s ease 0.2s;
}

.ysat-hero__heading {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2.2vw, 1.75rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.35;
  letter-spacing: -0.01em;
  margin: 0 0 20px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease 0.35s, transform 0.6s ease 0.35s;
}

.ysat-hero__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease 0.5s, transform 0.6s ease 0.5s;
}

/* Animate class triggers staggered entrance */
.ysat-hero__content.animate .ysat-hero__tagline,
.ysat-hero__content.animate .ysat-hero__heading,
.ysat-hero__content.animate .ysat-hero__actions {
  opacity: 1;
  transform: translateY(0);
}

/* Gold CTA button */
.ysat-hero__btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.15s ease;
}

.ysat-hero__btn-primary:hover {
  background-color: var(--color-gold-amber-dk);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* Dark secondary button */
.ysat-hero__btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-white);
  background-color: var(--color-near-black);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border: 2px solid var(--color-near-black);
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.15s ease;
}

.ysat-hero__btn-secondary:hover {
  background-color: var(--color-black);
  border-color: var(--color-black);
  transform: translateY(-2px);
}

/* ---- Dot indicators ---- */
.ysat-hero__dots {
  position: absolute;
  bottom: 32px;
  left: 50px;
  right: auto;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 10px;
}

.ysat-hero__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.45);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.25s ease, transform 0.25s ease;
}

.ysat-hero__dot.active {
  background-color: var(--color-gold-amber);
  transform: scale(1.25);
}

.ysat-hero__dot:hover:not(.active) {
  background-color: rgba(255, 255, 255, 0.75);
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ysat-hero {
    height: 85vh;
    min-height: 460px;
  }

  .ysat-hero__content {
    bottom: 80px;
    right: 24px;
    left: 24px;
    max-width: 100%;
  }

  .ysat-hero__dots {
    left: 24px;
    bottom: 28px;
  }

  .ysat-hero__btn-primary,
  .ysat-hero__btn-secondary {
    padding: 11px 20px;
    font-size: 0.88rem;
  }
}

@media (max-width: 480px) {
  .ysat-hero {
    height: 80vh;
  }

  .ysat-hero__content {
    left: 16px;
    right: 16px;
    bottom: 70px;
  }

  .ysat-hero__dots {
    left: 16px;
  }

  .ysat-hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .ysat-hero__btn-primary,
  .ysat-hero__btn-secondary {
    width: 100%;
    justify-content: center;
  }
}





/* =============================================================
   YSAT PAGE HERO — .ysat-pages-hero-img
   Reusable for all inner pages — add background-image per page
   ============================================================= */

.ysat-pages-hero-img {
  position: relative;
  width: 100%;
  height: 480px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  /* background-image set per page via style attribute in HTML */
}

/* no overlay needed — content bar handles background */

.ysat-pages-hero-img__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 16px 50px;
  background-color: rgba(0, 90, 40, 0.72);
}

.ysat-pages-hero-img__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
}

.ysat-pages-hero-img__breadcrumb li {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.04em;
}

.ysat-pages-hero-img__breadcrumb li a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: color 0.18s ease;
}

.ysat-pages-hero-img__breadcrumb li a:hover {
  color: var(--color-gold-amber);
}

.ysat-pages-hero-img__breadcrumb li.active {
  color: var(--color-gold-amber);
  font-weight: 600;
}

.ysat-pages-hero-img__breadcrumb .sep {
  color: rgba(255, 255, 255, 0.4);
  font-size: 0.7rem;
}

.ysat-pages-hero-img__title {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0;
}


/* =============================================================
   PAGE SECTIONS — shared across all inner pages
   ============================================================= */

.ysat-page-section {
  padding: 72px 50px;
}

.ysat-page-section--alt {
  background-color: var(--color-pale-green);
}

.ysat-page-section__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-section-label {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-section-heading {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.ysat-section-heading span {
  color: var(--color-brand-green);
}

/* ysat-section-rule removed */

.ysat-section-lead {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  max-width: 680px;
}

.ysat-section-text {
  font-family: var(--font-primary);
  font-size: 0.97rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin-top: 16px;
}


/* =============================================================
   WHO WE ARE — .ysat-who-grid
   ============================================================= */

.ysat-who-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.ysat-who-img-wrap {
  position: relative;
}

.ysat-who-img-wrap img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

.ysat-who-img-wrap__accent {
  position: absolute;
  bottom: -20px;
  left: -20px;
  width: 120px;
  height: 120px;
  background-color: var(--color-brand-green);
  opacity: 0.12;
  border-radius: 4px;
  z-index: -1;
}


/* =============================================================
   STATS BAR — .ysat-stats-row
   ============================================================= */

.ysat-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background-color: var(--color-forest-green);
  padding: 48px 50px;
}

.ysat-stat {
  text-align: center;
  padding: 16px 20px;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-stat:last-child {
  border-right: none;
}

.ysat-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
}

.ysat-stat__label {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.80);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}


/* =============================================================
   VISION & MISSION — .ysat-vm-grid
   ============================================================= */

.ysat-vm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-top: 16px;
}

.ysat-vm-card {
  padding: 32px;
  background-color: var(--color-white);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.07);
}

.ysat-vm-card--mission {
  background-color: var(--color-white);
}

.ysat-vm-card__icon {
  font-size: 1.8rem;
  color: var(--color-brand-green);
  margin-bottom: 14px;
}

.ysat-vm-card--mission .ysat-vm-card__icon {
  color: var(--color-gold-amber);
}

.ysat-vm-card__title {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 12px;
}

.ysat-vm-card__text {
  font-family: var(--font-primary);
  font-size: 0.97rem;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}


/* =============================================================
   CORE VALUES — .ysat-values-grid
   ============================================================= */

.ysat-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}

.ysat-value-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-light-gray);
  padding: 28px 24px;
  border-radius: 4px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-value-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.10);
  transform: translateY(-3px);
}

.ysat-value-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background-color: var(--color-mint-tint);
  border-radius: 50%;
  margin-bottom: 16px;
  font-size: 1.3rem;
  color: var(--color-brand-green);
}

.ysat-value-card__title {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-near-black);
  margin: 0 0 8px;
}

.ysat-value-card__text {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  color: var(--color-dark-gray);
  line-height: 1.65;
  margin: 0;
}


/* =============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================= */

@media (max-width: 1024px) {
  .ysat-values-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-stats-row {
    grid-template-columns: repeat(2, 1fr);
    padding: 40px 24px;
  }

  .ysat-stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
    padding: 20px;
  }

  .ysat-stat:nth-child(3),
  .ysat-stat:nth-child(4) {
    border-bottom: none;
  }
}

@media (max-width: 900px) {
  .ysat-who-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-vm-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .ysat-pages-hero-img {
    height: 360px;
  }

  .ysat-pages-hero-img__content {
    padding: 14px 24px;
  }

  .ysat-page-section {
    padding: 48px 24px;
  }

  .ysat-stats-row {
    padding: 32px 16px;
  }

  .ysat-values-grid {
    grid-template-columns: 1fr;
  }

  .ysat-who-img-wrap img {
    height: 280px;
  }
}

@media (max-width: 480px) {
  .ysat-pages-hero-img {
    height: 280px;
  }

  .ysat-pages-hero-img__content {
    padding: 12px 16px;
  }

  .ysat-page-section {
    padding: 36px 16px;
  }

  .ysat-stats-row {
    grid-template-columns: 1fr 1fr;
    padding: 24px 16px;
  }
}




/* =============================================================
   WHO YSAT IS — SHORT SECTION
   .ysat-who-short
   Add this into ysat-brand.css
   ============================================================= */

.ysat-who-short {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-who-short__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
  align-items: center;
}

/* Left — label + heading */
.ysat-who-short__heading-block {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-who-short__label {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-who-short__title {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.18;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-who-short__title span {
  color: var(--color-brand-green);
}

/* ysat-who-short__accent removed */

/* Right — text + CTA */
.ysat-who-short__body {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.ysat-who-short__text {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

.ysat-who-short__text strong {
  color: var(--color-near-black);
  font-weight: 700;
}

.ysat-who-short__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border-bottom: 2px solid var(--color-brand-green);
  padding-bottom: 3px;
  align-self: flex-start;
  transition: color 0.18s ease, border-color 0.18s ease;
}

.ysat-who-short__cta:hover {
  color: var(--color-deep-green);
  border-color: var(--color-deep-green);
}

.ysat-who-short__cta i {
  font-size: 0.85rem;
  transition: transform 0.18s ease;
}

.ysat-who-short__cta:hover i {
  transform: translateX(4px);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-who-short__inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ysat-who-short__accent {
    margin-bottom: 8px;
  }
}

@media (max-width: 768px) {
  .ysat-who-short {
    padding: 36px 24px;
  }
}

@media (max-width: 480px) {
  .ysat-who-short {
    padding: 28px 16px;
  }

  .ysat-who-short__text {
    font-size: 0.97rem;
  }
}



/* =============================================================
   PROBLEM WE ARE SOLVING SECTION
   .ysat-problem
   Add this block into ysat-brand.css
   ============================================================= */

.ysat-problem {
  padding: 48px 50px;
  background-color: var(--color-pale-green);
}

.ysat-problem__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 80px;
  align-items: start;
}

/* ---- Right — label + heading (sticky) ---- */
.ysat-problem__heading-block {
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 110px;
}

.ysat-problem__label {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-problem__title {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.18;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-problem__title span {
  color: var(--color-brand-green);
}

/* ---- Left — content column ---- */
.ysat-problem__body {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.ysat-problem__img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

.ysat-problem__text {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

.ysat-problem__text--lead {
  font-weight: 600;
  color: var(--color-near-black);
}

.ysat-problem__text strong {
  color: var(--color-near-black);
  font-weight: 700;
}

/* ---- Stats grid ---- */
.ysat-problem__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 8px 0;
}

.ysat-problem__stat {
  background-color: var(--color-white);
  padding: 18px 20px;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.ysat-problem__stat:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}

.ysat-problem__stat-number {
  font-family: var(--font-primary);
  font-size: 1.7rem;
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
  transition: color 0.3s ease;
}

.ysat-problem__stat.animated .ysat-problem__stat-number {
  color: var(--color-brand-green);
}

.ysat-problem__stat-label {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.45;
}

/* ---- Closing statement ---- */
.ysat-problem__closing {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-forest-green);
  line-height: 1.7;
  margin: 0;
}

/* ---- South Sudan context block ---- */
.ysat-problem__ss-context {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 8px;
  border-top: 2px solid var(--color-mint-tint);
}

/* ---- Reality on the Ground table ---- */
.ysat-problem__table-wrap {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1.5px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-white);
}

.ysat-problem__table-heading {
  font-family: var(--font-primary);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-white);
  background-color: var(--color-forest-green);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.ysat-problem__table-heading i {
  font-size: 1rem;
  opacity: 0.85;
}

/* ---- Thematic pillars list ---- */
.ysat-problem__pillars {
  display: flex;
  flex-direction: column;
}

.ysat-problem__pillar {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 20px;
  border-bottom: 1px solid var(--color-off-white);
  transition: background-color 0.2s ease;
}

.ysat-problem__pillar:last-child {
  border-bottom: none;
}

.ysat-problem__pillar:hover {
  background-color: var(--color-pale-green);
}

.ysat-problem__pillar-icon {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-sm);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

.ysat-problem__pillar-icon i {
  font-size: 1rem;
  color: var(--color-forest-green);
}

.ysat-problem__pillar-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.ysat-problem__pillar-title {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin: 0;
}

.ysat-problem__pillar-text {
  font-family: var(--font-primary);
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.7;
  margin: 0;
}

.ysat-problem__pillar-text strong {
  color: var(--color-near-black);
  font-weight: 700;
}

/* ---- Side image slider ---- */
.ysat-problem__side-slider {
  position: relative;
  width: 100%;
  margin-top: 28px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-problem__side-slides {
  position: relative;
  width: 100%;
  height: 260px;
}

.ysat-problem__side-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.9s ease;
}

.ysat-problem__side-slide.active {
  opacity: 1;
}

/* Caption strip at bottom of each slide */
.ysat-problem__side-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px 14px 10px;
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-white);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.62) 0%, transparent 100%);
  line-height: 1.4;
  pointer-events: none;
}

/* Dot row */
.ysat-problem__side-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 0 12px;
  background-color: var(--color-forest-green);
}

.ysat-problem__side-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.35);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.22s ease, transform 0.22s ease;
}

.ysat-problem__side-dot.active {
  background-color: var(--color-gold-amber);
  transform: scale(1.3);
}

.ysat-problem__side-dot:hover:not(.active) {
  background-color: rgba(255, 255, 255, 0.65);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-problem__inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .ysat-problem__heading-block {
    position: static;
    order: -1;
  }

  .ysat-problem__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Hide side slider on mobile — the hero slider already provides imagery */
  .ysat-problem__side-slider {
    display: none;
  }
}

@media (max-width: 768px) {
  .ysat-problem {
    padding: 36px 24px;
  }

  .ysat-problem__inner {
    gap: 24px;
  }
}

@media (max-width: 480px) {
  .ysat-problem {
    padding: 28px 16px;
  }

  .ysat-problem__stats {
    grid-template-columns: 1fr;
  }

  .ysat-problem__text {
    font-size: 0.97rem;
  }

  .ysat-problem__pillar {
    gap: 12px;
    padding: 16px;
  }

  .ysat-problem__pillar-icon {
    width: 32px;
    height: 32px;
  }
}

/* =============================================================
   YSAT IMPACT DISPLAY SECTION
   .ysat-impact-display
   Add this into ysat-brand.css
   ============================================================= */

.ysat-impact-display {
  background-color: var(--color-white);
  position: relative; /* needed so sticky child is contained within the section */
}

/* ---- Section intro ---- */
.ysat-impact-display__intro {
  padding: 48px 50px 36px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  border-bottom: 2px solid var(--color-pale-green);
}

.ysat-impact-display__intro-text {
  flex: 1;
}

.ysat-impact-display__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 14px;
}

.ysat-impact-display__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.12;
  letter-spacing: -0.03em;
  margin: 0;
}

.ysat-impact-display__title span {
  color: var(--color-brand-green);
}

.ysat-impact-display__intro-note {
  flex-shrink: 0;
  max-width: 320px;
  font-family: var(--font-primary);
  font-size: 0.92rem;
  color: var(--color-mid-gray);
  line-height: 1.65;
  text-align: right;
}

/* ---- Totals band ---- */
.ysat-impact-display__totals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background-color: var(--color-forest-green);
}

.ysat-impact-total {
  padding: 36px 40px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  gap: 20px;
  transition: background-color 0.22s ease;
}

.ysat-impact-total:last-child {
  border-right: none;
}

.ysat-impact-total:hover {
  background-color: var(--color-deep-green);
}

.ysat-impact-total--grand {
  background-color: var(--color-brand-green);
}

.ysat-impact-total--grand:hover {
  background-color: var(--color-deep-green);
}

.ysat-impact-total__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);
  font-size: 1.5rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
}

.ysat-impact-total--grand .ysat-impact-total__icon {
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--color-gold-amber);
}

.ysat-impact-total__text {
  flex: 1;
}

.ysat-impact-total__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.ysat-impact-total__label {
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.65);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.ysat-impact-total--grand .ysat-impact-total__label {
  color: rgba(255, 255, 255, 0.8);
}

/* ---- Programme cards — 3 columns, no bottom padding ---- */
.ysat-impact-display__programmes {
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-pale-green);
}

.ysat-icard {
  position: relative;
  padding: 36px 36px;
  border-right: 1px solid var(--color-pale-green);
  border-bottom: 1px solid var(--color-pale-green);
  overflow: hidden;
  transition: background-color 0.25s ease;
}

.ysat-icard:hover {
  background-color: var(--color-pale-green);
}

/* Remove right border on every third card in normal flow */
.ysat-icard:nth-child(3n) {
  border-right: none;
}

/* Cards inside the context row have no bottom border */

/* Last 2 cards: force a dedicated 2-col row so they split exactly 50/50 */
.ysat-icard--half {
  grid-column: span 1;
  border-right: none;
}

/* Put the two half cards into a full-width 2-col sub-row */
.ysat-impact-display__programmes .ysat-icard--half:first-of-type,
.ysat-icard--half ~ .ysat-icard--half {
  /* handled by placing them in a wrapper row below */
}

/* Use a flex row wrapper for the last 2 cards */
.ysat-impact__context-row {
  grid-column: 1 / -1;    /* span all 3 columns */
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--color-pale-green);
}

.ysat-impact__context-row .ysat-icard {
  border-bottom: none;
}

.ysat-impact__context-row .ysat-icard:first-child {
  border-right: 1px solid var(--color-pale-green);
}

.ysat-impact__context-row .ysat-icard:last-child {
  border-right: none;
}

/* Flower canvas */
#ysatFlowerCanvas {
  display: block;
  pointer-events: none;
  position: fixed;
  z-index: 999;
}

/* Ghost watermark number */
.ysat-icard__ghost {
  position: absolute;
  top: 50%;
  right: -10px;
  transform: translateY(-50%);
  font-family: var(--font-primary);
  font-size: 7rem;
  font-weight: 900;
  color: var(--color-brand-green);
  opacity: 0.05;
  line-height: 1;
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.04em;
  transition: opacity 0.25s ease;
}

.ysat-icard:hover .ysat-icard__ghost {
  opacity: 0.09;
}

/* Icon + number row */
.ysat-icard__top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}

.ysat-icard__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background-color: var(--color-mint-tint);
  font-size: 1.2rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color 0.25s ease, color 0.25s ease;
}

.ysat-icard:hover .ysat-icard__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

/* Big, bold, clearly visible numbers */
.ysat-icard__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: -0.03em;
  position: relative;
  z-index: 1;
}

.ysat-icard__title {
  font-family: var(--font-primary);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.6;
  margin: 0;
  position: relative;
  z-index: 1;
}

/* Funds card — gold accent */
.ysat-icard--funds .ysat-icard__number {
  color: var(--color-gold-amber-dk);
}

.ysat-icard--funds .ysat-icard__icon {
  background-color: #FFF5DF;
  color: var(--color-gold-amber-dk);
}

.ysat-icard--funds:hover .ysat-icard__icon {
  background-color: var(--color-gold-amber);
  color: var(--color-white);
}

.ysat-icard--funds .ysat-icard__ghost {
  color: var(--color-gold-amber);
}

/* Land card */
.ysat-icard--land .ysat-icard__number {
  color: var(--color-forest-green);
}

.ysat-icard--land .ysat-icard__icon {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
}

.ysat-icard--land:hover .ysat-icard__icon {
  background-color: var(--color-forest-green);
  color: var(--color-white);
}

/* Context cards: years + staff */
.ysat-icard--context {
  background-color: var(--color-mint-tint);
}

.ysat-icard--context:hover {
  background-color: var(--color-soft-green);
}

.ysat-icard--context .ysat-icard__number {
  color: var(--color-forest-green);
}

.ysat-icard--context .ysat-icard__ghost {
  color: var(--color-forest-green);
  opacity: 0.06;
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .ysat-impact-display__programmes {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Reset 3n rule, apply 2n rule */
  .ysat-icard:nth-child(3n) {
    border-right: 1px solid var(--color-pale-green);
  }

  .ysat-icard:nth-child(2n) {
    border-right: none;
  }

  /* Context row stays 2-col on tablet */
  .ysat-impact__context-row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .ysat-impact-display__intro {
    flex-direction: column;
    align-items: flex-start;
    padding: 40px 24px 32px;
    gap: 16px;
  }

  .ysat-impact-display__intro-note {
    text-align: left;
    max-width: 100%;
  }

  .ysat-impact-display__totals {
    grid-template-columns: 1fr;
  }

  .ysat-impact-total {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-impact-total:last-child {
    border-bottom: none;
  }

  .ysat-icard {
    padding: 28px 24px;
  }

  .ysat-icard__ghost {
    font-size: 5rem;
  }
}

@media (max-width: 540px) {
  .ysat-impact-display__programmes {
    grid-template-columns: 1fr;
  }

  /* Reset all border-right rules */
  .ysat-icard:nth-child(3n),
  .ysat-icard:nth-child(2n) {
    border-right: none;
  }

  /* Context row stacks on mobile */
  .ysat-impact__context-row {
    grid-template-columns: 1fr;
  }

  .ysat-impact__context-row .ysat-icard:first-child {
    border-right: none;
    border-bottom: 1px solid var(--color-pale-green);
  }

  .ysat-impact__context-row .ysat-icard:last-child {
    border-bottom: none;
  }

  .ysat-impact-display__intro {
    padding: 32px 16px 24px;
  }

  .ysat-impact-total {
    padding: 24px 20px;
  }
}

/* =============================================================
   YSAT WHAT WE DO — HOME SECTION
   .ysat-what-we-do-home
   Add this into ysat-brand.css
   ============================================================= */

.ysat-what-we-do-home {
  padding: 56px 50px;
  background-color: var(--color-forest-green);
  overflow: hidden;
}

.ysat-what-we-do-home__inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- Header row ---- */
.ysat-what-we-do-home__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 40px;
}

.ysat-what-we-do-home__heading-block {
  display: flex;
  flex-direction: column;
}

.ysat-what-we-do-home__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 10px;
}

.ysat-what-we-do-home__title {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-what-we-do-home__title span {
  color: var(--color-gold-amber);
}

.ysat-what-we-do-home__header-right {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
}

.ysat-what-we-do-home__view-all {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  white-space: nowrap;
  border: 1.5px solid rgba(232, 160, 32, 0.45);
  padding: 9px 18px;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast), color var(--transition-fast),
              border-color var(--transition-fast), gap var(--transition-fast);
}

.ysat-what-we-do-home__view-all:hover {
  background-color: var(--color-gold-amber);
  color: var(--color-near-black);
  border-color: var(--color-gold-amber);
  gap: 12px;
}

/* ---- Arrow buttons ---- */
.ysat-pillars-arrows {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ysat-pillars-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  font-size: var(--font-size-base);
  color: var(--color-white);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.ysat-pillars-arrow:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

.ysat-pillars-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* ---- Slider track ---- */
.ysat-pillars-slider {
  position: relative;
  overflow: hidden;
  touch-action: pan-y; /* allow vertical scroll, hand horizontal to JS */
  cursor: grab;
}

.ysat-pillars-slider:active {
  cursor: grabbing;
}

.ysat-pillars-track {
  display: flex;
  gap: 20px;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

/* ---- Pillar card ---- */
.ysat-pillar-card {
  flex: 0 0 calc(25% - 15px);
  min-width: 0;
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.ysat-pillar-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}

/* Coloured top accent bar per SPA */
.ysat-pillar-card__accent {
  height: 5px;
  width: 100%;
  flex-shrink: 0;
}

.ysat-pillar-card--spa1 .ysat-pillar-card__accent { background-color: var(--color-gold-amber); }
.ysat-pillar-card--spa2 .ysat-pillar-card__accent { background-color: var(--color-brand-green); }
.ysat-pillar-card--spa3 .ysat-pillar-card__accent { background-color: var(--color-soft-green); }
.ysat-pillar-card--spa4 .ysat-pillar-card__accent { background-color: var(--color-mid-green); }
.ysat-pillar-card--spa5 .ysat-pillar-card__accent { background-color: var(--color-link-blue); }

/* Card body */
.ysat-pillar-card__body {
  padding: var(--space-6) var(--space-5) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  flex: 1;
}

/* Top row: SPA badge + icon */
.ysat-pillar-card__top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-pillar-card__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background-color: var(--color-off-white);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-dark-gray);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-pillar-card--spa1:hover .ysat-pillar-card__number { background-color: #FFF5DF; color: var(--color-gold-amber-dk); }
.ysat-pillar-card--spa2:hover .ysat-pillar-card__number { background-color: var(--color-mint-tint); color: var(--color-brand-green); }
.ysat-pillar-card--spa3:hover .ysat-pillar-card__number { background-color: var(--color-mint-tint); color: var(--color-forest-green); }
.ysat-pillar-card--spa4:hover .ysat-pillar-card__number { background-color: var(--color-mint-tint); color: var(--color-mid-green); }
.ysat-pillar-card--spa5:hover .ysat-pillar-card__number { background-color: #E8F2FA; color: var(--color-link-blue); }

.ysat-pillar-card__icon {
  font-size: 1.6rem;
  transition: color var(--transition-base);
}

.ysat-pillar-card--spa1 .ysat-pillar-card__icon { color: var(--color-gold-amber); }
.ysat-pillar-card--spa2 .ysat-pillar-card__icon { color: var(--color-brand-green); }
.ysat-pillar-card--spa3 .ysat-pillar-card__icon { color: var(--color-forest-green); }
.ysat-pillar-card--spa4 .ysat-pillar-card__icon { color: var(--color-mid-green); }
.ysat-pillar-card--spa5 .ysat-pillar-card__icon { color: var(--color-link-blue); }

/* Title */
.ysat-pillar-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

/* Description */
.ysat-pillar-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

/* Partner chips */
.ysat-pillar-card__partners {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.ysat-pillar-card__partners span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-mid-gray);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-full);
  padding: 2px 9px;
}

/* Read more link */
.ysat-pillar-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-off-white);
  transition: gap var(--transition-fast);
}

.ysat-pillar-card--spa1 .ysat-pillar-card__link { color: var(--color-gold-amber-dk); }
.ysat-pillar-card--spa2 .ysat-pillar-card__link { color: var(--color-brand-green); }
.ysat-pillar-card--spa3 .ysat-pillar-card__link { color: var(--color-forest-green); }
.ysat-pillar-card--spa4 .ysat-pillar-card__link { color: var(--color-mid-green); }
.ysat-pillar-card--spa5 .ysat-pillar-card__link { color: var(--color-link-blue); }

.ysat-pillar-card:hover .ysat-pillar-card__link {
  gap: var(--space-3);
}

/* ---- Footer: dots + counter ---- */
.ysat-pillars-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-8);
}

.ysat-pillars-nav {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.ysat-pillars-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.25);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-pillars-dot.active {
  background-color: var(--color-gold-amber);
  width: 24px;
  border-radius: var(--radius-sm);
}

.ysat-pillars-dot:hover:not(.active) {
  background-color: rgba(255, 255, 255, 0.55);
}

.ysat-pillars-counter {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.45);
  letter-spacing: var(--letter-spacing-wider);
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .ysat-pillar-card {
    flex: 0 0 calc(33.333% - 14px);
  }
}

@media (max-width: 768px) {
  .ysat-what-we-do-home {
    padding: var(--space-10) var(--space-6);
  }

  .ysat-what-we-do-home__header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-5);
    margin-bottom: var(--space-8);
  }

  .ysat-pillar-card {
    flex: 0 0 calc(100% - 0px);
  }
}

@media (max-width: 480px) {
  .ysat-what-we-do-home {
    padding: var(--space-8) var(--space-4);
  }

  .ysat-pillar-card {
    flex: 0 0 100%;
  }

  .ysat-pillars-footer {
    flex-direction: column;
    gap: var(--space-3);
    align-items: center;
  }
}



/* =============================================================
   YSAT WHAT MAKES US DIFFERENT SECTION
   .ysat-difference-now
   Add this into ysat-brand.css
   ============================================================= */

.ysat-difference-now {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-difference-now__inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- Section header ---- */
.ysat-difference-now__header {
  margin-bottom: 48px;
}

.ysat-difference-now__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-difference-now__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-difference-now__title span {
  color: var(--color-brand-green);
}

/* ---- Main layout ---- */
.ysat-difference-now__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}

/* ---- Image panel (sticky) ---- */
.ysat-difference-now__img-panel {
  position: sticky;
  top: 110px;
}

.ysat-difference-now__img-wrap {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  height: 480px;
}

.ysat-diff-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.ysat-diff-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Dots */
.ysat-difference-now__img-dots {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-4);
}

.ysat-difference-now__img-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-difference-now__img-dot.active {
  background-color: var(--color-brand-green);
  width: 20px;
  border-radius: var(--radius-sm);
}

/* ---- Accordion panel ---- */
.ysat-difference-now__accordion {
  display: flex;
  flex-direction: column;
}

.ysat-diff-item {
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-diff-item:first-child {
  border-top: 1px solid var(--color-light-gray);
}

/* Trigger */
.ysat-diff-item__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  padding: var(--space-5) 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
}

.ysat-diff-item__trigger:hover .ysat-diff-item__title {
  color: var(--color-brand-green);
}

.ysat-diff-item__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
  transition: color var(--transition-fast);
}

.ysat-diff-item.open .ysat-diff-item__title {
  color: var(--color-brand-green);
}

/* Icon */
.ysat-diff-item__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: var(--radius-full);
  background-color: var(--color-off-white);
  font-size: var(--font-size-xs);
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), transform 0.3s ease;
}

.ysat-diff-item.open .ysat-diff-item__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
  transform: rotate(45deg);
}

/* Body panel */
.ysat-diff-item__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}

.ysat-diff-item.open .ysat-diff-item__body {
  max-height: 600px;
}

.ysat-diff-item__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  padding: 0 0 var(--space-5);
  margin: 0;
}

/* Mobile image inside accordion — hidden on desktop */
.ysat-diff-item__mobile-img {
  display: none;
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-4);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-difference-now__layout {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .ysat-difference-now__img-panel {
    display: none;
  }

  .ysat-diff-item__mobile-img {
    display: block;
  }
}

@media (max-width: 768px) {
  .ysat-difference-now {
    padding: 36px 24px;
  }

  .ysat-difference-now__header {
    margin-bottom: 32px;
  }
}

@media (max-width: 480px) {
  .ysat-difference-now {
    padding: 28px 16px;
  }
}



/* =============================================================
   YSAT TESTIMONIES HOME SECTION — Redesigned
   .ysat-testimonies-home
   Add this into ysat-brand.css
   ============================================================= */

.ysat-testimonies-home {
  position: relative;
  background-color: var(--color-forest-green);
  overflow: hidden;
}

/* Subtle grain texture overlay for depth */
.ysat-testimonies-home::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-testimonies-home__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 64px 50px 56px;
}

/* ---- Header ---- */
.ysat-testimonies-home__header {
  margin-bottom: 48px;
}

.ysat-testimonies-home__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 10px;
}

.ysat-testimonies-home__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-testimonies-home__title span {
  color: var(--color-gold-amber);
}

/* ---- Stage (overflow container) ---- */
.ysat-testimonies-home__stage {
  position: relative;
  touch-action: pan-y;
}

/* Track holds all slides stacked — we show/hide with opacity */
.ysat-testimonies-home__track {
  position: relative;
}

/* ---- Individual slide ---- */
.ysat-testimony-slide {
  display: grid;
  grid-template-columns: 96px 1fr 340px;
  gap: 0;
  align-items: stretch;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.55s ease, transform 0.55s ease;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.ysat-testimony-slide.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  position: relative;
}

/* ---- Oversized counter column ---- */
.ysat-testimony-slide__counter {
  font-family: var(--font-primary);
  font-size: 5rem;
  font-weight: var(--font-weight-black);
  color: rgba(255, 255, 255, 0.07);
  line-height: 1;
  letter-spacing: -0.04em;
  padding-top: 8px;
  user-select: none;
  flex-shrink: 0;
}

/* ---- Body column ---- */
.ysat-testimony-slide__body {
  padding: 0 48px 0 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-6);
  min-height: 280px;
}

/* Programme tag */
.ysat-testimony-slide__tag {
  display: inline-flex;
  align-self: flex-start;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 14px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* The quote — big, italic, editorial */
.ysat-testimony-slide__quote {
  font-family: var(--font-primary);
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  font-weight: var(--font-weight-medium);
  font-style: italic;
  color: var(--color-white);
  line-height: 1.75;
  margin: 0;
  quotes: none;
  position: relative;
  padding-left: 24px;
  border-left: 3px solid var(--color-gold-amber);
}

/* Footer: rule + name */
.ysat-testimony-slide__footer {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.ysat-testimony-slide__rule {
  width: 36px;
  height: 3px;
  background-color: var(--color-gold-amber);
  border-radius: 2px;
  flex-shrink: 0;
}

.ysat-testimony-slide__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  margin: 0 0 2px;
  line-height: 1.2;
}

.ysat-testimony-slide__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-soft-green);
  margin: 0;
  line-height: 1.3;
}

/* ---- Portrait column — tall image bleeding to edge ---- */
.ysat-testimony-slide__portrait {
  position: relative;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  overflow: hidden;
  min-height: 320px;
}

.ysat-testimony-slide__portrait img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: brightness(0.88) saturate(0.9);
  transition: filter 0.4s ease;
}

.ysat-testimony-slide.is-active .ysat-testimony-slide__portrait img {
  filter: brightness(1) saturate(1);
}

/* Green tint overlay on portrait */
.ysat-testimony-slide__portrait::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0, 90, 40, 0.55) 0%, transparent 60%);
  pointer-events: none;
}

/* ---- Navigation ---- */
.ysat-testimonies-home__nav {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-top: 36px;
}

.ysat-test-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  border: 1.5px solid rgba(255, 255, 255, 0.18);
  font-size: var(--font-size-base);
  color: var(--color-white);
  cursor: pointer;
  flex-shrink: 0;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.ysat-test-arrow:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

.ysat-test-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* Progress bar — auto-advance timer visualised */
.ysat-test-progress {
  flex: 1;
  height: 2px;
  background-color: rgba(255, 255, 255, 0.12);
  border-radius: 2px;
  overflow: hidden;
}

.ysat-test-progress__fill {
  height: 100%;
  width: 0%;
  background-color: var(--color-gold-amber);
  border-radius: 2px;
}

/* Dots */
.ysat-test-dots {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.ysat-test-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.25);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-test-dot.active {
  background-color: var(--color-gold-amber);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-test-dot:hover:not(.active) {
  background-color: rgba(255, 255, 255, 0.5);
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .ysat-testimonies-home__inner {
    padding: 48px 24px 40px;
  }

  .ysat-testimony-slide {
    grid-template-columns: 56px 1fr;
  }

  /* Hide portrait on tablet */
  .ysat-testimony-slide__portrait {
    display: none;
  }

  .ysat-testimony-slide__body {
    padding-right: 0;
    min-height: 240px;
  }

  .ysat-testimony-slide__counter {
    font-size: 3.5rem;
  }
}

@media (max-width: 600px) {
  .ysat-testimonies-home__inner {
    padding: 40px 16px 32px;
  }

  /* Hide counter on small mobile — more room for the quote */
  .ysat-testimony-slide {
    grid-template-columns: 1fr;
  }

  .ysat-testimony-slide__counter {
    display: none;
  }

  .ysat-testimony-slide__body {
    gap: var(--space-4);
    min-height: unset;
  }

  .ysat-testimony-slide__quote {
    padding-left: 16px;
  }

  .ysat-testimonies-home__nav {
    gap: var(--space-3);
  }

  .ysat-test-progress {
    display: none;
  }
}


.ysat-partners-home-display {
  padding: 56px 0;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-pale-green);
  border-bottom: 1px solid var(--color-pale-green);
  overflow: hidden;
}

/* Header — centered with side rules */
.ysat-partners-home-display__header {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 0 50px;
  margin-bottom: 44px;
}

.ysat-partners-home-display__rule {
  flex: 1;
  height: 2px;
  background-color: #009444;
  background-color: var(--color-brand-green);
}

.ysat-partners-home-display__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  white-space: nowrap;
}

/* ---- Marquee wrapper ---- */
.ysat-partners-marquee-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* Fade edges */
.ysat-partners-marquee-wrap::before,
.ysat-partners-marquee-wrap::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 120px;
  z-index: 2;
  pointer-events: none;
}

.ysat-partners-marquee-wrap::before {
  left: 0;
  background: linear-gradient(to right, var(--color-white) 0%, transparent 100%);
}

.ysat-partners-marquee-wrap::after {
  right: 0;
  background: linear-gradient(to left, var(--color-white) 0%, transparent 100%);
}

/* Track */
.ysat-partners-marquee-track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: ysat-marquee 70s linear infinite;
}

.ysat-partners-marquee-track:hover {
  animation-play-state: paused;
}

@keyframes ysat-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Individual logo item */
.ysat-partner-logo-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 64px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
  cursor: default;
}

.ysat-partner-logo-item:hover {
  transform: scale(1.1);
}

.ysat-partner-logo-item img {
  height: 120px;
  width: auto;
  max-width: 240px;
  object-fit: contain;
  display: block;
}

/* Vertical divider between logos */
.ysat-partner-divider {
  width: 1px;
  height: 48px;
  background-color: var(--color-light-gray);
  flex-shrink: 0;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ysat-partners-home-display {
    padding: 40px 0;
  }

  .ysat-partners-home-display__header {
    padding: 0 24px;
    margin-bottom: 32px;
  }

  .ysat-partner-logo-item img {
    height: 72px;
  }

  .ysat-partner-logo-item {
    padding: 0 36px;
  }

  .ysat-partners-marquee-wrap::before,
  .ysat-partners-marquee-wrap::after {
    width: 60px;
  }
}


/* =============================================================
   YSAT WHAT WE DO — ABOUT PAGE
   .ysat-what-we-do-about
   Add this into ysat-brand.css
   ============================================================= */

.ysat-what-we-do-about {
  padding: 48px 50px;
  background-color: var(--color-forest-green);
}

.ysat-what-we-do-about__inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- Header ---- */
.ysat-what-we-do-about__header {
  margin-bottom: 36px;
}

.ysat-what-we-do-about__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-what-we-do-about__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 8px;
}

.ysat-what-we-do-about__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
  line-height: var(--line-height-relaxed);
}

/* ---- Pillar table ---- */
.ysat-what-we-do-about__table {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* Each row: dot | SPA badge | name | description | link */
.ysat-wwd-row {
  display: grid;
  grid-template-columns: 44px 72px 240px 1fr auto;
  align-items: center;
  gap: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  transition: background-color var(--transition-base);
}

.ysat-wwd-row:last-child {
  border-bottom: none;
}

.ysat-wwd-row:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

/* Colour dot column */
.ysat-wwd-row__dot-col {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 0 28px 20px;
  align-self: stretch;
}

.ysat-wwd-row__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.ysat-wwd-row__dot--1 { background-color: var(--color-gold-amber); }
.ysat-wwd-row__dot--2 { background-color: var(--color-brand-green); }
.ysat-wwd-row__dot--3 { background-color: var(--color-soft-green); }
.ysat-wwd-row__dot--4 { background-color: #4A90D9; }
.ysat-wwd-row__dot--5 { background-color: #C3A3E0; }

/* SPA badge column */
.ysat-wwd-row__spa-col {
  padding: 28px 12px 28px 0;
  align-self: stretch;
  display: flex;
  align-items: center;
}

.ysat-wwd-row__spa {
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: var(--font-weight-extrabold);
  color: rgba(255, 255, 255, 0.35);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
}

/* Pillar name column */
.ysat-wwd-row__name-col {
  padding: 28px 24px;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  align-self: stretch;
  display: flex;
  align-items: center;
}

.ysat-wwd-row__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
  transition: color var(--transition-fast);
}

.ysat-wwd-row:hover .ysat-wwd-row__name {
  color: var(--color-gold-amber);
}

/* Description column */
.ysat-wwd-row__desc-col {
  padding: 28px 32px;
  align-self: stretch;
  display: flex;
  align-items: center;
}

.ysat-wwd-row__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.65);
  line-height: var(--line-height-relaxed);
  margin: 0;
  transition: color var(--transition-fast);
}

.ysat-wwd-row:hover .ysat-wwd-row__desc {
  color: rgba(255, 255, 255, 0.85);
}

/* Learn more link column */
.ysat-wwd-row__link-col {
  padding: 28px 24px 28px 16px;
  align-self: stretch;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.ysat-wwd-row__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  white-space: nowrap;
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-wwd-row__link:hover {
  color: var(--color-gold-amber);
  gap: 10px;
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .ysat-wwd-row {
    grid-template-columns: 40px 60px 1fr;
    grid-template-rows: auto auto auto;
  }

  .ysat-wwd-row__dot-col {
    grid-row: 1;
    grid-column: 1;
    padding: 24px 0 0 16px;
    align-self: start;
  }

  .ysat-wwd-row__spa-col {
    grid-row: 1;
    grid-column: 2;
    padding: 24px 0 0 0;
    align-self: start;
  }

  .ysat-wwd-row__name-col {
    grid-row: 1;
    grid-column: 3;
    border-right: none;
    padding: 24px 20px 6px 0;
    align-self: start;
  }

  .ysat-wwd-row__desc-col {
    grid-row: 2;
    grid-column: 2 / 4;
    padding: 0 20px 10px 0;
    align-self: start;
  }

  .ysat-wwd-row__link-col {
    grid-row: 3;
    grid-column: 2 / 4;
    padding: 0 20px 24px 0;
    align-self: start;
  }
}

@media (max-width: 768px) {
  .ysat-what-we-do-about {
    padding: 36px 24px;
  }
}

@media (max-width: 480px) {
  .ysat-what-we-do-about {
    padding: 28px 16px;
  }
}

/* =============================================================
   YSAT CORE VALUES — ABOUT PAGE
   .ysat-core-values-about
   Add this into ysat-brand.css
   ============================================================= */

.ysat-core-values-about {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-core-values-about__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

/* ---- Left: image ---- */
.ysat-core-values-about__img-col {
  position: sticky;
  top: 110px;
}

.ysat-core-values-about__img-wrap {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  height: 520px;
}

.ysat-core-values-about__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ysat-core-values-about__img-accent {
  position: absolute;
  bottom: -16px;
  right: -16px;
  width: 100px;
  height: 100px;
  background-color: var(--color-brand-green);
  opacity: 0.12;
  border-radius: var(--radius-sm);
  z-index: -1;
}

/* ---- Right: header + table ---- */
.ysat-core-values-about__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.ysat-core-values-about__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-core-values-about__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-core-values-about__title span {
  color: var(--color-brand-green);
}

/* ---- Values table ---- */
.ysat-core-values-about__table {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.ysat-cv-row {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 0;
  border-bottom: 1px solid var(--color-light-gray);
  transition: background-color var(--transition-base);
}

.ysat-cv-row:last-child {
  border-bottom: none;
}

.ysat-cv-row:hover {
  background-color: var(--color-pale-green);
}

/* Name column */
.ysat-cv-row__name-col {
  padding: 24px 20px;
  border-right: 1px solid var(--color-light-gray);
  display: flex;
  align-items: center;
}

.ysat-cv-row__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
  transition: color var(--transition-fast);
}

.ysat-cv-row:hover .ysat-cv-row__name {
  color: var(--color-brand-green);
}

/* Description column */
.ysat-cv-row__desc-col {
  padding: 24px 28px;
  display: flex;
  align-items: center;
}

.ysat-cv-row__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .ysat-core-values-about__inner {
    gap: var(--space-12);
  }

  .ysat-cv-row {
    grid-template-columns: 170px 1fr;
  }
}

@media (max-width: 900px) {
  .ysat-core-values-about__inner {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .ysat-core-values-about__img-col {
    position: static;
  }

  .ysat-core-values-about__img-wrap {
    height: 280px;
  }

  .ysat-cv-row {
    grid-template-columns: 1fr;
  }

  .ysat-cv-row__name-col {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
    padding: 18px 20px 12px;
  }

  .ysat-cv-row__desc-col {
    padding: 12px 20px 18px;
  }
}

@media (max-width: 768px) {
  .ysat-core-values-about {
    padding: 36px 24px;
  }
}

@media (max-width: 480px) {
  .ysat-core-values-about {
    padding: 28px 16px;
  }

  .ysat-core-values-about__img-wrap {
    height: 220px;
  }
}


/* =============================================================
   YSAT FOUNDERS SNAPSHOT
   .ysat-founders-snapshot
   Add this into ysat-brand.css
   ============================================================= */

.ysat-founders-snapshot {
  padding: 48px 50px;
  background-color: var(--color-near-black);
}

.ysat-founders-snapshot__inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- Header ---- */
.ysat-founders-snapshot__header {
  margin-bottom: 36px;
}

.ysat-founders-snapshot__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-founders-snapshot__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-founders-snapshot__title span {
  color: var(--color-gold-amber);
}

/* ---- List container ---- */
.ysat-founders-snapshot__list {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* ---- Divider between founder and early volunteers ---- */
.ysat-founders-snapshot__divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-8);
  background-color: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-founders-snapshot__divider::before,
.ysat-founders-snapshot__divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.1);
}

.ysat-founders-snapshot__divider span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.35);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  white-space: nowrap;
}

/* ---- Single founder row ---- */
.ysat-founder-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 28px 32px;
  transition: background-color var(--transition-base);
}

.ysat-founder-row__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-founder-row--founder {
  align-items: center;
  padding: 20px 32px;
  border-left: 3px solid var(--color-brand-green);
  border-right: 3px solid var(--color-brand-green);
}

/* ---- Photo (all rows) ---- */
.ysat-founder-row__photo {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-full);
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid rgba(255, 255, 255, 0.15);
  margin-right: var(--space-6);
}

/* Volunteer photo — free treatment */
.ysat-founder-row__photo--free {
  width: 220px;
  max-width: 220px;
  height: auto;
  overflow: hidden;
  border-radius: 16px;
  border: none;
  box-shadow: none;
  background: transparent;
  align-self: center;
  display: block;
  margin-right: var(--space-6);
}

.ysat-founder-row__photo--free img {
  width: 100%;
  height: auto;
  max-width: none;
  max-height: none;
  object-fit: unset;
  object-position: unset;
  transform: none;
  display: block;
  image-rendering: auto;
}

/* Founder photo — transparent PNG, no clip, natural size */
.ysat-founder-row--founder .ysat-founder-row__photo {
  width: 220px;
  max-width: 220px;
  height: auto;
  overflow: hidden;
  border-radius: 16px;
  border: none;
  box-shadow: none;
  background: transparent;
  align-self: center;
  display: block;
  margin-right: var(--space-6);
}

/* Base photo image */
.ysat-founder-row__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* Founder photo image */
.ysat-founder-row--founder .ysat-founder-row__photo img {
  width: 100%;
  height: auto;
  max-width: none;
  max-height: none;
  object-fit: unset;
  object-position: unset;
  transform: none;
  display: block;
  image-rendering: auto;
}

/* Initials fallback */
.ysat-founder-row__initials {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-full);
  background-color: var(--color-brand-green);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-right: var(--space-6);
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  letter-spacing: 0.05em;
}

/* Name + badge */
.ysat-founder-row__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-1);
}

.ysat-founder-row__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  margin: 0;
  line-height: 1.2;
}

.ysat-founder-row__badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.12);
  white-space: nowrap;
  flex-shrink: 0;
}

.ysat-founder-row__badge--founder {
  background-color: rgba(0, 148, 68, 0.18);
  color: var(--color-soft-green);
  border-color: rgba(0, 148, 68, 0.35);
}

.ysat-founder-row__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-soft-green);
  margin: 0;
  line-height: 1.4;
}

.ysat-founder-row__bio {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.55);
  margin: var(--space-2) 0 0;
  line-height: var(--line-height-relaxed);
}

/* ---- Link button ---- */
.ysat-founder-row__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: var(--space-8);
  flex-shrink: 0;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  white-space: nowrap;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-full);
  padding: 8px 18px;
  transition: color var(--transition-fast),
              border-color var(--transition-fast),
              background-color var(--transition-fast);
}

.ysat-founder-row__link:hover {
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  border-color: var(--color-gold-amber);
}

.ysat-founder-row__link i {
  font-size: var(--font-size-xs);
  transition: transform var(--transition-fast);
}

.ysat-founder-row__link:hover i {
  transform: translateX(3px);
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ysat-founders-snapshot {
    padding: 36px 24px;
  }

  /* ALL rows stack: photo top, text middle, link bottom */
  .ysat-founder-row,
  .ysat-founder-row--founder {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    padding: 24px 20px;
    align-items: start;
  }

  /* Photo always full width on top */
  .ysat-founder-row__photo,
  .ysat-founder-row__photo--free,
  .ysat-founder-row--founder .ysat-founder-row__photo {
    grid-row: 1;
    grid-column: 1;
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: 16px;
    border: none;
    overflow: hidden;
    margin-right: 0;
    margin-bottom: var(--space-4);
    align-self: auto;
  }

  .ysat-founder-row__photo img,
  .ysat-founder-row__photo--free img,
  .ysat-founder-row--founder .ysat-founder-row__photo img {
    width: 100%;
    height: auto;
    object-fit: unset;
  }

  /* Text always second */
  .ysat-founder-row__text,
  .ysat-founder-row--founder .ysat-founder-row__text {
    grid-row: 2;
    grid-column: 1;
  }

  /* Link always third */
  .ysat-founder-row__link,
  .ysat-founder-row--founder .ysat-founder-row__link {
    grid-row: 3;
    grid-column: 1;
    margin-left: 0;
    margin-top: var(--space-4);
    align-self: start;
  }

  .ysat-founders-snapshot__divider {
    padding: var(--space-3) var(--space-5);
  }
}

@media (max-width: 480px) {
  .ysat-founders-snapshot {
    padding: 28px 16px;
  }

  .ysat-founder-row__bio {
    display: none;
  }

  .ysat-founders-snapshot__divider {
    padding: var(--space-2) var(--space-4);
  }
}
/* =============================================================
   YSAT LOCATION & REGISTRATION
   .ysat-location-registration
   Add this into ysat-brand.css
   ============================================================= */

.ysat-location-registration {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-location-registration__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

/* ---- WHERE WE WORK ---- */
.ysat-location-registration__where {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.ysat-loc-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
}

.ysat-location-registration__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

/* Location card */
.ysat-loc-card {
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.ysat-loc-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

/* Country name */
.ysat-loc-card__country {
  font-family: var(--font-primary);
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--color-near-black);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.ysat-loc-card__country i {
  font-size: 1rem;
  color: var(--color-brand-green);
}

.ysat-loc-card--south-sudan .ysat-loc-card__country i {
  color: var(--color-gold-amber);
}

/* Description */
.ysat-loc-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.7;
  margin: 0;
}

/* Tags */
.ysat-loc-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.ysat-loc-tag {
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-forest-green);
  background-color: var(--color-mint-tint);
  border: 1px solid var(--color-soft-green);
  border-radius: 20px;
  padding: 4px 12px;
  letter-spacing: 0.04em;
}

.ysat-loc-card--south-sudan .ysat-loc-tag {
  color: #7a4f00;
  background-color: #fdf3e0;
  border-color: #f5c97a;
}

/* ---- REGISTRATION ---- */
.ysat-location-registration__reg {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 28px;
  align-items: center;
  background-color: var(--color-pale-green);
  border: 1px solid var(--color-mint-tint);
  border-radius: 6px;
  padding: 28px 32px;
}

.ysat-reg-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background-color: var(--color-brand-green);
  border-radius: 50%;
  font-size: 1.4rem;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-reg-text {}

.ysat-reg-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 6px;
  display: block;
}

.ysat-reg-body {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-near-black);
  line-height: 1.7;
  margin: 0;
}

.ysat-reg-body strong {
  font-weight: 700;
  color: var(--color-forest-green);
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ysat-location-registration {
    padding: 36px 24px;
  }

  .ysat-location-registration__cards {
    grid-template-columns: 1fr;
  }

  .ysat-location-registration__reg {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 24px 20px;
  }
}

@media (max-width: 480px) {
  .ysat-location-registration {
    padding: 28px 16px;
  }
}


/* =============================================================
   YSAT FOOD SECURITY PROGRAMME PAGE
   .food-ysat-security
   Add this into ysat-brand.css
   ============================================================= */

/* ---- Programme Intro ---- */
.food-ysat-security {
  background-color: var(--color-white);
}

/* ---- What We Do ---- */
.food-ysat-security__what {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.food-ysat-security__what-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.food-ysat-security__what-img-col {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.food-ysat-security__what-img {
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  height: 460px;
}

.food-ysat-security__what-img .prog-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.food-ysat-security__what-img .prog-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Shared slider dots (used by both sections) */
.prog-img-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 12px;
}

.prog-img-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.22s ease, width 0.22s ease;
}

.prog-img-dot.active {
  background-color: var(--color-brand-green);
  width: 20px;
  border-radius: 4px;
}

.food-ysat-security__what-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.food-ysat-security__section-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.food-ysat-security__section-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.food-ysat-security__body-text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* ---- Key Figures ---- */
.food-ysat-security__figures {
  padding: 64px 50px;
  background-color: var(--color-forest-green);
}

.food-ysat-security__figures-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.food-ysat-security__figures-header {
  margin-bottom: 40px;
}

.food-ysat-security__figures-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.food-ysat-security__figures-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.food-ysat-security__figures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.food-ysat-figure-card {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 28px 24px;
  transition: background-color 0.22s ease;
}

.food-ysat-figure-card:hover {
  background-color: rgba(255, 255, 255, 0.11);
}

.food-ysat-figure-card__number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}

.food-ysat-figure-card__label {
  font-family: var(--font-primary);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

/* ---- Why This Works ---- */
.food-ysat-security__why {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.food-ysat-security__why-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.food-ysat-security__why-text {}

.food-ysat-security__why-img {
  border-radius: 6px;
  overflow: hidden;
  height: 360px;
}

.food-ysat-security__why-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---- Testimony ---- */
.food-ysat-security__testimony {
  padding: 64px 50px;
  background-color: var(--color-off-white);
}

.food-ysat-security__testimony-inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.food-ysat-security__quote-mark {
  font-family: Georgia, serif;
  font-size: 6rem;
  line-height: 0.5;
  color: var(--color-brand-green);
  opacity: 0.2;
  display: block;
  margin-bottom: 24px;
}

.food-ysat-security__quote-text {
  font-family: var(--font-primary);
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  font-weight: 400;
  font-style: italic;
  color: var(--color-near-black);
  line-height: 1.85;
  margin: 0 0 28px;
}

.food-ysat-security__quote-author {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.food-ysat-security__quote-name {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-near-black);
}

.food-ysat-security__quote-role {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-brand-green);
}

/* ---- Donors & Partners ---- */
.food-ysat-security__donors {
  padding: 48px 50px;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-light-gray);
}

.food-ysat-security__donors-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.food-ysat-security__donors-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.food-ysat-security__donors-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.food-ysat-donor-tag {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 20px;
  padding: 6px 16px;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.food-ysat-donor-tag:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-soft-green);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .food-ysat-security__overview-inner,
  .food-ysat-security__what-inner,
  .food-ysat-security__why-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .food-ysat-security__what-img-col {
    position: static;
  }

  .food-ysat-security__overview-img,
  .food-ysat-security__why-img {
    height: 260px;
  }

  .food-ysat-security__figures-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .food-ysat-security__overview,
  .food-ysat-security__what,
  .food-ysat-security__figures,
  .food-ysat-security__why,
  .food-ysat-security__testimony,
  .food-ysat-security__donors {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .food-ysat-security__overview,
  .food-ysat-security__what,
  .food-ysat-security__figures,
  .food-ysat-security__why,
  .food-ysat-security__testimony,
  .food-ysat-security__donors {
    padding: 28px 16px;
  }

  .food-ysat-security__figures-grid {
    grid-template-columns: 1fr;
  }
}

/* =============================================================
   YSAT ENVIRONMENT & ENERGY PROGRAMME
   .env-ysat-energy
   Add this into ysat-brand.css
   ============================================================= */

.env-ysat-energy {
  background-color: var(--color-white);
}

/* ---- What We Do ---- */
.env-ysat-energy__what {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.env-ysat-energy__what-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.env-ysat-energy__what-img-col {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.env-ysat-energy__what-img {
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  height: 460px;
}

.env-ysat-energy__what-img .prog-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.env-ysat-energy__what-img .prog-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Slider dots */
.prog-img-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 12px;
}

.prog-img-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.22s ease, width 0.22s ease;
}

.prog-img-dot.active {
  background-color: var(--color-brand-green);
  width: 20px;
  border-radius: 4px;
}

.env-ysat-energy__what-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.env-ysat-energy__section-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.env-ysat-energy__section-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.env-ysat-energy__body-text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* ---- Key Figures ---- */
.env-ysat-energy__figures {
  padding: 64px 50px;
  background-color: var(--color-forest-green);
}

.env-ysat-energy__figures-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.env-ysat-energy__figures-header {
  margin-bottom: 40px;
}

.env-ysat-energy__figures-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.env-ysat-energy__figures-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.env-ysat-energy__figures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.env-ysat-figure-card {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 28px 24px;
  transition: background-color 0.22s ease;
}

.env-ysat-figure-card:hover {
  background-color: rgba(255, 255, 255, 0.11);
}

.env-ysat-figure-card__number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}

.env-ysat-figure-card__label {
  font-family: var(--font-primary);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

/* ---- Why This Works ---- */
.env-ysat-energy__why {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.env-ysat-energy__why-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.env-ysat-energy__why-img {
  border-radius: 6px;
  overflow: hidden;
  height: 360px;
}

.env-ysat-energy__why-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---- Donors & Partners ---- */
.env-ysat-energy__donors {
  padding: 48px 50px;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-light-gray);
}

.env-ysat-energy__donors-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.env-ysat-energy__donors-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.env-ysat-energy__donors-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.env-ysat-energy-donor-tag {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 20px;
  padding: 6px 16px;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.env-ysat-energy-donor-tag:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-soft-green);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .env-ysat-energy__what-inner,
  .env-ysat-energy__why-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .env-ysat-energy__what-img-col {
    position: static;
  }

  .env-ysat-energy__why-img {
    height: 260px;
  }

  .env-ysat-energy__figures-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .env-ysat-energy__what,
  .env-ysat-energy__figures,
  .env-ysat-energy__why,
  .env-ysat-energy__donors {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .env-ysat-energy__what,
  .env-ysat-energy__figures,
  .env-ysat-energy__why,
  .env-ysat-energy__donors {
    padding: 28px 16px;
  }

  .env-ysat-energy__figures-grid {
    grid-template-columns: 1fr;
  }
}



/* =============================================================
   YSAT EDUCATION IN EMERGENCIES PROGRAMME
   .edu-ysat-emergencies
   Add this into ysat-brand.css
   ============================================================= */

.edu-ysat-emergencies {
  background-color: var(--color-white);
}

/* ---- What We Do ---- */
.edu-ysat-emergencies__what {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.edu-ysat-emergencies__what-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.edu-ysat-emergencies__what-img-col {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.edu-ysat-emergencies__what-img {
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  height: 460px;
}

.edu-ysat-emergencies__what-img .prog-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.edu-ysat-emergencies__what-img .prog-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.edu-ysat-emergencies__what-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.edu-ysat-emergencies__section-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.edu-ysat-emergencies__section-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.edu-ysat-emergencies__body-text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Sub-location label */
.edu-ysat-emergencies__sub-label {
  font-family: var(--font-primary);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-forest-green);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  background-color: var(--color-mint-tint);
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  margin-top: 8px;
  margin-bottom: 4px;
}

/* ---- Key Figures ---- */
.edu-ysat-emergencies__figures {
  padding: 64px 50px;
  background-color: var(--color-forest-green);
}

.edu-ysat-emergencies__figures-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.edu-ysat-emergencies__figures-header {
  margin-bottom: 40px;
}

.edu-ysat-emergencies__figures-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.edu-ysat-emergencies__figures-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.edu-ysat-emergencies__figures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.edu-ysat-figure-card {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 28px 24px;
  transition: background-color 0.22s ease;
}

.edu-ysat-figure-card:hover {
  background-color: rgba(255, 255, 255, 0.11);
}

.edu-ysat-figure-card__number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}

.edu-ysat-figure-card__label {
  font-family: var(--font-primary);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

/* ---- Why This Works ---- */
.edu-ysat-emergencies__why {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.edu-ysat-emergencies__why-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.edu-ysat-emergencies__why-img {
  border-radius: 6px;
  overflow: hidden;
  height: 360px;
}

.edu-ysat-emergencies__why-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---- Testimony ---- */
.edu-ysat-emergencies__testimony {
  padding: 64px 50px;
  background-color: var(--color-off-white);
}

.edu-ysat-emergencies__testimony-inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.edu-ysat-emergencies__quote-mark {
  font-family: Georgia, serif;
  font-size: 6rem;
  line-height: 0.5;
  color: var(--color-brand-green);
  opacity: 0.2;
  display: block;
  margin-bottom: 24px;
}

.edu-ysat-emergencies__quote-text {
  font-family: var(--font-primary);
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  font-weight: 400;
  font-style: italic;
  color: var(--color-near-black);
  line-height: 1.85;
  margin: 0 0 28px;
}

.edu-ysat-emergencies__quote-author {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.edu-ysat-emergencies__quote-name {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-near-black);
}

.edu-ysat-emergencies__quote-role {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-brand-green);
}

/* ---- Donors & Partners ---- */
.edu-ysat-emergencies__donors {
  padding: 48px 50px;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-light-gray);
}

.edu-ysat-emergencies__donors-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.edu-ysat-emergencies__donors-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.edu-ysat-emergencies__donors-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.edu-ysat-emergencies-donor-tag {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 20px;
  padding: 6px 16px;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.edu-ysat-emergencies-donor-tag:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-soft-green);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .edu-ysat-emergencies__what-inner,
  .edu-ysat-emergencies__why-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .edu-ysat-emergencies__what-img-col {
    position: static;
  }

  .edu-ysat-emergencies__why-img {
    height: 260px;
  }

  .edu-ysat-emergencies__figures-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .edu-ysat-emergencies__what,
  .edu-ysat-emergencies__figures,
  .edu-ysat-emergencies__why,
  .edu-ysat-emergencies__testimony,
  .edu-ysat-emergencies__donors {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .edu-ysat-emergencies__what,
  .edu-ysat-emergencies__figures,
  .edu-ysat-emergencies__why,
  .edu-ysat-emergencies__testimony,
  .edu-ysat-emergencies__donors {
    padding: 28px 16px;
  }

  .edu-ysat-emergencies__figures-grid {
    grid-template-columns: 1fr;
  }
}



/* =============================================================
   YSAT PROTECTION & PEACEBUILDING PROGRAMME
   .protect-ysat-peace
   Add this into ysat-brand.css
   ============================================================= */

.protect-ysat-peace {
  background-color: var(--color-white);
}

/* ---- What We Do ---- */
.protect-ysat-peace__what {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.protect-ysat-peace__what-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.protect-ysat-peace__what-img-col {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.protect-ysat-peace__what-img {
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  height: 460px;
}

.protect-ysat-peace__what-img .prog-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.protect-ysat-peace__what-img .prog-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.protect-ysat-peace__what-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.protect-ysat-peace__section-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.protect-ysat-peace__section-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.protect-ysat-peace__body-text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* ---- Key Figures ---- */
.protect-ysat-peace__figures {
  padding: 64px 50px;
  background-color: var(--color-forest-green);
}

.protect-ysat-peace__figures-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.protect-ysat-peace__figures-header {
  margin-bottom: 40px;
}

.protect-ysat-peace__figures-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.protect-ysat-peace__figures-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.protect-ysat-peace__figures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.protect-ysat-figure-card {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 28px 24px;
  transition: background-color 0.22s ease;
}

.protect-ysat-figure-card:hover {
  background-color: rgba(255, 255, 255, 0.11);
}

.protect-ysat-figure-card__number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}

.protect-ysat-figure-card__label {
  font-family: var(--font-primary);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

/* ---- Why This Works ---- */
.protect-ysat-peace__why {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.protect-ysat-peace__why-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.protect-ysat-peace__why-img {
  border-radius: 6px;
  overflow: hidden;
  height: 360px;
}

.protect-ysat-peace__why-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---- Donors & Partners ---- */
.protect-ysat-peace__donors {
  padding: 48px 50px;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-light-gray);
}

.protect-ysat-peace__donors-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.protect-ysat-peace__donors-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.protect-ysat-peace__donors-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.protect-ysat-peace-donor-tag {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 20px;
  padding: 6px 16px;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.protect-ysat-peace-donor-tag:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-soft-green);
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .protect-ysat-peace__what-inner,
  .protect-ysat-peace__why-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .protect-ysat-peace__what-img-col {
    position: static;
  }

  .protect-ysat-peace__why-img {
    height: 260px;
  }

  .protect-ysat-peace__figures-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .protect-ysat-peace__what,
  .protect-ysat-peace__figures,
  .protect-ysat-peace__why,
  .protect-ysat-peace__donors {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .protect-ysat-peace__what,
  .protect-ysat-peace__figures,
  .protect-ysat-peace__why,
  .protect-ysat-peace__donors {
    padding: 28px 16px;
  }

  .protect-ysat-peace__figures-grid {
    grid-template-columns: 1fr;
  }
}



/* =============================================================
   YSAT TECHNOLOGY & INNOVATION PROGRAMME
   .tech-ysat-innovation
   Add this into ysat-brand.css
   ============================================================= */

.tech-ysat-innovation {
  background-color: var(--color-white);
}

.tech-ysat-innovation__what {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.tech-ysat-innovation__what-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.tech-ysat-innovation__what-img-col {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.tech-ysat-innovation__what-img {
  border-radius: 6px;
  overflow: hidden;
  width: 100%;
  height: 460px;
}

.tech-ysat-innovation__what-img .prog-img-track {
  display: flex;
  height: 100%;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.tech-ysat-innovation__what-img .prog-img-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.tech-ysat-innovation__what-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.tech-ysat-innovation__section-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.tech-ysat-innovation__section-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}

.tech-ysat-innovation__body-text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

.tech-ysat-innovation__sub-label {
  font-family: var(--font-primary);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-forest-green);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  background-color: var(--color-mint-tint);
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  margin-top: 8px;
  margin-bottom: 4px;
}

.tech-ysat-innovation__figures {
  padding: 64px 50px;
  background-color: var(--color-forest-green);
}

.tech-ysat-innovation__figures-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.tech-ysat-innovation__figures-header {
  margin-bottom: 40px;
}

.tech-ysat-innovation__figures-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 8px;
}

.tech-ysat-innovation__figures-title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.tech-ysat-innovation__figures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.tech-ysat-figure-card {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 28px 24px;
  transition: background-color 0.22s ease;
}

.tech-ysat-figure-card:hover {
  background-color: rgba(255, 255, 255, 0.11);
}

.tech-ysat-figure-card__number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 900;
  color: var(--color-gold-amber);
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}

.tech-ysat-figure-card__label {
  font-family: var(--font-primary);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

.tech-ysat-innovation__why {
  padding: 64px 50px;
  background-color: var(--color-white);
}

.tech-ysat-innovation__why-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.tech-ysat-innovation__why-img {
  border-radius: 6px;
  overflow: hidden;
  height: 360px;
}

.tech-ysat-innovation__why-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.tech-ysat-innovation__donors {
  padding: 48px 50px;
  background-color: var(--color-white);
  border-top: 1px solid var(--color-light-gray);
}

.tech-ysat-innovation__donors-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.tech-ysat-innovation__donors-label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.tech-ysat-innovation__donors-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.tech-ysat-innovation-donor-tag {
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-near-black);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: 20px;
  padding: 6px 16px;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.tech-ysat-innovation-donor-tag:hover {
  background-color: var(--color-mint-tint);
  border-color: var(--color-soft-green);
}

@media (max-width: 900px) {
  .tech-ysat-innovation__what-inner,
  .tech-ysat-innovation__why-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .tech-ysat-innovation__what-img-col {
    position: static;
  }

  .tech-ysat-innovation__why-img {
    height: 260px;
  }

  .tech-ysat-innovation__figures-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .tech-ysat-innovation__what,
  .tech-ysat-innovation__figures,
  .tech-ysat-innovation__why,
  .tech-ysat-innovation__donors {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .tech-ysat-innovation__what,
  .tech-ysat-innovation__figures,
  .tech-ysat-innovation__why,
  .tech-ysat-innovation__donors {
    padding: 28px 16px;
  }

  .tech-ysat-innovation__figures-grid {
    grid-template-columns: 1fr;
  }
}



/* =============================================================
   YSAT PROJECTS SECTION
   .ysat-inspire-project-section
   Add this into ysat-brand.css
   ============================================================= */

.ysat-inspire-project-section {
  background-color: var(--color-white);
}

/* ---- Photo Grid ---- */
.ysat-inspire-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
}

.ysat-inspire-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-inspire-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-inspire-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-inspire-photo:hover img {
  transform: scale(1.04);
}

/* Dark overlay on hover */
.ysat-inspire-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-inspire-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

/* Zoom icon */
.ysat-inspire-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-inspire-photo:hover .ysat-inspire-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* ---- Lightbox ---- */
.ysat-inspire-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-inspire-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-inspire-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-inspire-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-inspire-lightbox.open .ysat-inspire-lightbox__box {
  transform: scale(1);
}

.ysat-inspire-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-inspire-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-inspire-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-inspire-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* Large — spans 2 rows on the left */
.ysat-inspire-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

/* Wide — spans 2 columns on bottom right */
.ysat-inspire-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Project Intro ---- */
.ysat-inspire-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-inspire-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-inspire-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-inspire-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-inspire-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-inspire-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-inspire-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-inspire-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-inspire-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Four Approaches ---- */
.ysat-inspire-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-inspire-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-inspire-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-inspire-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-inspire-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-inspire-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-inspire-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-inspire-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-inspire-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-inspire-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-inspire-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-inspire-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-inspire-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-inspire-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-inspire-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Community Reach Callout ---- */
.ysat-inspire-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-inspire-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-inspire-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-inspire-project-callout__text {}

.ysat-inspire-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-inspire-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-inspire-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-inspire-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-inspire-project-intro,
  .ysat-inspire-project-approaches,
  .ysat-inspire-project-callout {
    padding: 40px 24px;
  }

  .ysat-inspire-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-inspire-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-inspire-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-inspire-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-inspire-project-intro,
  .ysat-inspire-project-approaches,
  .ysat-inspire-project-callout {
    padding: 28px 16px;
  }

  .ysat-inspire-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-inspire-photo--large,
  .ysat-inspire-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}



/* =============================================================
   YSAT PROJECTS PAGE HERO
   .ysat-projects-pages-img
   ============================================================= */

.ysat-projects-pages-img {
  position: relative;
  width: 100%;
  height: 480px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.ysat-projects-pages-img__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 18px 50px 22px;
  background-color: rgba(0, 90, 40, 0.72);
}

/* Breadcrumb */
.ysat-projects-pages-img__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
}

.ysat-projects-pages-img__breadcrumb li {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.04em;
}

.ysat-projects-pages-img__breadcrumb li a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: color 0.18s ease;
}

.ysat-projects-pages-img__breadcrumb li a:hover {
  color: var(--color-gold-amber);
}

.ysat-projects-pages-img__breadcrumb-active {
  color: var(--color-gold-amber) !important;
  font-weight: 600 !important;
}

.ysat-projects-pages-img__sep {
  color: rgba(255, 255, 255, 0.4);
  font-size: 0.7rem;
}

.ysat-projects-pages-img__title {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0;
}

/* ---- Meta bar — sticky below navbar ---- */
.ysat-projects-pages-img__meta-bar {
  background-color: var(--color-forest-green);
  width: 100%;
  position: sticky;
  top: var(--ysat-menubar-height, 90px);
  z-index: 99;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.ysat-projects-pages-img__meta-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 50px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.ysat-projects-pages-img__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

.ysat-projects-pages-img__meta-divider {
  width: 1px;
  height: 20px;
  background-color: rgba(255, 255, 255, 0.2);
  flex-shrink: 0;
}

.ysat-projects-pages-img__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ysat-projects-pages-img__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  white-space: nowrap;
}

.ysat-projects-pages-img__pill i {
  font-size: 0.8rem;
  color: var(--color-soft-green);
}

.ysat-projects-pages-img__pill + .ysat-projects-pages-img__pill::before {
  content: '·';
  color: rgba(255, 255, 255, 0.3);
  margin-right: 2px;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ysat-projects-pages-img {
    height: 400px;
  }

  .ysat-projects-pages-img__content {
    padding: 16px 24px 18px;
  }

  .ysat-projects-pages-img__meta-inner {
    padding: 14px 24px;
    gap: 12px;
  }

  .ysat-projects-pages-img__meta-divider {
    display: none;
  }
}

@media (max-width: 480px) {
  .ysat-projects-pages-img {
    height: 320px;
  }

  .ysat-projects-pages-img__content {
    padding: 14px 16px 16px;
  }

  .ysat-projects-pages-img__meta-inner {
    padding: 12px 16px;
  }

  .ysat-projects-pages-img__pill {
    font-size: 0.75rem;
  }
}

/* =============================================================
   YSAT PROJECTS SECTION
   .ysat-inspire-project-section
   Add this into ysat-brand.css
   ============================================================= */

.ysat-inspire-project-section {
  background-color: var(--color-white);
}

/* ---- Photo Grid ---- */
.ysat-inspire-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
}

.ysat-inspire-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-inspire-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-inspire-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-inspire-photo:hover img {
  transform: scale(1.04);
}

/* Dark overlay on hover */
.ysat-inspire-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-inspire-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

/* Zoom icon */
.ysat-inspire-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-inspire-photo:hover .ysat-inspire-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* ---- Lightbox ---- */
.ysat-inspire-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-inspire-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-inspire-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-inspire-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-inspire-lightbox.open .ysat-inspire-lightbox__box {
  transform: scale(1);
}

.ysat-inspire-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-inspire-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-inspire-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-inspire-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* Large — spans 2 rows on the left */
.ysat-inspire-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

/* Wide — spans 2 columns on bottom right */
.ysat-inspire-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Project Intro ---- */
.ysat-inspire-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-inspire-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-inspire-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-inspire-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-inspire-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-inspire-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-inspire-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-inspire-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-inspire-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Four Approaches ---- */
.ysat-inspire-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-inspire-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-inspire-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-inspire-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-inspire-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-inspire-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-inspire-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-inspire-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-inspire-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-inspire-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-inspire-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-inspire-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-inspire-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-inspire-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-inspire-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Community Reach Callout ---- */
.ysat-inspire-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-inspire-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-inspire-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-inspire-project-callout__text {}

.ysat-inspire-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-inspire-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-inspire-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-inspire-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-inspire-project-intro,
  .ysat-inspire-project-approaches,
  .ysat-inspire-project-callout {
    padding: 40px 24px;
  }

  .ysat-inspire-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-inspire-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-inspire-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-inspire-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-inspire-project-intro,
  .ysat-inspire-project-approaches,
  .ysat-inspire-project-callout {
    padding: 28px 16px;
  }

  .ysat-inspire-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-inspire-photo--large,
  .ysat-inspire-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}


/* =============================================================
   URRI PROJECT SECTION
   .ysat-urri-project-section
   ============================================================= */

.ysat-urri-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-urri-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-urri-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-urri-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-urri-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-urri-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Meta pills row */
.ysat-urri-project-intro__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}

.ysat-urri-project-intro__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-forest-green);
  background-color: var(--color-pale-green);
  border-radius: var(--radius-full);
  padding: 4px 12px;
  white-space: nowrap;
}

.ysat-urri-project-intro__pill i {
  font-size: 0.75rem;
  color: var(--color-brand-green);
}

/* Quick stats right side */
.ysat-urri-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-urri-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-urri-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-urri-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-urri-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-urri-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-urri-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-urri-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-urri-photo:hover img {
  transform: scale(1.04);
}

.ysat-urri-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-urri-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-urri-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-urri-photo:hover .ysat-urri-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-urri-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-urri-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-urri-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-urri-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-urri-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-urri-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-urri-lightbox.open .ysat-urri-lightbox__box {
  transform: scale(1);
}

.ysat-urri-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-urri-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-urri-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-urri-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Two Focus Areas ---- */
.ysat-urri-project-focus {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-urri-project-focus__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-urri-project-focus__header {
  margin-bottom: 36px;
}

.ysat-urri-project-focus__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-urri-project-focus__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-urri-project-focus__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-urri-focus-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-urri-focus-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-urri-focus-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-urri-focus-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-size: 1.1rem;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-urri-focus-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-urri-focus-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-urri-focus-card__results {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-urri-focus-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ysat-urri-focus-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
  min-width: 60px;
}

.ysat-urri-focus-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Community Reach Callout ---- */
.ysat-urri-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-urri-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-urri-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-urri-project-callout__text {}

.ysat-urri-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-urri-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-urri-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-urri-project-focus__grid {
    grid-template-columns: 1fr;
  }

  .ysat-urri-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-urri-project-intro,
  .ysat-urri-project-focus,
  .ysat-urri-project-callout {
    padding: 40px 24px;
  }

  .ysat-urri-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-urri-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-urri-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-urri-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-urri-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-urri-project-intro,
  .ysat-urri-project-focus,
  .ysat-urri-project-callout {
    padding: 28px 16px;
  }

  .ysat-urri-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-urri-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-urri-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-urri-photo--large,
  .ysat-urri-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}


/* =============================================================
   BRIDGE YAW PROJECT SECTION
   .ysat-yaw-project-section
   ============================================================= */
 
.ysat-yaw-project-section {
  background-color: var(--color-white);
}
 
/* ---- Project Intro ---- */
.ysat-yaw-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}
 
.ysat-yaw-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
 
.ysat-yaw-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}
 
.ysat-yaw-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}
 
.ysat-yaw-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}
 
/* Quick stats right side */
.ysat-yaw-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
 
.ysat-yaw-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}
 
.ysat-yaw-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}
 
.ysat-yaw-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}
 
/* ---- Photo Grid ---- */
.ysat-yaw-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}
 
.ysat-yaw-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}
 
.ysat-yaw-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
 
.ysat-yaw-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
 
.ysat-yaw-photo:hover img {
  transform: scale(1.04);
}
 
.ysat-yaw-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}
 
.ysat-yaw-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}
 
.ysat-yaw-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}
 
.ysat-yaw-photo:hover .ysat-yaw-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
 
.ysat-yaw-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}
 
.ysat-yaw-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}
 
/* ---- Lightbox ---- */
.ysat-yaw-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
 
.ysat-yaw-lightbox.open {
  opacity: 1;
  pointer-events: all;
}
 
.ysat-yaw-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}
 
.ysat-yaw-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}
 
.ysat-yaw-lightbox.open .ysat-yaw-lightbox__box {
  transform: scale(1);
}
 
.ysat-yaw-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}
 
.ysat-yaw-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}
 
.ysat-yaw-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
 
.ysat-yaw-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}
 
/* ---- Three Approaches ---- */
.ysat-yaw-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}
 
.ysat-yaw-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}
 
.ysat-yaw-project-approaches__header {
  margin-bottom: 36px;
}
 
.ysat-yaw-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}
 
.ysat-yaw-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}
 
.ysat-yaw-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}
 
.ysat-yaw-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}
 
.ysat-yaw-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}
 
.ysat-yaw-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}
 
.ysat-yaw-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}
 
.ysat-yaw-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}
 
.ysat-yaw-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}
 
.ysat-yaw-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}
 
.ysat-yaw-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}
 
.ysat-yaw-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}
 
/* ---- Reach Callout ---- */
.ysat-yaw-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}
 
.ysat-yaw-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}
 
.ysat-yaw-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}
 
.ysat-yaw-project-callout__text {}
 
.ysat-yaw-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}
 
.ysat-yaw-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}
 
/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-yaw-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }
 
  .ysat-yaw-project-approaches__grid {
    grid-template-columns: 1fr;
  }
 
  .ysat-yaw-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}
 
@media (max-width: 768px) {
  .ysat-yaw-project-intro,
  .ysat-yaw-project-approaches,
  .ysat-yaw-project-callout {
    padding: 40px 24px;
  }
 
  .ysat-yaw-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }
 
  .ysat-yaw-project-photos__inner {
    padding: 0 24px;
  }
 
  .ysat-yaw-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }
 
  .ysat-yaw-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }
 
  .ysat-yaw-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}
 
@media (max-width: 480px) {
  .ysat-yaw-project-intro,
  .ysat-yaw-project-approaches,
  .ysat-yaw-project-callout {
    padding: 28px 16px;
  }
 
  .ysat-yaw-project-intro__stats {
    grid-template-columns: 1fr;
  }
 
  .ysat-yaw-project-photos__inner {
    padding: 0 16px;
  }
 
  .ysat-yaw-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }
 
  .ysat-yaw-photo--large,
  .ysat-yaw-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}



/* =============================================================
   GEARED FOR SUCCESS (GFS) PROJECT SECTION
   .ysat-gfs-project-section
   ============================================================= */

.ysat-gfs-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-gfs-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-gfs-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-gfs-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-gfs-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-gfs-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-gfs-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-gfs-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-gfs-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-gfs-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-gfs-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-gfs-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-gfs-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-gfs-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-gfs-photo:hover img {
  transform: scale(1.04);
}

.ysat-gfs-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-gfs-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-gfs-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-gfs-photo:hover .ysat-gfs-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-gfs-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-gfs-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-gfs-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-gfs-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-gfs-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-gfs-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-gfs-lightbox.open .ysat-gfs-lightbox__box {
  transform: scale(1);
}

.ysat-gfs-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-gfs-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-gfs-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-gfs-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Three Approaches ---- */
.ysat-gfs-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-gfs-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-gfs-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-gfs-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-gfs-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}

.ysat-gfs-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-gfs-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-gfs-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-gfs-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-gfs-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-gfs-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-gfs-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-gfs-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-gfs-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-gfs-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-gfs-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-gfs-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-gfs-project-callout__text {}

.ysat-gfs-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-gfs-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-gfs-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-gfs-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-gfs-project-intro,
  .ysat-gfs-project-approaches,
  .ysat-gfs-project-callout {
    padding: 40px 24px;
  }

  .ysat-gfs-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-gfs-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-gfs-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-gfs-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-gfs-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-gfs-project-intro,
  .ysat-gfs-project-approaches,
  .ysat-gfs-project-callout {
    padding: 28px 16px;
  }

  .ysat-gfs-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-gfs-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-gfs-photo--large,
  .ysat-gfs-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}


/* =============================================================
   CREATIVE LEARNING HAVEN PROJECT SECTION
   .ysat-clh-project-section
   ============================================================= */

.ysat-clh-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-clh-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-clh-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-clh-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-clh-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-clh-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-clh-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-clh-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-clh-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-clh-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-clh-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-clh-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-clh-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-clh-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-clh-photo:hover img {
  transform: scale(1.04);
}

.ysat-clh-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-clh-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-clh-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-clh-photo:hover .ysat-clh-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-clh-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-clh-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-clh-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-clh-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-clh-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-clh-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-clh-lightbox.open .ysat-clh-lightbox__box {
  transform: scale(1);
}

.ysat-clh-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-clh-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-clh-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-clh-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Two Core Programmes ---- */
.ysat-clh-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-clh-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-clh-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-clh-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-clh-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-clh-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-clh-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-clh-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-clh-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-clh-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-clh-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-clh-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-clh-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-clh-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-clh-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-clh-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-clh-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-clh-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-clh-project-callout__text {}

.ysat-clh-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-clh-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-clh-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-clh-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-clh-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-clh-project-intro,
  .ysat-clh-project-approaches,
  .ysat-clh-project-callout {
    padding: 40px 24px;
  }

  .ysat-clh-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-clh-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-clh-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-clh-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-clh-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-clh-project-intro,
  .ysat-clh-project-approaches,
  .ysat-clh-project-callout {
    padding: 28px 16px;
  }

  .ysat-clh-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-clh-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-clh-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-clh-photo--large,
  .ysat-clh-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}



/* =============================================================
   DESIGN FOR SECOND LIFE INNOVATION PROJECT SECTION
   .ysat-dsli-project-section
   ============================================================= */

.ysat-dsli-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-dsli-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-dsli-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-dsli-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-dsli-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-dsli-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-dsli-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-dsli-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-dsli-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-dsli-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-dsli-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-dsli-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-dsli-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-dsli-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-dsli-photo:hover img {
  transform: scale(1.04);
}

.ysat-dsli-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-dsli-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-dsli-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-dsli-photo:hover .ysat-dsli-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-dsli-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-dsli-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-dsli-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-dsli-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-dsli-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-dsli-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-dsli-lightbox.open .ysat-dsli-lightbox__box {
  transform: scale(1);
}

.ysat-dsli-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-dsli-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-dsli-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-dsli-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Four Interventions ---- */
.ysat-dsli-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-dsli-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-dsli-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-dsli-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-dsli-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-dsli-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-dsli-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-dsli-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-dsli-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-dsli-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-dsli-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-dsli-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-dsli-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-dsli-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-dsli-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-dsli-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-dsli-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-dsli-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-dsli-project-callout__text {}

.ysat-dsli-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-dsli-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-dsli-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-dsli-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-dsli-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-dsli-project-intro,
  .ysat-dsli-project-approaches,
  .ysat-dsli-project-callout {
    padding: 40px 24px;
  }

  .ysat-dsli-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-dsli-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-dsli-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-dsli-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-dsli-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-dsli-project-intro,
  .ysat-dsli-project-approaches,
  .ysat-dsli-project-callout {
    padding: 28px 16px;
  }

  .ysat-dsli-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-dsli-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-dsli-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-dsli-photo--large,
  .ysat-dsli-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}


/* =============================================================
   DANIDA SPII (HDPI) PROJECT SECTION
   .ysat-hdpi-project-section
   ============================================================= */

.ysat-hdpi-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-hdpi-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-hdpi-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-hdpi-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-hdpi-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-hdpi-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-hdpi-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-hdpi-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-hdpi-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-hdpi-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-hdpi-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-hdpi-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-hdpi-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-hdpi-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-hdpi-photo:hover img {
  transform: scale(1.04);
}

.ysat-hdpi-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-hdpi-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-hdpi-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-hdpi-photo:hover .ysat-hdpi-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-hdpi-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-hdpi-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-hdpi-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-hdpi-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-hdpi-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-hdpi-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-hdpi-lightbox.open .ysat-hdpi-lightbox__box {
  transform: scale(1);
}

.ysat-hdpi-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-hdpi-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-hdpi-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-hdpi-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Four Interventions ---- */
.ysat-hdpi-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-hdpi-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-hdpi-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-hdpi-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-hdpi-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-hdpi-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-hdpi-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-hdpi-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-hdpi-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-hdpi-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-hdpi-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-hdpi-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-hdpi-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-hdpi-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.2rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-hdpi-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-hdpi-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-hdpi-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-hdpi-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-hdpi-project-callout__text {}

.ysat-hdpi-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-hdpi-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-hdpi-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-hdpi-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-hdpi-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-hdpi-project-intro,
  .ysat-hdpi-project-approaches,
  .ysat-hdpi-project-callout {
    padding: 40px 24px;
  }

  .ysat-hdpi-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-hdpi-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-hdpi-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-hdpi-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-hdpi-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-hdpi-project-intro,
  .ysat-hdpi-project-approaches,
  .ysat-hdpi-project-callout {
    padding: 28px 16px;
  }

  .ysat-hdpi-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-hdpi-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-hdpi-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-hdpi-photo--large,
  .ysat-hdpi-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}


/* =============================================================
   ENVIRONMENT AND ENERGY PROJECT SECTION
   .ysat-eep-project-section
   ============================================================= */

.ysat-eep-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-eep-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-eep-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-eep-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-eep-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-eep-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-eep-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-eep-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-eep-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-eep-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-eep-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-eep-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-eep-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-eep-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-eep-photo:hover img {
  transform: scale(1.04);
}

.ysat-eep-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-eep-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-eep-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-eep-photo:hover .ysat-eep-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-eep-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-eep-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-eep-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-eep-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-eep-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-eep-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-eep-lightbox.open .ysat-eep-lightbox__box {
  transform: scale(1);
}

.ysat-eep-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-eep-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-eep-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-eep-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Four Interventions ---- */
.ysat-eep-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-eep-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-eep-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-eep-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-eep-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-eep-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.ysat-eep-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-eep-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-eep-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-eep-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-eep-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-eep-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-eep-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-eep-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.2rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-eep-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-eep-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-eep-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-eep-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-eep-project-callout__text {}

.ysat-eep-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-eep-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-eep-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-eep-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-eep-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-eep-project-intro,
  .ysat-eep-project-approaches,
  .ysat-eep-project-callout {
    padding: 40px 24px;
  }

  .ysat-eep-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-eep-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-eep-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-eep-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-eep-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-eep-project-intro,
  .ysat-eep-project-approaches,
  .ysat-eep-project-callout {
    padding: 28px 16px;
  }

  .ysat-eep-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-eep-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-eep-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-eep-photo--large,
  .ysat-eep-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}



/* =============================================================
   AFRICAN YOUTH PANEL (AYP) PROJECT SECTION
   .ysat-ayp-project-section
   ============================================================= */

.ysat-ayp-project-section {
  background-color: var(--color-white);
}

/* ---- Project Intro ---- */
.ysat-ayp-project-intro {
  padding: 48px 50px;
  background-color: var(--color-white);
}

.ysat-ayp-project-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.ysat-ayp-project-intro__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 12px;
}

.ysat-ayp-project-intro__title {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-ayp-project-intro__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
}

/* Quick stats right side */
.ysat-ayp-project-intro__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ysat-ayp-project-stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 24px 20px;
  text-align: center;
}

.ysat-ayp-project-stat__number {
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 6px;
}

.ysat-ayp-project-stat__label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

/* ---- Photo Grid ---- */
.ysat-ayp-project-photos__inner {
  max-width: 1200px;
  margin: 32px auto 0;
  padding: 0 50px;
}

.ysat-ayp-project-photos__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: 8px;
  border-radius: 8px;
  overflow: hidden;
}

.ysat-ayp-photo {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.ysat-ayp-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-ayp-photo:hover img {
  transform: scale(1.04);
}

.ysat-ayp-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 40, 20, 0);
  transition: background-color 0.25s ease;
  pointer-events: none;
  z-index: 1;
}

.ysat-ayp-photo:hover::after {
  background-color: rgba(0, 40, 20, 0.3);
}

.ysat-ayp-photo__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.7);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--color-forest-green);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 2;
}

.ysat-ayp-photo:hover .ysat-ayp-photo__zoom {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.ysat-ayp-photo--large {
  grid-column: 1;
  grid-row: 1 / 3;
}

.ysat-ayp-photo--wide {
  grid-column: 2 / 4;
  grid-row: 2;
}

/* ---- Lightbox ---- */
.ysat-ayp-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.ysat-ayp-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.ysat-ayp-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.88);
  cursor: pointer;
}

.ysat-ayp-lightbox__box {
  position: relative;
  z-index: 1;
  width: 90vw;
  max-width: 1000px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  transform: scale(0.92);
  transition: transform 0.3s ease;
}

.ysat-ayp-lightbox.open .ysat-ayp-lightbox__box {
  transform: scale(1);
}

.ysat-ayp-lightbox__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}

.ysat-ayp-lightbox__caption {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
  margin: 0;
  align-self: flex-start;
}

.ysat-ayp-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 10000;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--color-white);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ysat-ayp-lightbox__close:hover {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
}

/* ---- Three Programme Phases ---- */
.ysat-ayp-project-approaches {
  padding: 48px 50px;
  background-color: var(--color-off-white);
}

.ysat-ayp-project-approaches__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-ayp-project-approaches__header {
  margin-bottom: 36px;
}

.ysat-ayp-project-approaches__label {
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-ayp-project-approaches__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-ayp-project-approaches__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}

.ysat-ayp-approach-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-ayp-approach-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-3px);
}

.ysat-ayp-approach-card__top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ysat-ayp-approach-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-brand-green);
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 900;
  color: var(--color-white);
  flex-shrink: 0;
}

.ysat-ayp-approach-card__name {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-ayp-approach-card__desc {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
}

.ysat-ayp-approach-card__result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-ayp-approach-card__result-number {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--color-brand-green);
  line-height: 1;
  flex-shrink: 0;
}

.ysat-ayp-approach-card__result-label {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
}

/* ---- Reach Callout ---- */
.ysat-ayp-project-callout {
  padding: 48px 50px;
  background-color: var(--color-brand-green);
}

.ysat-ayp-project-callout__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.ysat-ayp-project-callout__number {
  font-family: var(--font-primary);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}

.ysat-ayp-project-callout__text {}

.ysat-ayp-project-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 10px;
}

.ysat-ayp-project-callout__desc {
  font-family: var(--font-primary);
  font-size: 0.92rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.7;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .ysat-ayp-project-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .ysat-ayp-project-approaches__grid {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-project-callout__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ysat-ayp-project-intro,
  .ysat-ayp-project-approaches,
  .ysat-ayp-project-callout {
    padding: 40px 24px;
  }

  .ysat-ayp-project-intro__stats {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-ayp-project-photos__inner {
    padding: 0 24px;
  }

  .ysat-ayp-project-photos__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 200px 200px 200px;
  }

  .ysat-ayp-photo--large {
    grid-column: 1 / 3;
    grid-row: 1;
  }

  .ysat-ayp-photo--wide {
    grid-column: 1 / 3;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .ysat-ayp-project-intro,
  .ysat-ayp-project-approaches,
  .ysat-ayp-project-callout {
    padding: 28px 16px;
  }

  .ysat-ayp-project-intro__stats {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-project-photos__inner {
    padding: 0 16px;
  }

  .ysat-ayp-project-photos__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, 200px);
  }

  .ysat-ayp-photo--large,
  .ysat-ayp-photo--wide {
    grid-column: 1;
    grid-row: auto;
  }
}



/* =============================================================
   YSAT PROJECTS LISTING SECTION
   .ysat-projects-listing
   ============================================================= */

.ysat-projects-listing {
  padding: 64px 50px;
  background-color: var(--color-off-white);
}

.ysat-projects-listing__inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- Section Header ---- */
.ysat-projects-listing__header {
  width: 100%;
  margin-bottom: 40px;
}

.ysat-projects-listing__header-desc {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
  text-align: justify;
}

/* ---- Filter Tabs ---- */
.ysat-projects-listing__tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.ysat-projects-listing__tab {
  padding: 8px 20px;
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-dark-gray);
  background-color: var(--color-white);
  border: 1.5px solid var(--color-light-gray);
  border-radius: var(--radius-full);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: background-color 0.18s ease,
              color 0.18s ease,
              border-color 0.18s ease;
}

.ysat-projects-listing__tab:hover {
  border-color: var(--color-brand-green);
  color: var(--color-brand-green);
}

.ysat-projects-listing__tab.is-active {
  background-color: var(--color-brand-green);
  border-color: var(--color-brand-green);
  color: var(--color-white);
}

/* ---- Projects Grid ---- */
.ysat-projects-listing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* ---- Project Card ---- */
.ysat-project-card {
  background-color: var(--color-white);
  border-radius: 10px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-project-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

/* Card top — badges + title + subtitle */
.ysat-project-card__top {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ysat-project-card__badges {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* Status badge */
.ysat-project-card__status {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-primary);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}

.ysat-project-card__status--active {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-project-card__status--ongoing {
  background-color: var(--color-forest-green);
  color: var(--color-white);
}

.ysat-project-card__status--completed {
  background-color: var(--color-light-gray);
  color: var(--color-dark-gray);
}

/* Theme pill */
.ysat-project-card__theme {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-primary);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background-color: var(--color-pale-green);
  color: var(--color-forest-green);
}

.ysat-project-card__title {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin: 0;
}

.ysat-project-card__subtitle {
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  line-height: 1.4;
  margin: 0;
}

/* Description */
.ysat-project-card__desc {
  font-family: var(--font-primary);
  font-size: 0.88rem;
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.75;
  margin: 0;
  flex-grow: 1;
}

/* Meta list */
.ysat-project-card__meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding-top: 12px;
  border-top: 1px solid var(--color-light-gray);
}

.ysat-project-card__meta li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.4;
}

.ysat-project-card__meta li i {
  font-size: 0.78rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  width: 14px;
}

/* Stats row */
.ysat-project-card__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.ysat-project-card__stat {
  background-color: var(--color-pale-green);
  border-radius: 6px;
  padding: 12px 10px;
  text-align: center;
}

.ysat-project-card__stat-number {
  display: block;
  font-family: var(--font-primary);
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--color-forest-green);
  line-height: 1;
  margin-bottom: 4px;
}

.ysat-project-card__stat-label {
  display: block;
  font-family: var(--font-primary);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--color-dark-gray);
  line-height: 1.35;
}

/* Read more button */
.ysat-project-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  padding: 10px 20px;
  font-family: var(--font-primary);
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--color-white);
  background-color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: 5px;
  transition: background-color 0.18s ease, transform 0.18s ease;
}

.ysat-project-card__btn:hover {
  background-color: var(--color-forest-green);
  color: var(--color-white);
  transform: translateX(3px);
}

.ysat-project-card__btn i {
  font-size: 0.8rem;
  transition: transform 0.18s ease;
}

.ysat-project-card__btn:hover i {
  transform: translateX(3px);
}

/* Completed card — slightly muted */
.ysat-project-card[data-status="completed"] {
  opacity: 0.88;
}

.ysat-project-card[data-status="completed"] .ysat-project-card__btn {
  background-color: var(--color-dark-gray);
}

.ysat-project-card[data-status="completed"] .ysat-project-card__btn:hover {
  background-color: var(--color-near-black);
}

/* Empty state */
.ysat-projects-listing__empty {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-mid-gray);
  text-align: center;
  padding: 48px 0;
  margin: 0;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .ysat-projects-listing__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .ysat-projects-listing {
    padding: 48px 24px;
  }

  .ysat-projects-listing__grid {
    grid-template-columns: 1fr;
  }

  .ysat-projects-listing__tabs {
    gap: 6px;
  }

  .ysat-projects-listing__tab {
    padding: 7px 14px;
    font-size: 0.78rem;
  }
}

@media (max-width: 480px) {
  .ysat-projects-listing {
    padding: 36px 16px;
  }

  .ysat-project-card__stats {
    grid-template-columns: 1fr;
  }
}


/* =============================================================
   YSAT STRATEGIC DIRECTION & SCALING PLAN 2026–2030
   .ysat-strategy-section
   ============================================================= */

.ysat-strategy-section {
  background-color: var(--color-white);
  padding: 64px 50px;
  overflow: hidden;
}

.ysat-strategy-section__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 72px;
  width: 100%;
}

/* ============================================================
   THE PLAN + AMBITION
   ============================================================ */
.ysat-strategy-plan {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  width: 100%;
}

.ysat-strategy-plan__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-near-black);
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}

.ysat-strategy-plan__text {
  min-width: 0;
}

.ysat-strategy-plan__text p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0 0 12px;
}

.ysat-strategy-plan__text p:last-of-type {
  margin-bottom: 20px;
}

/* SDG sliding carousel */
.ysat-strategy-plan__sdgs {
  overflow: hidden;
  width: 100%;
  margin-top: 8px;
  position: relative;
}

/* Fade edges */
.ysat-strategy-plan__sdgs::before,
.ysat-strategy-plan__sdgs::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 40px;
  z-index: 2;
  pointer-events: none;
}

.ysat-strategy-plan__sdgs::before {
  left: 0;
  background: linear-gradient(to right, var(--color-white), transparent);
}

.ysat-strategy-plan__sdgs::after {
  right: 0;
  background: linear-gradient(to left, var(--color-white), transparent);
}

.ysat-strategy-sdg-track {
  overflow: hidden;
  width: 100%;
}

.ysat-strategy-sdg-track__inner {
  display: flex;
  align-items: center;
  gap: 14px;
  width: max-content;
  animation: ysatSdgScroll 22s linear infinite;
}

.ysat-strategy-sdg-track__inner img {
  height: 100px;
  width: 100px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 8px;
  display: block;
}

@keyframes ysatSdgScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Ambition card */
.ysat-strategy-plan__ambition {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.ysat-strategy-ambition-card {
  background-color: var(--color-forest-green);
  border-radius: 10px;
  padding: 36px 32px;
  color: var(--color-white);
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  box-sizing: border-box;
}

.ysat-strategy-ambition-card__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-soft-green);
}

.ysat-strategy-ambition-card__number {
  font-family: var(--font-primary);
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
}

.ysat-strategy-ambition-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.6;
}

.ysat-strategy-ambition-card__growth {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-strategy-ambition-card__growth-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ysat-strategy-ambition-card__growth-num {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
}

.ysat-strategy-ambition-card__growth-year {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 500;
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.ysat-strategy-ambition-card__growth-arrow {
  font-size: 1.4rem;
  color: var(--color-gold-amber);
  flex-shrink: 0;
}

.ysat-strategy-ambition-card__multiplier {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ============================================================
   FIVE STRATEGIC PRIORITY AREAS
   ============================================================ */
.ysat-strategy-spas__header {
  margin-bottom: 36px;
}

.ysat-strategy-spas__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-strategy-spas__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
}

.ysat-strategy-spas__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}

.ysat-strategy-spa-card {
  background-color: var(--color-off-white);
  border-radius: 10px;
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.ysat-strategy-spa-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
  transform: translateY(-4px);
}

.ysat-strategy-spa-card:nth-child(1),
.ysat-strategy-spa-card:nth-child(2),
.ysat-strategy-spa-card:nth-child(3) {
  grid-column: span 2;
}

.ysat-strategy-spa-card:nth-child(4),
.ysat-strategy-spa-card:nth-child(5) {
  grid-column: span 3;
}

.ysat-strategy-spa-card__num {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 800;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.ysat-strategy-spa-card__icon {
  font-size: 1.6rem;
  color: var(--color-brand-green);
  line-height: 1;
}

.ysat-strategy-spa-card__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-strategy-spa-card__goal {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.6;
  margin: 0;
  font-style: italic;
}

.ysat-strategy-spa-card__goal strong {
  font-style: normal;
  color: var(--color-near-black);
}

.ysat-strategy-spa-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-mid-gray);
  line-height: 1.65;
  margin: 0;
}

/* ============================================================
   SCALING PLANS
   ============================================================ */
.ysat-strategy-scaling {
  background-color: var(--color-pale-green);
  border-radius: 12px;
  padding: 48px 44px;
}

.ysat-strategy-scaling__header {
  margin-bottom: 36px;
}

.ysat-strategy-scaling__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  display: block;
  margin-bottom: 10px;
}

.ysat-strategy-scaling__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
}

.ysat-strategy-scaling__intro {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.8;
  margin: 0;
  max-width: 800px;
}

.ysat-strategy-scaling__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.ysat-strategy-scale-card {
  background-color: var(--color-white);
  border-radius: 8px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.22s ease;
}

.ysat-strategy-scale-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.ysat-strategy-scale-card__icon {
  font-size: 1.4rem;
  color: var(--color-brand-green);
  line-height: 1;
}

.ysat-strategy-scale-card__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 900;
  color: var(--color-near-black);
  line-height: 1.25;
  margin: 0;
}

.ysat-strategy-scale-card__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ysat-strategy-scale-card__list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-dark-gray);
  line-height: 1.55;
}

.ysat-strategy-scale-card__list li i {
  color: var(--color-brand-green);
  font-size: var(--font-size-xs);
  flex-shrink: 0;
  margin-top: 3px;
}

/* ============================================================
   CLOSING CALLOUT
   ============================================================ */
.ysat-strategy-callout {
  background-color: var(--color-brand-green);
  border-radius: 12px;
  padding: 48px 44px;
}

.ysat-strategy-callout__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: center;
}

.ysat-strategy-callout__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1.25;
  margin: 0 0 14px;
}

.ysat-strategy-callout__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.75;
  margin: 0;
}

.ysat-strategy-callout__stat {
  text-align: center;
  flex-shrink: 0;
  min-width: 160px;
}

.ysat-strategy-callout__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 900;
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
}

.ysat-strategy-callout__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 8px;
  line-height: 1.4;
  max-width: 140px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .ysat-strategy-spas__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-strategy-spa-card:nth-child(1),
  .ysat-strategy-spa-card:nth-child(2),
  .ysat-strategy-spa-card:nth-child(3),
  .ysat-strategy-spa-card:nth-child(4),
  .ysat-strategy-spa-card:nth-child(5) {
    grid-column: span 1;
  }
}

@media (max-width: 900px) {
  .ysat-strategy-section {
    padding: 48px 24px;
  }

  .ysat-strategy-plan {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ysat-strategy-spas__grid {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-strategy-scaling {
    padding: 36px 24px;
  }

  .ysat-strategy-scaling__grid {
    grid-template-columns: 1fr 1fr;
  }

  .ysat-strategy-callout__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .ysat-strategy-callout__stat {
    margin: 0 auto;
  }
}

@media (max-width: 600px) {
  .ysat-strategy-section {
    padding: 36px 16px;
  }

  .ysat-strategy-section__inner {
    gap: 48px;
  }

  .ysat-strategy-spas__grid {
    grid-template-columns: 1fr;
  }

  .ysat-strategy-spa-card:nth-child(n) {
    grid-column: span 1;
  }

  .ysat-strategy-scaling {
    padding: 28px 16px;
  }

  .ysat-strategy-scaling__grid {
    grid-template-columns: 1fr;
  }

  .ysat-strategy-callout {
    padding: 28px 16px;
  }
}


/* =============================================================
   YSAT — Where We Work Section
   Class prefix: .ysat-wwm__
   Depends on: ysat-brand.css (CSS vars, font, reset)
   ============================================================= */

/* ---- Section shell ---- */
.ysat-wwm {
  padding: 56px 50px;
  background: var(--color-white);
}

.ysat-wwm__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ---- Section header ---- */
.ysat-wwm__head {
  text-align: center;
  max-width: 640px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ysat-wwm__eyebrow {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  color: var(--color-brand-green);
}

.ysat-wwm__title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: var(--line-height-tight);
}

.ysat-wwm__sub {
  font-size: var(--font-size-base);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

/* ---- Body: list + right panel ---- */
.ysat-wwm__body {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: var(--space-6);
  align-items: start;
}

/* ---- Location list (left column) ---- */
.ysat-wwm__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  background: var(--color-white);
  border: 1.5px solid #d8d8d8;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: calc(90px + var(--space-6));
}

.ysat-wwm__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: 13px var(--space-4);
  background: var(--color-white);
  border: 1.5px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--transition-base),
              background-color var(--transition-base),
              box-shadow var(--transition-base);
  position: relative;
}

.ysat-wwm__item:hover {
  border-color: var(--color-brand-green);
  background: var(--color-pale-green);
}

.ysat-wwm__item.is-active {
  border-color: var(--color-brand-green);
  background: var(--color-brand-green);
  box-shadow: 0 3px 10px rgba(0,148,68,0.25);
}

.ysat-wwm__item-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-brand-green);
  flex-shrink: 0;
  transition: background var(--transition-base);
}

.ysat-wwm__item-dot--hq {
  width: 12px;
  height: 12px;
  box-shadow: 0 0 0 3px rgba(0,148,68,0.2);
}

.ysat-wwm__item-dot--ss { background: var(--color-gold-amber); }

.ysat-wwm__item.is-active .ysat-wwm__item-dot { background: rgba(255,255,255,0.8); }
.ysat-wwm__item.is-active .ysat-wwm__item-dot--ss { background: var(--color-gold-amber); }

.ysat-wwm__item-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ysat-wwm__item-name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-near-black);
  line-height: var(--line-height-tight);
  transition: color var(--transition-base);
}

.ysat-wwm__item.is-active .ysat-wwm__item-name { color: var(--color-white); }

.ysat-wwm__hq-badge {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  background: var(--color-gold-amber);
  color: var(--color-near-black);
  border-radius: var(--radius-sm);
  padding: 1px 5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  vertical-align: middle;
  margin-left: 4px;
}

.ysat-wwm__item.is-active .ysat-wwm__hq-badge {
  background: rgba(255,255,255,0.25);
  color: var(--color-white);
}

.ysat-wwm__item-country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
  transition: color var(--transition-base);
}

.ysat-wwm__item.is-active .ysat-wwm__item-country { color: rgba(255,255,255,0.72); }

.ysat-wwm__item-arrow {
  width: 16px;
  height: 16px;
  color: var(--color-light-gray);
  flex-shrink: 0;
  transition: color var(--transition-base), transform var(--transition-base);
}

.ysat-wwm__item:hover .ysat-wwm__item-arrow {
  color: var(--color-brand-green);
  transform: translateX(2px);
}

.ysat-wwm__item.is-active .ysat-wwm__item-arrow {
  color: rgba(255,255,255,0.7);
  transform: translateX(2px);
}

/* Stats strip */
.ysat-wwm__stats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.ysat-wwm__stat {
  background: var(--color-forest-green);
  border-radius: var(--radius-md);
  padding: 12px 8px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ysat-wwm__stat-n {
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: 1;
}

.ysat-wwm__stat-l {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255,255,255,0.65);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ---- Right column: map + card ---- */
.ysat-wwm__right {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* ---- SVG Map ---- */
.ysat-wwm__map {
  background: transparent;
  position: relative;
  flex-shrink: 0;
}

.ysat-wwm__svg {
  width: 100%;
  height: 520px;
  display: block;
  vertical-align: top;
  margin: 0;
  padding: 0;
}

.ysat-wwm__country { stroke: #C8C8C8; stroke-width: 0.12; }
.ysat-wwm__country--ug { fill: #FFFFFF; stroke: #C8C8C8; stroke-width: 0.15; }
.ysat-wwm__country--ss { fill: #D6F0E2; stroke: #FFFFFF; stroke-width: 0.15; }

.ysat-wwm__clabel {
  font-family: Archivo, sans-serif;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.22em;
  text-anchor: middle;
  fill: rgba(0,90,40,0.55);
  pointer-events: none;
}

.ysat-wwm__clabel--ug { fill: rgba(0,90,40,0.62); }

.ysat-wwm__pin { cursor: pointer; outline: none; }
.ysat-wwm__pin:focus-visible circle { outline: 2px solid var(--color-gold-amber); }

.ysat-wwm__pulse { fill: #009444; pointer-events: none; display: none; }
.ysat-wwm__pulse--ss { fill: #E8A020; }
.ysat-wwm__pin.is-active .ysat-wwm__pulse { display: block; }

.ysat-wwm__pin-bg {
  fill: var(--color-brand-green);
  stroke: var(--color-white);
  stroke-width: 2;
  transition: fill 0.18s ease;
}

.ysat-wwm__pin-bg--ss { fill: var(--color-gold-amber); }
.ysat-wwm__pin:hover .ysat-wwm__pin-bg { fill: var(--color-deep-green); }

.ysat-wwm__pin.is-active .ysat-wwm__pin-bg {
  fill: var(--color-forest-green);
  filter: drop-shadow(0 0 5px rgba(0,90,40,0.6));
}

.ysat-wwm__pin:hover .ysat-wwm__pin-bg--ss,
.ysat-wwm__pin.is-active .ysat-wwm__pin-bg--ss {
  fill: var(--color-gold-amber-dk);
  filter: drop-shadow(0 0 5px rgba(200,125,10,0.7));
}

.ysat-wwm__pin-icon {
  font-size: 14px;
  fill: var(--color-white);
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
  font-family: Archivo, sans-serif;
}

.ysat-wwm__pin-lbl {
  font-family: Archivo, sans-serif;
  font-size: 11px;
  font-weight: 800;
  fill: var(--color-forest-green);
  pointer-events: none;
}

.ysat-wwm__pin-lbl--hq { font-size: 12px; font-weight: 900; }
.ysat-wwm__pin-lbl--ss { fill: var(--color-gold-amber-dk); font-size: 11px; font-weight: 800; }

.ysat-wwm__fdot {
  fill: var(--color-gold-amber);
  fill-opacity: 0.65;
  stroke: var(--color-white);
  stroke-width: 1;
}

.ysat-wwm__flbl {
  font-family: Archivo, sans-serif;
  font-size: 10.5px;
  font-style: italic;
  font-weight: 600;
  fill: var(--color-gold-amber-dk);
}

/* ---- Detail card ---- */
.ysat-wwm__card {
  background: var(--color-white);
  border: 1.5px solid var(--color-light-gray);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  min-height: 190px;
  margin-top: var(--space-4);
  box-shadow: var(--shadow-sm);
}

.ysat-wwm__detail { display: none; flex-direction: column; gap: var(--space-4); animation: ysatWwwFadeIn 0.22s ease; }
.ysat-wwm__detail.is-active { display: flex; }

@keyframes ysatWwwFadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: translateY(0); }
}

.ysat-wwm__card-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.ysat-wwm__badge {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 3px 11px;
  border-radius: var(--radius-full);
  background: var(--color-mint-tint);
  color: var(--color-forest-green);
}

.ysat-wwm__badge--hq { background: var(--color-brand-green); color: var(--color-white); }
.ysat-wwm__badge--ss { background: var(--color-gold-amber); color: var(--color-near-black); }

.ysat-wwm__card-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-tight);
}

.ysat-wwm__card-addr {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}

.ysat-wwm__card-addr svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; }

.ysat-wwm__card-note {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-mid-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  padding-left: var(--space-3);
  border-left: 3px solid var(--color-mint-tint);
}

.ysat-wwm__card-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brand-green);
  background: var(--color-pale-green);
  border-radius: var(--radius-full);
  padding: 4px 14px;
  align-self: flex-start;
}

.ysat-wwm__card-tag svg { width: 13px; height: 13px; }

.ysat-wwm__field-sites { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.ysat-wwm__field-sites span {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-dark-gray);
  background: var(--color-off-white);
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-full);
  padding: 4px 13px;
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .ysat-wwm__body { grid-template-columns: 1fr; }
  .ysat-wwm__list { display: grid; grid-template-columns: 1fr 1fr; position: static; }
  .ysat-wwm__stats { grid-column: 1 / -1; }
  .ysat-wwm__svg { height: 400px; }
  .ysat-wwm__card { min-height: unset; }
}

@media (max-width: 600px) {
  .ysat-wwm { padding: 40px 24px; }
  .ysat-wwm__list { grid-template-columns: 1fr; }
  .ysat-wwm__svg { height: 320px; }
  .ysat-wwm__title { font-size: var(--font-size-2xl); }
  .ysat-wwm__card { padding: var(--space-5) var(--space-4); }
}

@media (max-width: 480px) {
  .ysat-wwm { padding: 32px 16px; }
}



/* =============================================================
   SPA 1 — HUMANITARIAN RESPONSE & PEACEBUILDING
   Page sections for humanitarian-response.html
   Prefix: ysat-humanitarian-response-
   Add this into ysat-brand.css
   ============================================================= */


/* ============================================================
   SECTION 1: PAGE HERO
   ============================================================ */

.ysat-humanitarian-response-hero {
  padding: 64px 50px 56px;
  background-color: var(--color-forest-green);
  position: relative;
  overflow: hidden;
}

.ysat-humanitarian-response-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-humanitarian-response-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-humanitarian-response-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ysat-humanitarian-response-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-humanitarian-response-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-soft-green);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-humanitarian-response-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
  max-width: 700px;
}

.ysat-humanitarian-response-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-humanitarian-response-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
  max-width: 680px;
}

/* Stats band */
.ysat-humanitarian-response-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-top: var(--space-2);
}

.ysat-humanitarian-response-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-humanitarian-response-hero__stat:last-child {
  border-right: none;
}

.ysat-humanitarian-response-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-humanitarian-response-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-humanitarian-response-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: PROJECTS LISTING
   ============================================================ */

.ysat-humanitarian-response-projects {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-humanitarian-response-projects__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-humanitarian-response-projects__header {
  margin-bottom: 40px;
}

.ysat-humanitarian-response-projects__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-humanitarian-response-projects__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-humanitarian-response-projects__title span {
  color: var(--color-brand-green);
}

.ysat-humanitarian-response-projects__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 680px;
}

/* Projects grid — 3 columns, cards equal height per row */
.ysat-humanitarian-response-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* ---- Project card ---- */
.ysat-humanitarian-response-project-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.ysat-humanitarian-response-project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-soft-green);
}

/* Card body */
.ysat-humanitarian-response-project-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
}

/* Top row: icon left, status right */
.ysat-humanitarian-response-project-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-humanitarian-response-project-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-humanitarian-response-project-card:hover .ysat-humanitarian-response-project-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

/* Status badge */
.ysat-humanitarian-response-project-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.ysat-humanitarian-response-project-card__status--active {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border: 1px solid var(--color-soft-green);
}

.ysat-humanitarian-response-project-card__status--completed {
  background-color: var(--color-off-white);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

/* Title */
.ysat-humanitarian-response-project-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

/* Description — grows to push link to bottom */
.ysat-humanitarian-response-project-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

/* Link — always pinned to bottom */
.ysat-humanitarian-response-project-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-4);
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-light-gray);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.ysat-humanitarian-response-project-card__link:hover {
  color: var(--color-forest-green);
  gap: var(--space-3);
}


/* ============================================================
   SECTION 3: KEY RESULTS
   ============================================================ */

.ysat-humanitarian-response-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-humanitarian-response-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-humanitarian-response-results__header {
  margin-bottom: 40px;
}

.ysat-humanitarian-response-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-humanitarian-response-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-humanitarian-response-results__title span {
  color: var(--color-brand-green);
}

.ysat-humanitarian-response-results__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-humanitarian-response-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  border-bottom: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-humanitarian-response-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-humanitarian-response-result:nth-child(3n) {
  border-right: none;
}

.ysat-humanitarian-response-result:nth-last-child(-n+3) {
  border-bottom: none;
}

.ysat-humanitarian-response-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-humanitarian-response-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-humanitarian-response-projects__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-humanitarian-response-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-humanitarian-response-result:nth-child(3n) {
    border-right: 1px solid var(--color-light-gray);
  }

  .ysat-humanitarian-response-result:nth-child(2n) {
    border-right: none;
  }

  .ysat-humanitarian-response-result:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-humanitarian-response-result:nth-last-child(-n+2) {
    border-bottom: none;
  }
}

@media (max-width: 768px) {
  .ysat-humanitarian-response-hero {
    padding: 40px 24px 36px;
  }

  .ysat-humanitarian-response-projects,
  .ysat-humanitarian-response-results {
    padding: 40px 24px;
  }

  .ysat-humanitarian-response-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-humanitarian-response-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-humanitarian-response-hero__stat:nth-child(1),
  .ysat-humanitarian-response-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-humanitarian-response-projects__grid {
    grid-template-columns: 1fr;
  }

  .ysat-humanitarian-response-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-humanitarian-response-result {
    border-right: none;
  }

  .ysat-humanitarian-response-result:nth-last-child(-n+2) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-humanitarian-response-result:last-child {
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  .ysat-humanitarian-response-hero {
    padding: 32px 16px 28px;
  }

  .ysat-humanitarian-response-projects,
  .ysat-humanitarian-response-results {
    padding: 32px 16px;
  }

  .ysat-humanitarian-response-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-humanitarian-response-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-humanitarian-response-hero__stat:last-child {
    border-bottom: none;
  }
}


/* =============================================================
   SPA 2 — PROTECTING COMMUNITIES ON THE MOVE
   Page sections for protection-peacebuilding.html
   Prefix: ysat-protection-
   Add this into ysat-brand.css
   ============================================================= */


/* ============================================================
   SECTION 1: PAGE HERO
   ============================================================ */

.ysat-protection-hero {
  padding: 64px 50px 56px;
  background-color: var(--color-forest-green);
  position: relative;
  overflow: hidden;
}

.ysat-protection-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-protection-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-protection-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ysat-protection-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-protection-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.7);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-protection-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
  max-width: 700px;
}

.ysat-protection-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-protection-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
  max-width: 680px;
}

.ysat-protection-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-protection-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-protection-hero__stat:last-child {
  border-right: none;
}

.ysat-protection-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.06);
}

.ysat-protection-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-protection-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: PROJECTS LISTING
   ============================================================ */

.ysat-protection-projects {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-protection-projects__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-protection-projects__header {
  margin-bottom: 40px;
}

.ysat-protection-projects__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-protection-projects__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-protection-projects__title span {
  color: var(--color-brand-green);
}

.ysat-protection-projects__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 680px;
}

/* Only 2 projects — 2 equal columns */
.ysat-protection-projects__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* ---- Project card ---- */
.ysat-protection-project-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.ysat-protection-project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-soft-green);
}

.ysat-protection-project-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
}

.ysat-protection-project-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-protection-project-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-protection-project-card:hover .ysat-protection-project-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-protection-project-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.ysat-protection-project-card__status--active {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border: 1px solid var(--color-soft-green);
}

.ysat-protection-project-card__status--completed {
  background-color: var(--color-off-white);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

.ysat-protection-project-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-protection-project-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

.ysat-protection-project-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-4);
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-light-gray);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.ysat-protection-project-card__link:hover {
  color: var(--color-forest-green);
  gap: var(--space-3);
}


/* ============================================================
   SECTION 3: KEY RESULTS
   ============================================================ */

.ysat-protection-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-protection-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-protection-results__header {
  margin-bottom: 40px;
}

.ysat-protection-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-protection-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-protection-results__title span {
  color: var(--color-brand-green);
}

.ysat-protection-results__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-protection-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  border-bottom: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-protection-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-protection-result:nth-child(3n) {
  border-right: none;
}

.ysat-protection-result:nth-last-child(-n+3) {
  border-bottom: none;
}

.ysat-protection-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-protection-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  .ysat-protection-hero {
    padding: 40px 24px 36px;
  }

  .ysat-protection-projects,
  .ysat-protection-results {
    padding: 40px 24px;
  }

  .ysat-protection-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-protection-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-protection-hero__stat:nth-child(1),
  .ysat-protection-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  }

  .ysat-protection-projects__grid {
    grid-template-columns: 1fr;
  }

  .ysat-protection-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-protection-result:nth-child(3n) {
    border-right: 1px solid var(--color-light-gray);
  }

  .ysat-protection-result:nth-child(2n) {
    border-right: none;
  }

  .ysat-protection-result:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-protection-result:nth-last-child(-n+2) {
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  .ysat-protection-hero {
    padding: 32px 16px 28px;
  }

  .ysat-protection-projects,
  .ysat-protection-results {
    padding: 32px 16px;
  }

  .ysat-protection-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-protection-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  }

  .ysat-protection-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-protection-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-protection-result {
    border-right: none;
  }

  .ysat-protection-result:last-child {
    border-bottom: none;
  }
}



/* =============================================================
   SPA 3 — LIVELIHOODS & ENVIRONMENTAL PROTECTION
   Page sections for livelihoods-environment.html
   Prefix: ysat-livelihoods-
   Add this into ysat-brand.css
   ============================================================= */


/* ============================================================
   SECTION 1: PAGE HERO
   ============================================================ */

.ysat-livelihoods-hero {
  padding: 64px 50px 56px;
  background-color: var(--color-forest-green);
  position: relative;
  overflow: hidden;
}

.ysat-livelihoods-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-livelihoods-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-livelihoods-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ysat-livelihoods-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-livelihoods-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.7);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-livelihoods-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
  max-width: 700px;
}

.ysat-livelihoods-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-livelihoods-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
  max-width: 680px;
}

.ysat-livelihoods-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-livelihoods-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-livelihoods-hero__stat:last-child {
  border-right: none;
}

.ysat-livelihoods-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-livelihoods-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-livelihoods-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: PROJECTS LISTING
   ============================================================ */

.ysat-livelihoods-projects {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-livelihoods-projects__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-livelihoods-projects__header {
  margin-bottom: 40px;
}

.ysat-livelihoods-projects__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-livelihoods-projects__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-livelihoods-projects__title span {
  color: var(--color-brand-green);
}

.ysat-livelihoods-projects__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 680px;
}

/* 8 projects — 3 columns, last 2 fill row naturally */
.ysat-livelihoods-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* ---- Project card ---- */
.ysat-livelihoods-project-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.ysat-livelihoods-project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-soft-green);
}

.ysat-livelihoods-project-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
}

.ysat-livelihoods-project-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-livelihoods-project-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-livelihoods-project-card:hover .ysat-livelihoods-project-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-livelihoods-project-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.ysat-livelihoods-project-card__status--active {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border: 1px solid var(--color-soft-green);
}

.ysat-livelihoods-project-card__status--completed {
  background-color: var(--color-off-white);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

.ysat-livelihoods-project-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-livelihoods-project-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

.ysat-livelihoods-project-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-4);
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-light-gray);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.ysat-livelihoods-project-card__link:hover {
  color: var(--color-forest-green);
  gap: var(--space-3);
}


/* ============================================================
   SECTION 3: KEY RESULTS
   ============================================================ */

.ysat-livelihoods-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-livelihoods-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-livelihoods-results__header {
  margin-bottom: 40px;
}

.ysat-livelihoods-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-livelihoods-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-livelihoods-results__title span {
  color: var(--color-brand-green);
}

.ysat-livelihoods-results__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-livelihoods-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  border-bottom: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-livelihoods-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-livelihoods-result:nth-child(3n) {
  border-right: none;
}

.ysat-livelihoods-result:nth-last-child(-n+3) {
  border-bottom: none;
}

.ysat-livelihoods-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-livelihoods-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-livelihoods-projects__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .ysat-livelihoods-hero {
    padding: 40px 24px 36px;
  }

  .ysat-livelihoods-projects,
  .ysat-livelihoods-results {
    padding: 40px 24px;
  }

  .ysat-livelihoods-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-livelihoods-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-livelihoods-hero__stat:nth-child(1),
  .ysat-livelihoods-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-livelihoods-projects__grid {
    grid-template-columns: 1fr;
  }

  .ysat-livelihoods-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-livelihoods-result:nth-child(3n) {
    border-right: 1px solid var(--color-light-gray);
  }

  .ysat-livelihoods-result:nth-child(2n) {
    border-right: none;
  }

  .ysat-livelihoods-result:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-livelihoods-result:nth-last-child(-n+2) {
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  .ysat-livelihoods-hero {
    padding: 32px 16px 28px;
  }

  .ysat-livelihoods-projects,
  .ysat-livelihoods-results {
    padding: 32px 16px;
  }

  .ysat-livelihoods-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-livelihoods-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-livelihoods-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-livelihoods-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-livelihoods-result {
    border-right: none;
  }

  .ysat-livelihoods-result:last-child {
    border-bottom: none;
  }
}



/* =============================================================
   SPA 4 — EDUCATION IN EMERGENCIES
   Page sections for education-in-emergencies.html
   Prefix: ysat-education-
   Add this into ysat-brand.css
   ============================================================= */


/* ============================================================
   SECTION 1: PAGE HERO
   ============================================================ */

.ysat-education-hero {
  padding: 64px 50px 56px;
  background-color: var(--color-forest-green);
  position: relative;
  overflow: hidden;
}

.ysat-education-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-education-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-education-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ysat-education-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-education-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.7);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-education-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
  max-width: 700px;
}

.ysat-education-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-education-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
  max-width: 680px;
}

.ysat-education-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-education-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-education-hero__stat:last-child {
  border-right: none;
}

.ysat-education-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-education-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-education-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: PROJECTS LISTING
   ============================================================ */

.ysat-education-projects {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-education-projects__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-education-projects__header {
  margin-bottom: 40px;
}

.ysat-education-projects__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-education-projects__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-education-projects__title span {
  color: var(--color-brand-green);
}

.ysat-education-projects__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 680px;
}

/* 5 projects — 3 columns */
.ysat-education-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* ---- Project card ---- */
.ysat-education-project-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.ysat-education-project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-soft-green);
}

.ysat-education-project-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
}

.ysat-education-project-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-education-project-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-education-project-card:hover .ysat-education-project-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-education-project-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.ysat-education-project-card__status--active {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border: 1px solid var(--color-soft-green);
}

.ysat-education-project-card__status--completed {
  background-color: var(--color-off-white);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

.ysat-education-project-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-education-project-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

.ysat-education-project-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-4);
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-light-gray);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.ysat-education-project-card__link:hover {
  color: var(--color-forest-green);
  gap: var(--space-3);
}


/* ============================================================
   SECTION 3: KEY RESULTS
   ============================================================ */

.ysat-education-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-education-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-education-results__header {
  margin-bottom: 40px;
}

.ysat-education-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-education-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-education-results__title span {
  color: var(--color-brand-green);
}

.ysat-education-results__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-education-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  border-bottom: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-education-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-education-result:nth-child(3n) {
  border-right: none;
}

.ysat-education-result:nth-last-child(-n+3) {
  border-bottom: none;
}

.ysat-education-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-education-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-education-projects__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .ysat-education-hero {
    padding: 40px 24px 36px;
  }

  .ysat-education-projects,
  .ysat-education-results {
    padding: 40px 24px;
  }

  .ysat-education-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-education-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-education-hero__stat:nth-child(1),
  .ysat-education-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-education-projects__grid {
    grid-template-columns: 1fr;
  }

  .ysat-education-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-education-result:nth-child(3n) {
    border-right: 1px solid var(--color-light-gray);
  }

  .ysat-education-result:nth-child(2n) {
    border-right: none;
  }

  .ysat-education-result:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-education-result:nth-last-child(-n+2) {
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  .ysat-education-hero {
    padding: 32px 16px 28px;
  }

  .ysat-education-projects,
  .ysat-education-results {
    padding: 32px 16px;
  }

  .ysat-education-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-education-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-education-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-education-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-education-result {
    border-right: none;
  }

  .ysat-education-result:last-child {
    border-bottom: none;
  }
}


/* =============================================================
   SPA 5 — ORGANISATIONAL CAPACITY STRENGTHENING
   Page sections for organisational-capacity.html
   Prefix: ysat-orgcapacity-
   Add this into ysat-brand.css
   ============================================================= */


/* ============================================================
   SECTION 1: PAGE HERO
   ============================================================ */

.ysat-orgcapacity-hero {
  padding: 64px 50px 56px;
  background-color: var(--color-forest-green);
  position: relative;
  overflow: hidden;
}

.ysat-orgcapacity-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-orgcapacity-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-orgcapacity-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ysat-orgcapacity-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-orgcapacity-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.7);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-orgcapacity-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
  max-width: 700px;
}

.ysat-orgcapacity-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-orgcapacity-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
  max-width: 680px;
}

.ysat-orgcapacity-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-orgcapacity-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-orgcapacity-hero__stat:last-child {
  border-right: none;
}

.ysat-orgcapacity-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-orgcapacity-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-orgcapacity-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: INITIATIVES LISTING
   ============================================================ */

.ysat-orgcapacity-projects {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-orgcapacity-projects__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-orgcapacity-projects__header {
  margin-bottom: 40px;
}

.ysat-orgcapacity-projects__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-orgcapacity-projects__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-orgcapacity-projects__title span {
  color: var(--color-brand-green);
}

.ysat-orgcapacity-projects__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 680px;
}

/* 6 initiatives — 3 columns */
.ysat-orgcapacity-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* ---- Initiative card ---- */
.ysat-orgcapacity-project-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-base);
}

.ysat-orgcapacity-project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-soft-green);
}

.ysat-orgcapacity-project-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-3);
}

.ysat-orgcapacity-project-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ysat-orgcapacity-project-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-orgcapacity-project-card:hover .ysat-orgcapacity-project-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-orgcapacity-project-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.ysat-orgcapacity-project-card__status--active {
  background-color: var(--color-mint-tint);
  color: var(--color-forest-green);
  border: 1px solid var(--color-soft-green);
}

.ysat-orgcapacity-project-card__status--completed {
  background-color: var(--color-off-white);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

.ysat-orgcapacity-project-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-orgcapacity-project-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

.ysat-orgcapacity-project-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-brand-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  padding-top: var(--space-4);
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-light-gray);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.ysat-orgcapacity-project-card__link:hover {
  color: var(--color-forest-green);
  gap: var(--space-3);
}


/* ============================================================
   SECTION 3: KEY RESULTS
   ============================================================ */

.ysat-orgcapacity-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-orgcapacity-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-orgcapacity-results__header {
  margin-bottom: 40px;
}

.ysat-orgcapacity-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-orgcapacity-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-orgcapacity-results__title span {
  color: var(--color-brand-green);
}

.ysat-orgcapacity-results__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-orgcapacity-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  border-bottom: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-orgcapacity-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-orgcapacity-result:nth-child(3n) {
  border-right: none;
}

.ysat-orgcapacity-result:nth-last-child(-n+3) {
  border-bottom: none;
}

.ysat-orgcapacity-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-orgcapacity-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-orgcapacity-projects__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .ysat-orgcapacity-hero {
    padding: 40px 24px 36px;
  }

  .ysat-orgcapacity-projects,
  .ysat-orgcapacity-results {
    padding: 40px 24px;
  }

  .ysat-orgcapacity-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-orgcapacity-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-orgcapacity-hero__stat:nth-child(1),
  .ysat-orgcapacity-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-orgcapacity-projects__grid {
    grid-template-columns: 1fr;
  }

  .ysat-orgcapacity-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-orgcapacity-result:nth-child(3n) {
    border-right: 1px solid var(--color-light-gray);
  }

  .ysat-orgcapacity-result:nth-child(2n) {
    border-right: none;
  }

  .ysat-orgcapacity-result:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-orgcapacity-result:nth-last-child(-n+2) {
    border-bottom: none;
  }
}

@media (max-width: 480px) {
  .ysat-orgcapacity-hero {
    padding: 32px 16px 28px;
  }

  .ysat-orgcapacity-projects,
  .ysat-orgcapacity-results {
    padding: 32px 16px;
  }

  .ysat-orgcapacity-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-orgcapacity-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-orgcapacity-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-orgcapacity-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-orgcapacity-result {
    border-right: none;
  }

  .ysat-orgcapacity-result:last-child {
    border-bottom: none;
  }
}



/* =============================================================
   PROJECT DETAIL PAGE — SHARED STYLES
   Used across all project detail pages
   Prefix: ysat-general-food-assistance-
   Add this into ysat-brand.css ONCE — all project pages share it
   ============================================================= */


/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-general-food-assistance-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-general-food-assistance-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

/* Grain overlay */
.ysat-general-food-assistance-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* Image — explicitly placed in right column */
.ysat-general-food-assistance-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

/* Fade left edge of photo into the green background */
.ysat-general-food-assistance-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

/* Content — explicitly placed in left column */
.ysat-general-food-assistance-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Breadcrumb */
.ysat-general-food-assistance-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-general-food-assistance-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-general-food-assistance-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-general-food-assistance-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-general-food-assistance-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

/* Meta row */
.ysat-general-food-assistance-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-general-food-assistance-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-general-food-assistance-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-general-food-assistance-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-general-food-assistance-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-general-food-assistance-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-general-food-assistance-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Title and lead */
.ysat-general-food-assistance-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-general-food-assistance-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

/* Stats band */
.ysat-general-food-assistance-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-general-food-assistance-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-general-food-assistance-hero__stat:last-child {
  border-right: none;
}

.ysat-general-food-assistance-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-general-food-assistance-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-general-food-assistance-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

/* ---- Mobile: image on top, content below ---- */
@media (max-width: 900px) {
  .ysat-general-food-assistance-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-general-food-assistance-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-general-food-assistance-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-general-food-assistance-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-general-food-assistance-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-general-food-assistance-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-general-food-assistance-hero__stat:nth-child(1),
  .ysat-general-food-assistance-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-general-food-assistance-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-general-food-assistance-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-general-food-assistance-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-general-food-assistance-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-general-food-assistance-hero__stat:last-child {
    border-bottom: none;
  }
}

/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-general-food-assistance-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-general-food-assistance-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-general-food-assistance-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-general-food-assistance-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-general-food-assistance-overview__title span {
  color: var(--color-brand-green);
}

.ysat-general-food-assistance-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-general-food-assistance-overview__text:last-child {
  margin-bottom: 0;
}

/* Facts panel */
.ysat-general-food-assistance-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-general-food-assistance-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-general-food-assistance-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-general-food-assistance-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-general-food-assistance-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-general-food-assistance-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-general-food-assistance-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — GENERAL FOOD ASSISTANCE
   Prefix: ysat-general-food-assistance-
   ============================================================ */

.ysat-general-food-assistance-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-general-food-assistance-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-general-food-assistance-activities__header {
  margin-bottom: 40px;
}

.ysat-general-food-assistance-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-general-food-assistance-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-general-food-assistance-activities__title span {
  color: var(--color-brand-green);
}

/* Two-column layout: slideshow left, activity list right */
.ysat-general-food-assistance-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* ---- Image slideshow ---- */
.ysat-general-food-assistance-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-general-food-assistance-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-general-food-assistance-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-general-food-assistance-activities__slide.active {
  opacity: 1;
}

/* Caption */
.ysat-general-food-assistance-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

/* Dots */
.ysat-general-food-assistance-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-general-food-assistance-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-general-food-assistance-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

/* ---- Activity list ---- */
.ysat-general-food-assistance-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-general-food-assistance-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-general-food-assistance-activity:hover,
.ysat-general-food-assistance-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-general-food-assistance-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-general-food-assistance-activity:hover .ysat-general-food-assistance-activity__icon,
.ysat-general-food-assistance-activity.active .ysat-general-food-assistance-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-general-food-assistance-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-general-food-assistance-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-general-food-assistance-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-general-food-assistance-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-general-food-assistance-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-general-food-assistance-results__header {
  margin-bottom: 40px;
}

.ysat-general-food-assistance-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-general-food-assistance-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-general-food-assistance-results__title span {
  color: var(--color-brand-green);
}

.ysat-general-food-assistance-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-general-food-assistance-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-general-food-assistance-result:last-child {
  border-right: none;
}

.ysat-general-food-assistance-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-general-food-assistance-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-general-food-assistance-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-general-food-assistance-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-general-food-assistance-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-general-food-assistance-related__header {
  margin-bottom: 32px;
}

.ysat-general-food-assistance-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-general-food-assistance-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-general-food-assistance-related__title span {
  color: var(--color-gold-amber);
}

/* Related cards */
.ysat-general-food-assistance-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-general-food-assistance-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-general-food-assistance-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-general-food-assistance-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-general-food-assistance-related-card:hover .ysat-general-food-assistance-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-general-food-assistance-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-general-food-assistance-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-general-food-assistance-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-general-food-assistance-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-general-food-assistance-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-general-food-assistance-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-general-food-assistance-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-general-food-assistance-related-card:hover .ysat-general-food-assistance-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

/* Back link */
.ysat-general-food-assistance-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-general-food-assistance-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-general-food-assistance-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-general-food-assistance-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-general-food-assistance-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-general-food-assistance-activities__slider {
    position: static;
  }

  .ysat-general-food-assistance-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-general-food-assistance-hero,
  .ysat-general-food-assistance-overview,
  .ysat-general-food-assistance-activities,
  .ysat-general-food-assistance-results,
  .ysat-general-food-assistance-related {
    padding: 40px 24px;
  }

  .ysat-general-food-assistance-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-general-food-assistance-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-general-food-assistance-hero__stat:nth-child(1),
  .ysat-general-food-assistance-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-general-food-assistance-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-general-food-assistance-overview__facts {
    position: static;
  }

  .ysat-general-food-assistance-activities__grid {
    grid-template-columns: 1fr;
  }

  .ysat-general-food-assistance-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-general-food-assistance-result:nth-child(2) {
    border-right: none;
  }

  .ysat-general-food-assistance-result:nth-child(1),
  .ysat-general-food-assistance-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-general-food-assistance-hero,
  .ysat-general-food-assistance-overview,
  .ysat-general-food-assistance-activities,
  .ysat-general-food-assistance-results,
  .ysat-general-food-assistance-related {
    padding: 32px 16px;
  }

  .ysat-general-food-assistance-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-general-food-assistance-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-general-food-assistance-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-general-food-assistance-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-general-food-assistance-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-general-food-assistance-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-covid19-response-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-covid19-response-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

/* Grain overlay */
.ysat-covid19-response-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* Image — explicitly placed in right column */
.ysat-covid19-response-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

/* Fade left edge of photo into the green background */
.ysat-covid19-response-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

/* Content — explicitly placed in left column */
.ysat-covid19-response-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Breadcrumb */
.ysat-covid19-response-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-covid19-response-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-covid19-response-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-covid19-response-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-covid19-response-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

/* Meta row */
.ysat-covid19-response-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-covid19-response-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-covid19-response-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-covid19-response-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-covid19-response-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-covid19-response-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-covid19-response-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Title and lead */
.ysat-covid19-response-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-covid19-response-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

/* Stats band */
.ysat-covid19-response-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-covid19-response-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-covid19-response-hero__stat:last-child {
  border-right: none;
}

.ysat-covid19-response-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-covid19-response-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-covid19-response-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

/* ---- Mobile: image on top, content below ---- */
@media (max-width: 900px) {
  .ysat-covid19-response-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-covid19-response-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-covid19-response-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-covid19-response-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-covid19-response-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-covid19-response-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-covid19-response-hero__stat:nth-child(1),
  .ysat-covid19-response-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-covid19-response-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-covid19-response-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-covid19-response-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-covid19-response-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-covid19-response-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-covid19-response-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-covid19-response-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-covid19-response-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-covid19-response-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-covid19-response-overview__title span {
  color: var(--color-brand-green);
}

.ysat-covid19-response-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-covid19-response-overview__text:last-child {
  margin-bottom: 0;
}

/* Facts panel */
.ysat-covid19-response-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-covid19-response-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-covid19-response-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-covid19-response-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-covid19-response-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-covid19-response-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-covid19-response-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — COVID-19 COMMUNITY RESPONSE
   Prefix: ysat-covid19-response-
   ============================================================ */

.ysat-covid19-response-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-covid19-response-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-covid19-response-activities__header {
  margin-bottom: 40px;
}

.ysat-covid19-response-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-covid19-response-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-covid19-response-activities__title span {
  color: var(--color-brand-green);
}

/* Two-column layout: slideshow left, activity list right */
.ysat-covid19-response-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* ---- Image slideshow ---- */
.ysat-covid19-response-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-covid19-response-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-covid19-response-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-covid19-response-activities__slide.active {
  opacity: 1;
}

/* Caption */
.ysat-covid19-response-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

/* Dots */
.ysat-covid19-response-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-covid19-response-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-covid19-response-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

/* ---- Activity list ---- */
.ysat-covid19-response-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-covid19-response-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-covid19-response-activity:hover,
.ysat-covid19-response-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-covid19-response-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-covid19-response-activity:hover .ysat-covid19-response-activity__icon,
.ysat-covid19-response-activity.active .ysat-covid19-response-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-covid19-response-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-covid19-response-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-covid19-response-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-covid19-response-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-covid19-response-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-covid19-response-results__header {
  margin-bottom: 40px;
}

.ysat-covid19-response-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-covid19-response-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-covid19-response-results__title span {
  color: var(--color-brand-green);
}

.ysat-covid19-response-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-covid19-response-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-covid19-response-result:last-child {
  border-right: none;
}

.ysat-covid19-response-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-covid19-response-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-covid19-response-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-covid19-response-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-covid19-response-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-covid19-response-related__header {
  margin-bottom: 32px;
}

.ysat-covid19-response-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-covid19-response-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-covid19-response-related__title span {
  color: var(--color-gold-amber);
}

/* Related cards */
.ysat-covid19-response-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-covid19-response-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-covid19-response-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-covid19-response-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-covid19-response-related-card:hover .ysat-covid19-response-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-covid19-response-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-covid19-response-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-covid19-response-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-covid19-response-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-covid19-response-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-covid19-response-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-covid19-response-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-covid19-response-related-card:hover .ysat-covid19-response-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

/* Back link */
.ysat-covid19-response-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-covid19-response-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-covid19-response-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-covid19-response-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-covid19-response-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-covid19-response-activities__slider {
    position: static;
  }

  .ysat-covid19-response-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-covid19-response-hero,
  .ysat-covid19-response-overview,
  .ysat-covid19-response-activities,
  .ysat-covid19-response-results,
  .ysat-covid19-response-related {
    padding: 40px 24px;
  }

  .ysat-covid19-response-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-covid19-response-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-covid19-response-hero__stat:nth-child(1),
  .ysat-covid19-response-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-covid19-response-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-covid19-response-overview__facts {
    position: static;
  }

  .ysat-covid19-response-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-covid19-response-result:nth-child(2) {
    border-right: none;
  }

  .ysat-covid19-response-result:nth-child(1),
  .ysat-covid19-response-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-covid19-response-hero,
  .ysat-covid19-response-overview,
  .ysat-covid19-response-activities,
  .ysat-covid19-response-results,
  .ysat-covid19-response-related {
    padding: 32px 16px;
  }

  .ysat-covid19-response-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-covid19-response-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-covid19-response-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-covid19-response-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-covid19-response-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-covid19-response-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-norad-food-insecurity-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-norad-food-insecurity-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

/* Grain overlay */
.ysat-norad-food-insecurity-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* Image — explicitly placed in right column */
.ysat-norad-food-insecurity-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

/* Fade left edge of photo into the green background */
.ysat-norad-food-insecurity-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

/* Content — explicitly placed in left column */
.ysat-norad-food-insecurity-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Breadcrumb */
.ysat-norad-food-insecurity-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-norad-food-insecurity-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-norad-food-insecurity-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-norad-food-insecurity-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-norad-food-insecurity-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

/* Meta row */
.ysat-norad-food-insecurity-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-norad-food-insecurity-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-norad-food-insecurity-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-norad-food-insecurity-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-norad-food-insecurity-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-norad-food-insecurity-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-norad-food-insecurity-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Title and lead */
.ysat-norad-food-insecurity-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-norad-food-insecurity-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

/* Stats band */
.ysat-norad-food-insecurity-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-norad-food-insecurity-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-norad-food-insecurity-hero__stat:last-child {
  border-right: none;
}

.ysat-norad-food-insecurity-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-norad-food-insecurity-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-norad-food-insecurity-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

/* ---- Mobile: image on top, content below ---- */
@media (max-width: 900px) {
  .ysat-norad-food-insecurity-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-norad-food-insecurity-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-norad-food-insecurity-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-norad-food-insecurity-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-norad-food-insecurity-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-norad-food-insecurity-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-norad-food-insecurity-hero__stat:nth-child(1),
  .ysat-norad-food-insecurity-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-norad-food-insecurity-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-norad-food-insecurity-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-norad-food-insecurity-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-norad-food-insecurity-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-norad-food-insecurity-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-norad-food-insecurity-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-norad-food-insecurity-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-norad-food-insecurity-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-norad-food-insecurity-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-norad-food-insecurity-overview__title span {
  color: var(--color-brand-green);
}

.ysat-norad-food-insecurity-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-norad-food-insecurity-overview__text:last-child {
  margin-bottom: 0;
}

/* Facts panel */
.ysat-norad-food-insecurity-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-norad-food-insecurity-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-norad-food-insecurity-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-norad-food-insecurity-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-norad-food-insecurity-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-norad-food-insecurity-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-norad-food-insecurity-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — NORAD FOOD INSECURITY
   Prefix: ysat-norad-food-insecurity-
   ============================================================ */

.ysat-norad-food-insecurity-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-norad-food-insecurity-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-norad-food-insecurity-activities__header {
  margin-bottom: 40px;
}

.ysat-norad-food-insecurity-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-norad-food-insecurity-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-norad-food-insecurity-activities__title span {
  color: var(--color-brand-green);
}

/* Two-column layout: slideshow left, activity list right */
.ysat-norad-food-insecurity-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* ---- Image slideshow ---- */
.ysat-norad-food-insecurity-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-norad-food-insecurity-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-norad-food-insecurity-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-norad-food-insecurity-activities__slide.active {
  opacity: 1;
}

/* Caption */
.ysat-norad-food-insecurity-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

/* Dots */
.ysat-norad-food-insecurity-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-norad-food-insecurity-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-norad-food-insecurity-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

/* ---- Activity list ---- */
.ysat-norad-food-insecurity-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-norad-food-insecurity-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-norad-food-insecurity-activity:hover,
.ysat-norad-food-insecurity-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-norad-food-insecurity-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-norad-food-insecurity-activity:hover .ysat-norad-food-insecurity-activity__icon,
.ysat-norad-food-insecurity-activity.active .ysat-norad-food-insecurity-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-norad-food-insecurity-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-norad-food-insecurity-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-norad-food-insecurity-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-norad-food-insecurity-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-norad-food-insecurity-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-norad-food-insecurity-results__header {
  margin-bottom: 40px;
}

.ysat-norad-food-insecurity-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-norad-food-insecurity-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-norad-food-insecurity-results__title span {
  color: var(--color-brand-green);
}

.ysat-norad-food-insecurity-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-norad-food-insecurity-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-norad-food-insecurity-result:last-child {
  border-right: none;
}

.ysat-norad-food-insecurity-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-norad-food-insecurity-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-norad-food-insecurity-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-norad-food-insecurity-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-norad-food-insecurity-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-norad-food-insecurity-related__header {
  margin-bottom: 32px;
}

.ysat-norad-food-insecurity-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-norad-food-insecurity-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-norad-food-insecurity-related__title span {
  color: var(--color-gold-amber);
}

/* Related cards */
.ysat-norad-food-insecurity-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-norad-food-insecurity-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-norad-food-insecurity-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-norad-food-insecurity-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-norad-food-insecurity-related-card:hover .ysat-norad-food-insecurity-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-norad-food-insecurity-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-norad-food-insecurity-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-norad-food-insecurity-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-norad-food-insecurity-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-norad-food-insecurity-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-norad-food-insecurity-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-norad-food-insecurity-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-norad-food-insecurity-related-card:hover .ysat-norad-food-insecurity-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

/* Back link */
.ysat-norad-food-insecurity-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-norad-food-insecurity-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-norad-food-insecurity-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-norad-food-insecurity-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-norad-food-insecurity-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-norad-food-insecurity-activities__slider {
    position: static;
  }

  .ysat-norad-food-insecurity-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-norad-food-insecurity-hero,
  .ysat-norad-food-insecurity-overview,
  .ysat-norad-food-insecurity-activities,
  .ysat-norad-food-insecurity-results,
  .ysat-norad-food-insecurity-related {
    padding: 40px 24px;
  }

  .ysat-norad-food-insecurity-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-norad-food-insecurity-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-norad-food-insecurity-hero__stat:nth-child(1),
  .ysat-norad-food-insecurity-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-norad-food-insecurity-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-norad-food-insecurity-overview__facts {
    position: static;
  }

  .ysat-norad-food-insecurity-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-norad-food-insecurity-result:nth-child(2) {
    border-right: none;
  }

  .ysat-norad-food-insecurity-result:nth-child(1),
  .ysat-norad-food-insecurity-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-norad-food-insecurity-hero,
  .ysat-norad-food-insecurity-overview,
  .ysat-norad-food-insecurity-activities,
  .ysat-norad-food-insecurity-results,
  .ysat-norad-food-insecurity-related {
    padding: 32px 16px;
  }

  .ysat-norad-food-insecurity-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-norad-food-insecurity-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-norad-food-insecurity-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-norad-food-insecurity-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-norad-food-insecurity-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-norad-food-insecurity-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-unoy-research-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-unoy-research-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

/* Grain overlay */
.ysat-unoy-research-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* Image — explicitly placed in right column */
.ysat-unoy-research-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

/* Fade left edge of photo into the green background */
.ysat-unoy-research-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

/* Content — explicitly placed in left column */
.ysat-unoy-research-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Breadcrumb */
.ysat-unoy-research-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-unoy-research-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-unoy-research-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-unoy-research-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-unoy-research-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

/* Meta row */
.ysat-unoy-research-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-unoy-research-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-unoy-research-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-unoy-research-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-unoy-research-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-unoy-research-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-unoy-research-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Title and lead */
.ysat-unoy-research-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-unoy-research-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

/* Stats band */
.ysat-unoy-research-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-unoy-research-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-unoy-research-hero__stat:last-child {
  border-right: none;
}

.ysat-unoy-research-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-unoy-research-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-unoy-research-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

/* ---- Mobile: image on top, content below ---- */
@media (max-width: 900px) {
  .ysat-unoy-research-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-unoy-research-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-unoy-research-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-unoy-research-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-unoy-research-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-unoy-research-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-unoy-research-hero__stat:nth-child(1),
  .ysat-unoy-research-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-unoy-research-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-unoy-research-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-unoy-research-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-unoy-research-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-unoy-research-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-unoy-research-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-unoy-research-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-unoy-research-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-unoy-research-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-unoy-research-overview__title span {
  color: var(--color-brand-green);
}

.ysat-unoy-research-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-unoy-research-overview__text:last-child {
  margin-bottom: 0;
}

/* Facts panel */
.ysat-unoy-research-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-unoy-research-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-unoy-research-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-unoy-research-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-unoy-research-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-unoy-research-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-unoy-research-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — UNOY RESEARCH
   Prefix: ysat-unoy-research-
   ============================================================ */

.ysat-unoy-research-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-unoy-research-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-unoy-research-activities__header {
  margin-bottom: 40px;
}

.ysat-unoy-research-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-unoy-research-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-unoy-research-activities__title span {
  color: var(--color-brand-green);
}

.ysat-unoy-research-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-unoy-research-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-unoy-research-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-unoy-research-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-unoy-research-activities__slide.active {
  opacity: 1;
}

.ysat-unoy-research-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-unoy-research-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-unoy-research-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-unoy-research-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-unoy-research-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-unoy-research-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-unoy-research-activity:hover,
.ysat-unoy-research-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-unoy-research-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-unoy-research-activity:hover .ysat-unoy-research-activity__icon,
.ysat-unoy-research-activity.active .ysat-unoy-research-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-unoy-research-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-unoy-research-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-unoy-research-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-unoy-research-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-unoy-research-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-unoy-research-results__header {
  margin-bottom: 40px;
}

.ysat-unoy-research-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-unoy-research-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-unoy-research-results__title span {
  color: var(--color-brand-green);
}

.ysat-unoy-research-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-unoy-research-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-unoy-research-result:last-child {
  border-right: none;
}

.ysat-unoy-research-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-unoy-research-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-unoy-research-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-unoy-research-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-unoy-research-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-unoy-research-related__header {
  margin-bottom: 32px;
}

.ysat-unoy-research-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-unoy-research-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-unoy-research-related__title span {
  color: var(--color-gold-amber);
}

.ysat-unoy-research-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-unoy-research-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-unoy-research-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-unoy-research-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-unoy-research-related-card:hover .ysat-unoy-research-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-unoy-research-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-unoy-research-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-unoy-research-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-unoy-research-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-unoy-research-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-unoy-research-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-unoy-research-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-unoy-research-related-card:hover .ysat-unoy-research-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-unoy-research-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-unoy-research-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-unoy-research-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-unoy-research-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-unoy-research-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-unoy-research-activities__slider {
    position: static;
  }

  .ysat-unoy-research-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-unoy-research-hero,
  .ysat-unoy-research-overview,
  .ysat-unoy-research-activities,
  .ysat-unoy-research-results,
  .ysat-unoy-research-related {
    padding: 40px 24px;
  }

  .ysat-unoy-research-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-unoy-research-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-unoy-research-hero__stat:nth-child(1),
  .ysat-unoy-research-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-unoy-research-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-unoy-research-overview__facts {
    position: static;
  }

  .ysat-unoy-research-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-unoy-research-result:nth-child(2) {
    border-right: none;
  }

  .ysat-unoy-research-result:nth-child(1),
  .ysat-unoy-research-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-unoy-research-hero,
  .ysat-unoy-research-overview,
  .ysat-unoy-research-activities,
  .ysat-unoy-research-results,
  .ysat-unoy-research-related {
    padding: 32px 16px;
  }

  .ysat-unoy-research-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-unoy-research-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-unoy-research-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-unoy-research-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-unoy-research-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-unoy-research-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-peace-clubs-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-peace-clubs-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

/* Grain overlay */
.ysat-peace-clubs-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* Image — explicitly placed in right column */
.ysat-peace-clubs-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

/* Fade left edge of photo into the green background */
.ysat-peace-clubs-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

/* Content — explicitly placed in left column */
.ysat-peace-clubs-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Breadcrumb */
.ysat-peace-clubs-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-peace-clubs-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-peace-clubs-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-peace-clubs-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-peace-clubs-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

/* Meta row */
.ysat-peace-clubs-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-peace-clubs-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-peace-clubs-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-peace-clubs-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-peace-clubs-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-peace-clubs-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-peace-clubs-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Title and lead */
.ysat-peace-clubs-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-peace-clubs-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

/* Stats band */
.ysat-peace-clubs-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-peace-clubs-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-peace-clubs-hero__stat:last-child {
  border-right: none;
}

.ysat-peace-clubs-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-peace-clubs-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-peace-clubs-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

/* ---- Mobile: image on top, content below ---- */
@media (max-width: 900px) {
  .ysat-peace-clubs-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-peace-clubs-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-peace-clubs-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-peace-clubs-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-peace-clubs-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-peace-clubs-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-peace-clubs-hero__stat:nth-child(1),
  .ysat-peace-clubs-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-peace-clubs-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-peace-clubs-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-peace-clubs-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-peace-clubs-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-peace-clubs-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-peace-clubs-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-peace-clubs-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-peace-clubs-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-peace-clubs-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-peace-clubs-overview__title span {
  color: var(--color-brand-green);
}

.ysat-peace-clubs-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-peace-clubs-overview__text:last-child {
  margin-bottom: 0;
}

/* Facts panel */
.ysat-peace-clubs-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-peace-clubs-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-peace-clubs-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-peace-clubs-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-peace-clubs-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-peace-clubs-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-peace-clubs-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — PEACE CLUBS AND COMMUNITY DIALOGUES
   Prefix: ysat-peace-clubs-
   ============================================================ */

.ysat-peace-clubs-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-peace-clubs-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-peace-clubs-activities__header {
  margin-bottom: 40px;
}

.ysat-peace-clubs-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-peace-clubs-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-peace-clubs-activities__title span {
  color: var(--color-brand-green);
}

.ysat-peace-clubs-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-peace-clubs-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-peace-clubs-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-peace-clubs-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-peace-clubs-activities__slide.active {
  opacity: 1;
}

.ysat-peace-clubs-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-peace-clubs-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-peace-clubs-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-peace-clubs-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-peace-clubs-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-peace-clubs-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-peace-clubs-activity:hover,
.ysat-peace-clubs-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-peace-clubs-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-peace-clubs-activity:hover .ysat-peace-clubs-activity__icon,
.ysat-peace-clubs-activity.active .ysat-peace-clubs-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-peace-clubs-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-peace-clubs-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-peace-clubs-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-peace-clubs-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-peace-clubs-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-peace-clubs-results__header {
  margin-bottom: 40px;
}

.ysat-peace-clubs-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-peace-clubs-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-peace-clubs-results__title span {
  color: var(--color-brand-green);
}

.ysat-peace-clubs-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-peace-clubs-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-peace-clubs-result:last-child {
  border-right: none;
}

.ysat-peace-clubs-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-peace-clubs-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-peace-clubs-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-peace-clubs-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-peace-clubs-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-peace-clubs-related__header {
  margin-bottom: 32px;
}

.ysat-peace-clubs-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-peace-clubs-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-peace-clubs-related__title span {
  color: var(--color-gold-amber);
}

.ysat-peace-clubs-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-peace-clubs-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-peace-clubs-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-peace-clubs-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-peace-clubs-related-card:hover .ysat-peace-clubs-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-peace-clubs-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-peace-clubs-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-peace-clubs-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-peace-clubs-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-peace-clubs-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-peace-clubs-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-peace-clubs-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-peace-clubs-related-card:hover .ysat-peace-clubs-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-peace-clubs-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-peace-clubs-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-peace-clubs-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-peace-clubs-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-peace-clubs-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-peace-clubs-activities__slider {
    position: static;
  }

  .ysat-peace-clubs-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-peace-clubs-hero,
  .ysat-peace-clubs-overview,
  .ysat-peace-clubs-activities,
  .ysat-peace-clubs-results,
  .ysat-peace-clubs-related {
    padding: 40px 24px;
  }

  .ysat-peace-clubs-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-peace-clubs-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-peace-clubs-hero__stat:nth-child(1),
  .ysat-peace-clubs-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-peace-clubs-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-peace-clubs-overview__facts {
    position: static;
  }

  .ysat-peace-clubs-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-peace-clubs-result:nth-child(2) {
    border-right: none;
  }

  .ysat-peace-clubs-result:nth-child(1),
  .ysat-peace-clubs-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-peace-clubs-hero,
  .ysat-peace-clubs-overview,
  .ysat-peace-clubs-activities,
  .ysat-peace-clubs-results,
  .ysat-peace-clubs-related {
    padding: 32px 16px;
  }

  .ysat-peace-clubs-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-peace-clubs-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-peace-clubs-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-peace-clubs-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-peace-clubs-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-peace-clubs-result:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-inspire-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-inspire-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-inspire-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-inspire-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-inspire-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-inspire-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-inspire-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-inspire-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-inspire-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-inspire-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-inspire-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-inspire-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-inspire-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-inspire-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-inspire-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-inspire-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-inspire-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-inspire-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-inspire-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-inspire-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-inspire-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-inspire-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-inspire-hero__stat:last-child {
  border-right: none;
}

.ysat-inspire-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-inspire-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-inspire-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-inspire-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-inspire-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-inspire-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-inspire-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-inspire-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-inspire-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-inspire-hero__stat:nth-child(1),
  .ysat-inspire-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-inspire-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-inspire-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-inspire-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-inspire-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-inspire-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-inspire-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-inspire-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-inspire-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-inspire-overview__title span {
  color: var(--color-brand-green);
}

.ysat-inspire-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-inspire-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-inspire-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-inspire-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-inspire-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-inspire-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-inspire-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-inspire-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-inspire-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — INSPIRE PROJECT
   Prefix: ysat-inspire-
   ============================================================ */

.ysat-inspire-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-inspire-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-inspire-activities__header {
  margin-bottom: 40px;
}

.ysat-inspire-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-inspire-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-inspire-activities__title span {
  color: var(--color-brand-green);
}

.ysat-inspire-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-inspire-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-inspire-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-inspire-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-inspire-activities__slide.active {
  opacity: 1;
}

.ysat-inspire-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-inspire-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-inspire-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-inspire-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-inspire-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-inspire-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-inspire-activity:hover,
.ysat-inspire-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-inspire-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-inspire-activity:hover .ysat-inspire-activity__icon,
.ysat-inspire-activity.active .ysat-inspire-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-inspire-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-inspire-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-inspire-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-inspire-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-inspire-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-inspire-results__header {
  margin-bottom: 40px;
}

.ysat-inspire-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-inspire-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-inspire-results__title span {
  color: var(--color-brand-green);
}

.ysat-inspire-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-inspire-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-inspire-result:last-child {
  border-right: none;
}

.ysat-inspire-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-inspire-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-inspire-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-inspire-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-inspire-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-inspire-related__header {
  margin-bottom: 32px;
}

.ysat-inspire-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-inspire-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-inspire-related__title span {
  color: var(--color-gold-amber);
}

.ysat-inspire-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-inspire-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-inspire-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-inspire-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-inspire-related-card:hover .ysat-inspire-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-inspire-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-inspire-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-inspire-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-inspire-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-inspire-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-inspire-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-inspire-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-inspire-related-card:hover .ysat-inspire-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-inspire-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-inspire-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-inspire-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-inspire-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-inspire-activities__slider {
    position: static;
  }

  .ysat-inspire-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-inspire-hero,
  .ysat-inspire-overview,
  .ysat-inspire-activities,
  .ysat-inspire-results,
  .ysat-inspire-related {
    padding: 40px 24px;
  }

  .ysat-inspire-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-inspire-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-inspire-hero__stat:nth-child(1),
  .ysat-inspire-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-inspire-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-inspire-overview__facts {
    position: static;
  }

  .ysat-inspire-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-inspire-result:nth-child(2) {
    border-right: none;
  }

  .ysat-inspire-result:nth-child(1),
  .ysat-inspire-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-inspire-hero,
  .ysat-inspire-overview,
  .ysat-inspire-activities,
  .ysat-inspire-results,
  .ysat-inspire-related {
    padding: 32px 16px;
  }

  .ysat-inspire-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-inspire-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-inspire-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-inspire-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-inspire-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-gfs-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-gfs-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-gfs-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-gfs-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-gfs-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-gfs-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-gfs-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-gfs-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-gfs-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-gfs-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-gfs-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-gfs-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-gfs-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-gfs-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-gfs-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-gfs-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-gfs-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-gfs-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-gfs-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-gfs-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-gfs-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-gfs-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-gfs-hero__stat:last-child {
  border-right: none;
}

.ysat-gfs-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-gfs-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-gfs-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-gfs-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-gfs-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-gfs-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-gfs-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-gfs-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-hero__stat:nth-child(1),
  .ysat-gfs-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-gfs-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-gfs-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-gfs-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-gfs-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-gfs-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-gfs-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-gfs-overview__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-gfs-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-gfs-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-gfs-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-gfs-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-gfs-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-gfs-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-gfs-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-gfs-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — GEAR FOR SUCCESS
   Prefix: ysat-gfs-
   ============================================================ */

.ysat-gfs-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-gfs-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-activities__header {
  margin-bottom: 40px;
}

.ysat-gfs-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-activities__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-gfs-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-gfs-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-gfs-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-gfs-activities__slide.active {
  opacity: 1;
}

.ysat-gfs-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-gfs-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-gfs-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-gfs-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-gfs-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-gfs-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-gfs-activity:hover,
.ysat-gfs-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-gfs-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-gfs-activity:hover .ysat-gfs-activity__icon,
.ysat-gfs-activity.active .ysat-gfs-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-gfs-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-gfs-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-gfs-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-gfs-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-gfs-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-results__header {
  margin-bottom: 40px;
}

.ysat-gfs-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-results__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-gfs-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-gfs-result:last-child {
  border-right: none;
}

.ysat-gfs-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-gfs-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-gfs-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-gfs-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-gfs-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-related__header {
  margin-bottom: 32px;
}

.ysat-gfs-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-related__title span {
  color: var(--color-gold-amber);
}

.ysat-gfs-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-gfs-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-gfs-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-gfs-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-gfs-related-card:hover .ysat-gfs-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-gfs-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-gfs-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-gfs-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-gfs-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-gfs-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-gfs-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-gfs-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-gfs-related-card:hover .ysat-gfs-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-gfs-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-gfs-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-gfs-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-gfs-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-gfs-activities__slider {
    position: static;
  }

  .ysat-gfs-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-gfs-hero,
  .ysat-gfs-overview,
  .ysat-gfs-activities,
  .ysat-gfs-results,
  .ysat-gfs-related {
    padding: 40px 24px;
  }

  .ysat-gfs-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-hero__stat:nth-child(1),
  .ysat-gfs-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-gfs-overview__facts {
    position: static;
  }

  .ysat-gfs-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-result:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-result:nth-child(1),
  .ysat-gfs-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-gfs-hero,
  .ysat-gfs-overview,
  .ysat-gfs-activities,
  .ysat-gfs-results,
  .ysat-gfs-related {
    padding: 32px 16px;
  }

  .ysat-gfs-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-gfs-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-gfs-result:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-efsvl-skilling-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-efsvl-skilling-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-efsvl-skilling-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-efsvl-skilling-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-efsvl-skilling-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-efsvl-skilling-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-efsvl-skilling-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-efsvl-skilling-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-efsvl-skilling-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-efsvl-skilling-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-efsvl-skilling-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-efsvl-skilling-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-efsvl-skilling-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-efsvl-skilling-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-efsvl-skilling-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-efsvl-skilling-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-efsvl-skilling-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-efsvl-skilling-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-efsvl-skilling-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-efsvl-skilling-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-efsvl-skilling-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-efsvl-skilling-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-efsvl-skilling-hero__stat:last-child {
  border-right: none;
}

.ysat-efsvl-skilling-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-efsvl-skilling-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-efsvl-skilling-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-efsvl-skilling-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-efsvl-skilling-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-efsvl-skilling-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-efsvl-skilling-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-efsvl-skilling-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-efsvl-skilling-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-efsvl-skilling-hero__stat:nth-child(1),
  .ysat-efsvl-skilling-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-efsvl-skilling-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-efsvl-skilling-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-efsvl-skilling-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-efsvl-skilling-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-efsvl-skilling-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-efsvl-skilling-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-efsvl-skilling-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-efsvl-skilling-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-efsvl-skilling-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-efsvl-skilling-overview__title span {
  color: var(--color-brand-green);
}

.ysat-efsvl-skilling-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-efsvl-skilling-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-efsvl-skilling-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-efsvl-skilling-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-efsvl-skilling-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-efsvl-skilling-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-efsvl-skilling-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-efsvl-skilling-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-efsvl-skilling-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — EFSVL SKILLING
   Prefix: ysat-efsvl-skilling-
   ============================================================ */

.ysat-efsvl-skilling-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-efsvl-skilling-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-efsvl-skilling-activities__header {
  margin-bottom: 40px;
}

.ysat-efsvl-skilling-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-efsvl-skilling-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-efsvl-skilling-activities__title span {
  color: var(--color-brand-green);
}

.ysat-efsvl-skilling-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-efsvl-skilling-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-efsvl-skilling-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-efsvl-skilling-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-efsvl-skilling-activities__slide.active {
  opacity: 1;
}

.ysat-efsvl-skilling-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-efsvl-skilling-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-efsvl-skilling-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-efsvl-skilling-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-efsvl-skilling-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-efsvl-skilling-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-efsvl-skilling-activity:hover,
.ysat-efsvl-skilling-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-efsvl-skilling-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-efsvl-skilling-activity:hover .ysat-efsvl-skilling-activity__icon,
.ysat-efsvl-skilling-activity.active .ysat-efsvl-skilling-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-efsvl-skilling-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-efsvl-skilling-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-efsvl-skilling-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-efsvl-skilling-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-efsvl-skilling-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-efsvl-skilling-results__header {
  margin-bottom: 40px;
}

.ysat-efsvl-skilling-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-efsvl-skilling-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-efsvl-skilling-results__title span {
  color: var(--color-brand-green);
}

.ysat-efsvl-skilling-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-efsvl-skilling-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-efsvl-skilling-result:last-child {
  border-right: none;
}

.ysat-efsvl-skilling-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-efsvl-skilling-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-efsvl-skilling-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-efsvl-skilling-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-efsvl-skilling-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-efsvl-skilling-related__header {
  margin-bottom: 32px;
}

.ysat-efsvl-skilling-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-efsvl-skilling-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-efsvl-skilling-related__title span {
  color: var(--color-gold-amber);
}

.ysat-efsvl-skilling-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-efsvl-skilling-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-efsvl-skilling-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-efsvl-skilling-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-efsvl-skilling-related-card:hover .ysat-efsvl-skilling-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-efsvl-skilling-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-efsvl-skilling-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-efsvl-skilling-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-efsvl-skilling-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-efsvl-skilling-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-efsvl-skilling-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-efsvl-skilling-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-efsvl-skilling-related-card:hover .ysat-efsvl-skilling-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-efsvl-skilling-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-efsvl-skilling-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-efsvl-skilling-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-efsvl-skilling-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-efsvl-skilling-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-efsvl-skilling-activities__slider {
    position: static;
  }

  .ysat-efsvl-skilling-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-efsvl-skilling-hero,
  .ysat-efsvl-skilling-overview,
  .ysat-efsvl-skilling-activities,
  .ysat-efsvl-skilling-results,
  .ysat-efsvl-skilling-related {
    padding: 40px 24px;
  }

  .ysat-efsvl-skilling-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-efsvl-skilling-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-efsvl-skilling-hero__stat:nth-child(1),
  .ysat-efsvl-skilling-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-efsvl-skilling-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-efsvl-skilling-overview__facts {
    position: static;
  }

  .ysat-efsvl-skilling-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-efsvl-skilling-result:nth-child(2) {
    border-right: none;
  }

  .ysat-efsvl-skilling-result:nth-child(1),
  .ysat-efsvl-skilling-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-efsvl-skilling-hero,
  .ysat-efsvl-skilling-overview,
  .ysat-efsvl-skilling-activities,
  .ysat-efsvl-skilling-results,
  .ysat-efsvl-skilling-related {
    padding: 32px 16px;
  }

  .ysat-efsvl-skilling-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-efsvl-skilling-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-efsvl-skilling-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-efsvl-skilling-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-efsvl-skilling-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-efsvl-skilling-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-urri-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-urri-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-urri-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-urri-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-urri-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-urri-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-urri-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-urri-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-urri-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-urri-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-urri-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-urri-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-urri-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-urri-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-urri-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-urri-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-urri-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-urri-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-urri-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-urri-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-urri-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-urri-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-urri-hero__stat:last-child {
  border-right: none;
}

.ysat-urri-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-urri-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-urri-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-urri-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-urri-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-urri-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-urri-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-urri-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-urri-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-urri-hero__stat:nth-child(1),
  .ysat-urri-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-urri-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-urri-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-urri-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-urri-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-urri-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-urri-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-urri-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-urri-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-urri-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-urri-overview__title span {
  color: var(--color-brand-green);
}

.ysat-urri-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-urri-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-urri-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-urri-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-urri-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-urri-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-urri-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-urri-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-urri-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — URRI
   Prefix: ysat-urri-
   ============================================================ */

.ysat-urri-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-urri-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-urri-activities__header {
  margin-bottom: 40px;
}

.ysat-urri-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-urri-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-urri-activities__title span {
  color: var(--color-brand-green);
}

.ysat-urri-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-urri-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-urri-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-urri-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-urri-activities__slide.active {
  opacity: 1;
}

.ysat-urri-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-urri-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-urri-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-urri-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-urri-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-urri-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-urri-activity:hover,
.ysat-urri-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-urri-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-urri-activity:hover .ysat-urri-activity__icon,
.ysat-urri-activity.active .ysat-urri-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-urri-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-urri-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-urri-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-urri-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-urri-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-urri-results__header {
  margin-bottom: 40px;
}

.ysat-urri-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-urri-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-urri-results__title span {
  color: var(--color-brand-green);
}

.ysat-urri-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-urri-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-urri-result:last-child {
  border-right: none;
}

.ysat-urri-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-urri-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-urri-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-urri-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-urri-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-urri-related__header {
  margin-bottom: 32px;
}

.ysat-urri-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-urri-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-urri-related__title span {
  color: var(--color-gold-amber);
}

.ysat-urri-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-urri-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-urri-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-urri-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-urri-related-card:hover .ysat-urri-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-urri-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-urri-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-urri-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-urri-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-urri-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-urri-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-urri-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-urri-related-card:hover .ysat-urri-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-urri-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-urri-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-urri-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-urri-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-urri-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-urri-activities__slider {
    position: static;
  }

  .ysat-urri-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-urri-hero,
  .ysat-urri-overview,
  .ysat-urri-activities,
  .ysat-urri-results,
  .ysat-urri-related {
    padding: 40px 24px;
  }

  .ysat-urri-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-urri-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-urri-hero__stat:nth-child(1),
  .ysat-urri-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-urri-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-urri-overview__facts {
    position: static;
  }

  .ysat-urri-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-urri-result:nth-child(2) {
    border-right: none;
  }

  .ysat-urri-result:nth-child(1),
  .ysat-urri-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-urri-hero,
  .ysat-urri-overview,
  .ysat-urri-activities,
  .ysat-urri-results,
  .ysat-urri-related {
    padding: 32px 16px;
  }

  .ysat-urri-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-urri-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-urri-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-urri-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-urri-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-urri-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-danida-sp2-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-danida-sp2-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-danida-sp2-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-danida-sp2-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-danida-sp2-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-danida-sp2-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-danida-sp2-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-danida-sp2-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-danida-sp2-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-danida-sp2-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-danida-sp2-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-danida-sp2-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-danida-sp2-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-danida-sp2-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-danida-sp2-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-danida-sp2-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-danida-sp2-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-danida-sp2-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-danida-sp2-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-danida-sp2-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-danida-sp2-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-danida-sp2-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-danida-sp2-hero__stat:last-child {
  border-right: none;
}

.ysat-danida-sp2-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-danida-sp2-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-danida-sp2-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-danida-sp2-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-danida-sp2-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-danida-sp2-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-danida-sp2-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-danida-sp2-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-danida-sp2-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-danida-sp2-hero__stat:nth-child(1),
  .ysat-danida-sp2-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-danida-sp2-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-danida-sp2-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-danida-sp2-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-danida-sp2-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-danida-sp2-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-danida-sp2-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-danida-sp2-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-danida-sp2-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-danida-sp2-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-danida-sp2-overview__title span {
  color: var(--color-brand-green);
}

.ysat-danida-sp2-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-danida-sp2-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-danida-sp2-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-danida-sp2-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-danida-sp2-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-danida-sp2-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-danida-sp2-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-danida-sp2-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-danida-sp2-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — DANIDA SP II
   Prefix: ysat-danida-sp2-
   ============================================================ */

.ysat-danida-sp2-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-danida-sp2-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-danida-sp2-activities__header {
  margin-bottom: 40px;
}

.ysat-danida-sp2-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-danida-sp2-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-danida-sp2-activities__title span {
  color: var(--color-brand-green);
}

.ysat-danida-sp2-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-danida-sp2-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-danida-sp2-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-danida-sp2-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-danida-sp2-activities__slide.active {
  opacity: 1;
}

.ysat-danida-sp2-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-danida-sp2-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-danida-sp2-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-danida-sp2-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-danida-sp2-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-danida-sp2-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-danida-sp2-activity:hover,
.ysat-danida-sp2-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-danida-sp2-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-danida-sp2-activity:hover .ysat-danida-sp2-activity__icon,
.ysat-danida-sp2-activity.active .ysat-danida-sp2-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-danida-sp2-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-danida-sp2-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-danida-sp2-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-danida-sp2-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-danida-sp2-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-danida-sp2-results__header {
  margin-bottom: 40px;
}

.ysat-danida-sp2-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-danida-sp2-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-danida-sp2-results__title span {
  color: var(--color-brand-green);
}

.ysat-danida-sp2-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-danida-sp2-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-danida-sp2-result:last-child {
  border-right: none;
}

.ysat-danida-sp2-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-danida-sp2-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-danida-sp2-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-danida-sp2-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-danida-sp2-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-danida-sp2-related__header {
  margin-bottom: 32px;
}

.ysat-danida-sp2-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-danida-sp2-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-danida-sp2-related__title span {
  color: var(--color-gold-amber);
}

.ysat-danida-sp2-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-danida-sp2-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-danida-sp2-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-danida-sp2-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-danida-sp2-related-card:hover .ysat-danida-sp2-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-danida-sp2-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-danida-sp2-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-danida-sp2-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-danida-sp2-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-danida-sp2-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-danida-sp2-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-danida-sp2-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-danida-sp2-related-card:hover .ysat-danida-sp2-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-danida-sp2-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-danida-sp2-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-danida-sp2-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-danida-sp2-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-danida-sp2-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-danida-sp2-activities__slider {
    position: static;
  }

  .ysat-danida-sp2-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-danida-sp2-hero,
  .ysat-danida-sp2-overview,
  .ysat-danida-sp2-activities,
  .ysat-danida-sp2-results,
  .ysat-danida-sp2-related {
    padding: 40px 24px;
  }

  .ysat-danida-sp2-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-danida-sp2-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-danida-sp2-hero__stat:nth-child(1),
  .ysat-danida-sp2-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-danida-sp2-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-danida-sp2-overview__facts {
    position: static;
  }

  .ysat-danida-sp2-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-danida-sp2-result:nth-child(2) {
    border-right: none;
  }

  .ysat-danida-sp2-result:nth-child(1),
  .ysat-danida-sp2-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-danida-sp2-hero,
  .ysat-danida-sp2-overview,
  .ysat-danida-sp2-activities,
  .ysat-danida-sp2-results,
  .ysat-danida-sp2-related {
    padding: 32px 16px;
  }

  .ysat-danida-sp2-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-danida-sp2-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-danida-sp2-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-danida-sp2-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-danida-sp2-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-danida-sp2-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-reach-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-reach-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-reach-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-reach-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-reach-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-reach-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-reach-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-reach-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-reach-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-reach-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-reach-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-reach-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-reach-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-reach-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-reach-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-reach-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-reach-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-reach-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-reach-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-reach-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-reach-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-reach-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-reach-hero__stat:last-child {
  border-right: none;
}

.ysat-reach-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-reach-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-reach-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-reach-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-reach-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-reach-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-reach-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-reach-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-reach-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-reach-hero__stat:nth-child(1),
  .ysat-reach-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-reach-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-reach-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-reach-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-reach-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-reach-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-reach-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-reach-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-reach-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-reach-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-reach-overview__title span {
  color: var(--color-brand-green);
}

.ysat-reach-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-reach-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-reach-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-reach-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-reach-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-reach-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-reach-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-reach-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-reach-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — REACH
   Prefix: ysat-reach-
   ============================================================ */

.ysat-reach-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-reach-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-reach-activities__header {
  margin-bottom: 40px;
}

.ysat-reach-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-reach-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-reach-activities__title span {
  color: var(--color-brand-green);
}

.ysat-reach-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-reach-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-reach-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-reach-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-reach-activities__slide.active {
  opacity: 1;
}

.ysat-reach-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-reach-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-reach-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-reach-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-reach-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-reach-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-reach-activity:hover,
.ysat-reach-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-reach-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-reach-activity:hover .ysat-reach-activity__icon,
.ysat-reach-activity.active .ysat-reach-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-reach-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-reach-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-reach-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-reach-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-reach-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-reach-results__header {
  margin-bottom: 40px;
}

.ysat-reach-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-reach-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-reach-results__title span {
  color: var(--color-brand-green);
}

.ysat-reach-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-reach-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-reach-result:last-child {
  border-right: none;
}

.ysat-reach-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-reach-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-reach-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-reach-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-reach-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-reach-related__header {
  margin-bottom: 32px;
}

.ysat-reach-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-reach-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-reach-related__title span {
  color: var(--color-gold-amber);
}

.ysat-reach-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-reach-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-reach-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-reach-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-reach-related-card:hover .ysat-reach-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-reach-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-reach-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-reach-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-reach-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-reach-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-reach-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-reach-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-reach-related-card:hover .ysat-reach-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-reach-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-reach-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-reach-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-reach-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-reach-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-reach-activities__slider {
    position: static;
  }

  .ysat-reach-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-reach-hero,
  .ysat-reach-overview,
  .ysat-reach-activities,
  .ysat-reach-results,
  .ysat-reach-related {
    padding: 40px 24px;
  }

  .ysat-reach-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-reach-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-reach-hero__stat:nth-child(1),
  .ysat-reach-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-reach-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-reach-overview__facts {
    position: static;
  }

  .ysat-reach-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-reach-result:nth-child(2) {
    border-right: none;
  }

  .ysat-reach-result:nth-child(1),
  .ysat-reach-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-reach-hero,
  .ysat-reach-overview,
  .ysat-reach-activities,
  .ysat-reach-results,
  .ysat-reach-related {
    padding: 32px 16px;
  }

  .ysat-reach-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-reach-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-reach-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-reach-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-reach-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-reach-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-ayp-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-ayp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-ayp-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-ayp-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-ayp-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-ayp-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-ayp-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-ayp-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-ayp-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-ayp-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-ayp-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-ayp-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-ayp-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-ayp-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-ayp-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-ayp-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-ayp-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-ayp-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-ayp-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-ayp-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-ayp-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-ayp-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-ayp-hero__stat:last-child {
  border-right: none;
}

.ysat-ayp-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-ayp-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-ayp-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-ayp-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-ayp-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-ayp-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-ayp-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-ayp-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-ayp-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-ayp-hero__stat:nth-child(1),
  .ysat-ayp-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-ayp-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-ayp-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-ayp-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-ayp-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-ayp-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-ayp-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-ayp-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-ayp-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-ayp-overview__title span {
  color: var(--color-brand-green);
}

.ysat-ayp-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-ayp-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-ayp-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-ayp-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-ayp-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-ayp-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-ayp-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-ayp-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-ayp-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — AFRICAN YOUTH PANEL
   Prefix: ysat-ayp-
   ============================================================ */

.ysat-ayp-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-ayp-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-ayp-activities__header {
  margin-bottom: 40px;
}

.ysat-ayp-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-ayp-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-ayp-activities__title span {
  color: var(--color-brand-green);
}

.ysat-ayp-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-ayp-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-ayp-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-ayp-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-ayp-activities__slide.active {
  opacity: 1;
}

.ysat-ayp-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-ayp-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-ayp-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-ayp-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-ayp-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-ayp-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-ayp-activity:hover,
.ysat-ayp-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-ayp-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-ayp-activity:hover .ysat-ayp-activity__icon,
.ysat-ayp-activity.active .ysat-ayp-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-ayp-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-ayp-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-ayp-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-ayp-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-ayp-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-ayp-results__header {
  margin-bottom: 40px;
}

.ysat-ayp-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-ayp-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-ayp-results__title span {
  color: var(--color-brand-green);
}

.ysat-ayp-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-ayp-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-ayp-result:last-child {
  border-right: none;
}

.ysat-ayp-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-ayp-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-ayp-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-ayp-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-ayp-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-ayp-related__header {
  margin-bottom: 32px;
}

.ysat-ayp-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-ayp-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-ayp-related__title span {
  color: var(--color-gold-amber);
}

.ysat-ayp-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-ayp-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-ayp-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-ayp-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-ayp-related-card:hover .ysat-ayp-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-ayp-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-ayp-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-ayp-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-ayp-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-ayp-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-ayp-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-ayp-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-ayp-related-card:hover .ysat-ayp-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-ayp-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-ayp-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-ayp-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-ayp-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-ayp-activities__slider {
    position: static;
  }

  .ysat-ayp-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-ayp-hero,
  .ysat-ayp-overview,
  .ysat-ayp-activities,
  .ysat-ayp-results,
  .ysat-ayp-related {
    padding: 40px 24px;
  }

  .ysat-ayp-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-ayp-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-ayp-hero__stat:nth-child(1),
  .ysat-ayp-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-ayp-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-ayp-overview__facts {
    position: static;
  }

  .ysat-ayp-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-ayp-result:nth-child(2) {
    border-right: none;
  }

  .ysat-ayp-result:nth-child(1),
  .ysat-ayp-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-ayp-hero,
  .ysat-ayp-overview,
  .ysat-ayp-activities,
  .ysat-ayp-results,
  .ysat-ayp-related {
    padding: 32px 16px;
  }

  .ysat-ayp-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-ayp-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-ayp-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-ayp-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-ayp-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-dca-environment-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-dca-environment-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-dca-environment-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-dca-environment-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-dca-environment-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-dca-environment-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-dca-environment-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-dca-environment-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-dca-environment-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-dca-environment-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-dca-environment-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-dca-environment-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-dca-environment-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-dca-environment-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-dca-environment-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-dca-environment-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-dca-environment-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-dca-environment-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-dca-environment-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-dca-environment-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-dca-environment-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-dca-environment-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-dca-environment-hero__stat:last-child {
  border-right: none;
}

.ysat-dca-environment-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-dca-environment-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-dca-environment-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-dca-environment-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-dca-environment-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-dca-environment-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-dca-environment-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-dca-environment-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-dca-environment-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-dca-environment-hero__stat:nth-child(1),
  .ysat-dca-environment-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-dca-environment-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-dca-environment-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-dca-environment-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-dca-environment-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-dca-environment-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-dca-environment-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-dca-environment-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-dca-environment-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-dca-environment-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-dca-environment-overview__title span {
  color: var(--color-brand-green);
}

.ysat-dca-environment-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-dca-environment-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-dca-environment-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-dca-environment-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-dca-environment-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-dca-environment-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-dca-environment-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-dca-environment-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-dca-environment-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — DCA ENVIRONMENT
   Prefix: ysat-dca-environment-
   ============================================================ */

.ysat-dca-environment-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-dca-environment-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-dca-environment-activities__header {
  margin-bottom: 40px;
}

.ysat-dca-environment-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-dca-environment-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-dca-environment-activities__title span {
  color: var(--color-brand-green);
}

.ysat-dca-environment-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-dca-environment-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-dca-environment-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-dca-environment-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-dca-environment-activities__slide.active {
  opacity: 1;
}

.ysat-dca-environment-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-dca-environment-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-dca-environment-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-dca-environment-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-dca-environment-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-dca-environment-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-dca-environment-activity:hover,
.ysat-dca-environment-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-dca-environment-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-dca-environment-activity:hover .ysat-dca-environment-activity__icon,
.ysat-dca-environment-activity.active .ysat-dca-environment-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-dca-environment-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-dca-environment-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-dca-environment-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-dca-environment-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-dca-environment-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-dca-environment-results__header {
  margin-bottom: 40px;
}

.ysat-dca-environment-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-dca-environment-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-dca-environment-results__title span {
  color: var(--color-brand-green);
}

.ysat-dca-environment-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-dca-environment-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-dca-environment-result:last-child {
  border-right: none;
}

.ysat-dca-environment-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-dca-environment-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-dca-environment-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-dca-environment-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-dca-environment-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-dca-environment-related__header {
  margin-bottom: 32px;
}

.ysat-dca-environment-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-dca-environment-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-dca-environment-related__title span {
  color: var(--color-gold-amber);
}

.ysat-dca-environment-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-dca-environment-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-dca-environment-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-dca-environment-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-dca-environment-related-card:hover .ysat-dca-environment-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-dca-environment-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-dca-environment-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-dca-environment-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-dca-environment-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-dca-environment-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-dca-environment-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-dca-environment-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-dca-environment-related-card:hover .ysat-dca-environment-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-dca-environment-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-dca-environment-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-dca-environment-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-dca-environment-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-dca-environment-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-dca-environment-activities__slider {
    position: static;
  }

  .ysat-dca-environment-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-dca-environment-hero,
  .ysat-dca-environment-overview,
  .ysat-dca-environment-activities,
  .ysat-dca-environment-results,
  .ysat-dca-environment-related {
    padding: 40px 24px;
  }

  .ysat-dca-environment-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-dca-environment-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-dca-environment-hero__stat:nth-child(1),
  .ysat-dca-environment-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-dca-environment-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-dca-environment-overview__facts {
    position: static;
  }

  .ysat-dca-environment-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-dca-environment-result:nth-child(2) {
    border-right: none;
  }

  .ysat-dca-environment-result:nth-child(1),
  .ysat-dca-environment-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-dca-environment-hero,
  .ysat-dca-environment-overview,
  .ysat-dca-environment-activities,
  .ysat-dca-environment-results,
  .ysat-dca-environment-related {
    padding: 32px 16px;
  }

  .ysat-dca-environment-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-dca-environment-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-dca-environment-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-dca-environment-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-dca-environment-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-dca-environment-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-koica-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-koica-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-koica-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-koica-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-koica-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-koica-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-koica-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-koica-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-koica-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-koica-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-koica-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-koica-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-koica-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-koica-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-koica-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-koica-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-koica-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-koica-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-koica-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-koica-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-koica-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-koica-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-koica-hero__stat:last-child {
  border-right: none;
}

.ysat-koica-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-koica-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-koica-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-koica-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-koica-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-koica-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-koica-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-koica-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-koica-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-koica-hero__stat:nth-child(1),
  .ysat-koica-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-koica-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-koica-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-koica-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-koica-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-koica-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-koica-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-koica-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-koica-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-koica-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-koica-overview__title span {
  color: var(--color-brand-green);
}

.ysat-koica-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-koica-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-koica-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-koica-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-koica-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-koica-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-koica-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-koica-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-koica-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — KOICA
   Prefix: ysat-koica-
   ============================================================ */

.ysat-koica-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-koica-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-koica-activities__header {
  margin-bottom: 40px;
}

.ysat-koica-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-koica-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-koica-activities__title span {
  color: var(--color-brand-green);
}

.ysat-koica-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-koica-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-koica-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-koica-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-koica-activities__slide.active {
  opacity: 1;
}

.ysat-koica-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-koica-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-koica-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-koica-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-koica-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-koica-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-koica-activity:hover,
.ysat-koica-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-koica-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-koica-activity:hover .ysat-koica-activity__icon,
.ysat-koica-activity.active .ysat-koica-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-koica-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-koica-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-koica-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-koica-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-koica-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-koica-results__header {
  margin-bottom: 40px;
}

.ysat-koica-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-koica-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-koica-results__title span {
  color: var(--color-brand-green);
}

.ysat-koica-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-koica-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-koica-result:last-child {
  border-right: none;
}

.ysat-koica-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-koica-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-koica-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-koica-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-koica-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-koica-related__header {
  margin-bottom: 32px;
}

.ysat-koica-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-koica-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-koica-related__title span {
  color: var(--color-gold-amber);
}

.ysat-koica-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-koica-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-koica-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-koica-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-koica-related-card:hover .ysat-koica-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-koica-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-koica-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-koica-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-koica-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-koica-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-koica-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-koica-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-koica-related-card:hover .ysat-koica-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-koica-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-koica-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-koica-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-koica-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-koica-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-koica-activities__slider {
    position: static;
  }

  .ysat-koica-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-koica-hero,
  .ysat-koica-overview,
  .ysat-koica-activities,
  .ysat-koica-results,
  .ysat-koica-related {
    padding: 40px 24px;
  }

  .ysat-koica-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-koica-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-koica-hero__stat:nth-child(1),
  .ysat-koica-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-koica-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-koica-overview__facts {
    position: static;
  }

  .ysat-koica-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-koica-result:nth-child(2) {
    border-right: none;
  }

  .ysat-koica-result:nth-child(1),
  .ysat-koica-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-koica-hero,
  .ysat-koica-overview,
  .ysat-koica-activities,
  .ysat-koica-results,
  .ysat-koica-related {
    padding: 32px 16px;
  }

  .ysat-koica-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-koica-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-koica-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-koica-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-koica-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-koica-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-offgrid-ccb-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-offgrid-ccb-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-offgrid-ccb-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-offgrid-ccb-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-offgrid-ccb-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-offgrid-ccb-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-offgrid-ccb-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-offgrid-ccb-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-offgrid-ccb-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-offgrid-ccb-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-offgrid-ccb-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-offgrid-ccb-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-offgrid-ccb-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-offgrid-ccb-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-offgrid-ccb-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-offgrid-ccb-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-offgrid-ccb-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-offgrid-ccb-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-offgrid-ccb-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-offgrid-ccb-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-offgrid-ccb-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-offgrid-ccb-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-offgrid-ccb-hero__stat:last-child {
  border-right: none;
}

.ysat-offgrid-ccb-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-offgrid-ccb-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-offgrid-ccb-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-offgrid-ccb-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-offgrid-ccb-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-offgrid-ccb-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-offgrid-ccb-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-offgrid-ccb-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-offgrid-ccb-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-offgrid-ccb-hero__stat:nth-child(1),
  .ysat-offgrid-ccb-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-offgrid-ccb-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-offgrid-ccb-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-offgrid-ccb-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-offgrid-ccb-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-offgrid-ccb-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-offgrid-ccb-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-offgrid-ccb-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-offgrid-ccb-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-offgrid-ccb-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-offgrid-ccb-overview__title span {
  color: var(--color-brand-green);
}

.ysat-offgrid-ccb-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-offgrid-ccb-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-offgrid-ccb-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-offgrid-ccb-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-offgrid-ccb-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-offgrid-ccb-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-offgrid-ccb-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-offgrid-ccb-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-offgrid-ccb-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — OFF-GRID ENERGY AND CCB
   Prefix: ysat-offgrid-ccb-
   ============================================================ */

.ysat-offgrid-ccb-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-offgrid-ccb-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-offgrid-ccb-activities__header {
  margin-bottom: 40px;
}

.ysat-offgrid-ccb-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-offgrid-ccb-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-offgrid-ccb-activities__title span {
  color: var(--color-brand-green);
}

.ysat-offgrid-ccb-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-offgrid-ccb-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-offgrid-ccb-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-offgrid-ccb-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-offgrid-ccb-activities__slide.active {
  opacity: 1;
}

.ysat-offgrid-ccb-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-offgrid-ccb-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-offgrid-ccb-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-offgrid-ccb-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-offgrid-ccb-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-offgrid-ccb-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-offgrid-ccb-activity:hover,
.ysat-offgrid-ccb-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-offgrid-ccb-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-offgrid-ccb-activity:hover .ysat-offgrid-ccb-activity__icon,
.ysat-offgrid-ccb-activity.active .ysat-offgrid-ccb-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-offgrid-ccb-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-offgrid-ccb-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-offgrid-ccb-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-offgrid-ccb-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-offgrid-ccb-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-offgrid-ccb-results__header {
  margin-bottom: 40px;
}

.ysat-offgrid-ccb-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-offgrid-ccb-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-offgrid-ccb-results__title span {
  color: var(--color-brand-green);
}

.ysat-offgrid-ccb-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-offgrid-ccb-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-offgrid-ccb-result:last-child {
  border-right: none;
}

.ysat-offgrid-ccb-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-offgrid-ccb-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-offgrid-ccb-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-offgrid-ccb-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-offgrid-ccb-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-offgrid-ccb-related__header {
  margin-bottom: 32px;
}

.ysat-offgrid-ccb-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-offgrid-ccb-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-offgrid-ccb-related__title span {
  color: var(--color-gold-amber);
}

.ysat-offgrid-ccb-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-offgrid-ccb-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-offgrid-ccb-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-offgrid-ccb-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-offgrid-ccb-related-card:hover .ysat-offgrid-ccb-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-offgrid-ccb-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-offgrid-ccb-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-offgrid-ccb-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-offgrid-ccb-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-offgrid-ccb-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-offgrid-ccb-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-offgrid-ccb-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-offgrid-ccb-related-card:hover .ysat-offgrid-ccb-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-offgrid-ccb-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-offgrid-ccb-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-offgrid-ccb-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-offgrid-ccb-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-offgrid-ccb-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-offgrid-ccb-activities__slider {
    position: static;
  }

  .ysat-offgrid-ccb-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-offgrid-ccb-hero,
  .ysat-offgrid-ccb-overview,
  .ysat-offgrid-ccb-activities,
  .ysat-offgrid-ccb-results,
  .ysat-offgrid-ccb-related {
    padding: 40px 24px;
  }

  .ysat-offgrid-ccb-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-offgrid-ccb-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-offgrid-ccb-hero__stat:nth-child(1),
  .ysat-offgrid-ccb-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-offgrid-ccb-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-offgrid-ccb-overview__facts {
    position: static;
  }

  .ysat-offgrid-ccb-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-offgrid-ccb-result:nth-child(2) {
    border-right: none;
  }

  .ysat-offgrid-ccb-result:nth-child(1),
  .ysat-offgrid-ccb-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-offgrid-ccb-hero,
  .ysat-offgrid-ccb-overview,
  .ysat-offgrid-ccb-activities,
  .ysat-offgrid-ccb-results,
  .ysat-offgrid-ccb-related {
    padding: 32px 16px;
  }

  .ysat-offgrid-ccb-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-offgrid-ccb-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-offgrid-ccb-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-offgrid-ccb-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-offgrid-ccb-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-offgrid-ccb-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-bridge-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-bridge-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-bridge-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-bridge-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-bridge-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-bridge-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-bridge-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-bridge-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-bridge-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-bridge-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-bridge-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-bridge-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-bridge-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-bridge-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-bridge-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-bridge-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-bridge-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-bridge-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-bridge-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-bridge-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-bridge-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-bridge-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-bridge-hero__stat:last-child {
  border-right: none;
}

.ysat-bridge-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-bridge-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-bridge-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-bridge-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-bridge-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-bridge-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-bridge-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-bridge-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-hero__stat:nth-child(1),
  .ysat-bridge-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-bridge-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-bridge-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-bridge-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-bridge-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-bridge-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-bridge-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-bridge-overview__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-bridge-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-bridge-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-bridge-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-bridge-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-bridge-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-bridge-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-bridge-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-bridge-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — BRIDGE PROJECT
   Prefix: ysat-bridge-
   ============================================================ */

.ysat-bridge-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-bridge-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-activities__header {
  margin-bottom: 40px;
}

.ysat-bridge-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-activities__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-bridge-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-bridge-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-bridge-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-bridge-activities__slide.active {
  opacity: 1;
}

.ysat-bridge-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-bridge-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-bridge-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-bridge-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-bridge-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-bridge-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-bridge-activity:hover,
.ysat-bridge-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-bridge-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-bridge-activity:hover .ysat-bridge-activity__icon,
.ysat-bridge-activity.active .ysat-bridge-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-bridge-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-bridge-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-bridge-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-bridge-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-bridge-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-results__header {
  margin-bottom: 40px;
}

.ysat-bridge-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-results__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-bridge-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-bridge-result:last-child {
  border-right: none;
}

.ysat-bridge-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-bridge-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-bridge-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-bridge-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-bridge-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-related__header {
  margin-bottom: 32px;
}

.ysat-bridge-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-related__title span {
  color: var(--color-gold-amber);
}

.ysat-bridge-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-bridge-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-bridge-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-bridge-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-bridge-related-card:hover .ysat-bridge-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-bridge-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-bridge-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-bridge-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-bridge-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-bridge-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-bridge-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-bridge-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-bridge-related-card:hover .ysat-bridge-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-bridge-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-bridge-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-bridge-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-bridge-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-bridge-activities__slider {
    position: static;
  }

  .ysat-bridge-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-bridge-hero,
  .ysat-bridge-overview,
  .ysat-bridge-activities,
  .ysat-bridge-results,
  .ysat-bridge-related {
    padding: 40px 24px;
  }

  .ysat-bridge-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-hero__stat:nth-child(1),
  .ysat-bridge-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-bridge-overview__facts {
    position: static;
  }

  .ysat-bridge-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-result:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-result:nth-child(1),
  .ysat-bridge-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-bridge-hero,
  .ysat-bridge-overview,
  .ysat-bridge-activities,
  .ysat-bridge-results,
  .ysat-bridge-related {
    padding: 32px 16px;
  }

  .ysat-bridge-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-bridge-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-bridge-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-gfs-education-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-gfs-education-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-gfs-education-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-gfs-education-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-gfs-education-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-gfs-education-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-gfs-education-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-gfs-education-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-gfs-education-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-gfs-education-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-gfs-education-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-gfs-education-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-gfs-education-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-gfs-education-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-gfs-education-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-gfs-education-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-gfs-education-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-gfs-education-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-gfs-education-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-gfs-education-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-gfs-education-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-gfs-education-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-gfs-education-hero__stat:last-child {
  border-right: none;
}

.ysat-gfs-education-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-gfs-education-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-gfs-education-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-gfs-education-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-gfs-education-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-gfs-education-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-gfs-education-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-gfs-education-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-education-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-education-hero__stat:nth-child(1),
  .ysat-gfs-education-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-gfs-education-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-gfs-education-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-gfs-education-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-education-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-education-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-gfs-education-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-gfs-education-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-gfs-education-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-education-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-gfs-education-overview__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-education-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-gfs-education-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-gfs-education-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-gfs-education-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-gfs-education-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-gfs-education-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-gfs-education-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-gfs-education-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-gfs-education-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — GFS EDUCATION
   Prefix: ysat-gfs-education-
   ============================================================ */

.ysat-gfs-education-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-gfs-education-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-education-activities__header {
  margin-bottom: 40px;
}

.ysat-gfs-education-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-education-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-education-activities__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-education-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-gfs-education-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-gfs-education-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-gfs-education-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-gfs-education-activities__slide.active {
  opacity: 1;
}

.ysat-gfs-education-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-gfs-education-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-gfs-education-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-gfs-education-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-gfs-education-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-gfs-education-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-gfs-education-activity:hover,
.ysat-gfs-education-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-gfs-education-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-gfs-education-activity:hover .ysat-gfs-education-activity__icon,
.ysat-gfs-education-activity.active .ysat-gfs-education-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-gfs-education-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-gfs-education-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-gfs-education-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-gfs-education-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-gfs-education-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-education-results__header {
  margin-bottom: 40px;
}

.ysat-gfs-education-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-education-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-education-results__title span {
  color: var(--color-brand-green);
}

.ysat-gfs-education-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-gfs-education-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-gfs-education-result:last-child {
  border-right: none;
}

.ysat-gfs-education-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-gfs-education-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-gfs-education-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-gfs-education-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-gfs-education-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-gfs-education-related__header {
  margin-bottom: 32px;
}

.ysat-gfs-education-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-gfs-education-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-gfs-education-related__title span {
  color: var(--color-gold-amber);
}

.ysat-gfs-education-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-gfs-education-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-gfs-education-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-gfs-education-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-gfs-education-related-card:hover .ysat-gfs-education-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-gfs-education-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-gfs-education-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-gfs-education-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-gfs-education-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-gfs-education-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-gfs-education-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-gfs-education-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-gfs-education-related-card:hover .ysat-gfs-education-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-gfs-education-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-gfs-education-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-gfs-education-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-gfs-education-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-education-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-gfs-education-activities__slider {
    position: static;
  }

  .ysat-gfs-education-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-gfs-education-hero,
  .ysat-gfs-education-overview,
  .ysat-gfs-education-activities,
  .ysat-gfs-education-results,
  .ysat-gfs-education-related {
    padding: 40px 24px;
  }

  .ysat-gfs-education-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-education-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-education-hero__stat:nth-child(1),
  .ysat-gfs-education-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-education-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-gfs-education-overview__facts {
    position: static;
  }

  .ysat-gfs-education-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-gfs-education-result:nth-child(2) {
    border-right: none;
  }

  .ysat-gfs-education-result:nth-child(1),
  .ysat-gfs-education-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-gfs-education-hero,
  .ysat-gfs-education-overview,
  .ysat-gfs-education-activities,
  .ysat-gfs-education-results,
  .ysat-gfs-education-related {
    padding: 32px 16px;
  }

  .ysat-gfs-education-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-education-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-gfs-education-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-gfs-education-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-gfs-education-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-gfs-education-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-cwtl-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-cwtl-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-cwtl-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-cwtl-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-cwtl-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-cwtl-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-cwtl-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-cwtl-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-cwtl-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-cwtl-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-cwtl-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-cwtl-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-cwtl-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-cwtl-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-cwtl-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-cwtl-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-cwtl-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-cwtl-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-cwtl-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-cwtl-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-cwtl-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-cwtl-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-cwtl-hero__stat:last-child {
  border-right: none;
}

.ysat-cwtl-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-cwtl-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-cwtl-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-cwtl-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-cwtl-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-cwtl-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-cwtl-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-cwtl-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-cwtl-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-cwtl-hero__stat:nth-child(1),
  .ysat-cwtl-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-cwtl-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-cwtl-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-cwtl-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-cwtl-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-cwtl-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-cwtl-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-cwtl-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-cwtl-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-cwtl-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-cwtl-overview__title span {
  color: var(--color-brand-green);
}

.ysat-cwtl-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-cwtl-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-cwtl-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-cwtl-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-cwtl-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-cwtl-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-cwtl-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-cwtl-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-cwtl-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — CWTL
   Prefix: ysat-cwtl-
   ============================================================ */

.ysat-cwtl-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-cwtl-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-cwtl-activities__header {
  margin-bottom: 40px;
}

.ysat-cwtl-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-cwtl-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-cwtl-activities__title span {
  color: var(--color-brand-green);
}

.ysat-cwtl-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-cwtl-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-cwtl-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-cwtl-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-cwtl-activities__slide.active {
  opacity: 1;
}

.ysat-cwtl-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-cwtl-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-cwtl-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-cwtl-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-cwtl-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-cwtl-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-cwtl-activity:hover,
.ysat-cwtl-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-cwtl-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-cwtl-activity:hover .ysat-cwtl-activity__icon,
.ysat-cwtl-activity.active .ysat-cwtl-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-cwtl-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-cwtl-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-cwtl-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-cwtl-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-cwtl-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-cwtl-results__header {
  margin-bottom: 40px;
}

.ysat-cwtl-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-cwtl-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-cwtl-results__title span {
  color: var(--color-brand-green);
}

.ysat-cwtl-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-cwtl-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-cwtl-result:last-child {
  border-right: none;
}

.ysat-cwtl-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-cwtl-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-cwtl-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-cwtl-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-cwtl-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-cwtl-related__header {
  margin-bottom: 32px;
}

.ysat-cwtl-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-cwtl-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-cwtl-related__title span {
  color: var(--color-gold-amber);
}

.ysat-cwtl-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-cwtl-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-cwtl-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-cwtl-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-cwtl-related-card:hover .ysat-cwtl-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-cwtl-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-cwtl-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-cwtl-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-cwtl-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-cwtl-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-cwtl-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-cwtl-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-cwtl-related-card:hover .ysat-cwtl-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-cwtl-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-cwtl-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-cwtl-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-cwtl-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-cwtl-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-cwtl-activities__slider {
    position: static;
  }

  .ysat-cwtl-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-cwtl-hero,
  .ysat-cwtl-overview,
  .ysat-cwtl-activities,
  .ysat-cwtl-results,
  .ysat-cwtl-related {
    padding: 40px 24px;
  }

  .ysat-cwtl-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-cwtl-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-cwtl-hero__stat:nth-child(1),
  .ysat-cwtl-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-cwtl-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-cwtl-overview__facts {
    position: static;
  }

  .ysat-cwtl-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-cwtl-result:nth-child(2) {
    border-right: none;
  }

  .ysat-cwtl-result:nth-child(1),
  .ysat-cwtl-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-cwtl-hero,
  .ysat-cwtl-overview,
  .ysat-cwtl-activities,
  .ysat-cwtl-results,
  .ysat-cwtl-related {
    padding: 32px 16px;
  }

  .ysat-cwtl-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-cwtl-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-cwtl-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-cwtl-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-cwtl-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-cwtl-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-bridge-yaw-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-bridge-yaw-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-bridge-yaw-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-bridge-yaw-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-bridge-yaw-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-bridge-yaw-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-bridge-yaw-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-bridge-yaw-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-bridge-yaw-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-bridge-yaw-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-bridge-yaw-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-bridge-yaw-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-bridge-yaw-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-bridge-yaw-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-bridge-yaw-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-bridge-yaw-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-bridge-yaw-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-bridge-yaw-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-bridge-yaw-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-bridge-yaw-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-bridge-yaw-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-bridge-yaw-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-bridge-yaw-hero__stat:last-child {
  border-right: none;
}

.ysat-bridge-yaw-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-bridge-yaw-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-bridge-yaw-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-bridge-yaw-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-bridge-yaw-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-bridge-yaw-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-bridge-yaw-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-bridge-yaw-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-yaw-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-yaw-hero__stat:nth-child(1),
  .ysat-bridge-yaw-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-bridge-yaw-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-bridge-yaw-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-bridge-yaw-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-yaw-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-yaw-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-bridge-yaw-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-bridge-yaw-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-bridge-yaw-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-yaw-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-bridge-yaw-overview__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-yaw-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-bridge-yaw-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-bridge-yaw-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-bridge-yaw-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-bridge-yaw-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-bridge-yaw-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-bridge-yaw-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-bridge-yaw-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-bridge-yaw-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — BRIDGE YAW
   Prefix: ysat-bridge-yaw-
   ============================================================ */

.ysat-bridge-yaw-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-bridge-yaw-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-yaw-activities__header {
  margin-bottom: 40px;
}

.ysat-bridge-yaw-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-yaw-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-yaw-activities__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-yaw-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-bridge-yaw-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-bridge-yaw-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-bridge-yaw-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-bridge-yaw-activities__slide.active {
  opacity: 1;
}

.ysat-bridge-yaw-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-bridge-yaw-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-bridge-yaw-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-bridge-yaw-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-bridge-yaw-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-bridge-yaw-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-bridge-yaw-activity:hover,
.ysat-bridge-yaw-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-bridge-yaw-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-bridge-yaw-activity:hover .ysat-bridge-yaw-activity__icon,
.ysat-bridge-yaw-activity.active .ysat-bridge-yaw-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-bridge-yaw-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-bridge-yaw-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-bridge-yaw-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-bridge-yaw-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-bridge-yaw-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-yaw-results__header {
  margin-bottom: 40px;
}

.ysat-bridge-yaw-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-yaw-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-yaw-results__title span {
  color: var(--color-brand-green);
}

.ysat-bridge-yaw-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-bridge-yaw-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-bridge-yaw-result:last-child {
  border-right: none;
}

.ysat-bridge-yaw-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-bridge-yaw-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-bridge-yaw-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-bridge-yaw-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-bridge-yaw-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-bridge-yaw-related__header {
  margin-bottom: 32px;
}

.ysat-bridge-yaw-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-bridge-yaw-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-bridge-yaw-related__title span {
  color: var(--color-gold-amber);
}

.ysat-bridge-yaw-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-bridge-yaw-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-bridge-yaw-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-bridge-yaw-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-bridge-yaw-related-card:hover .ysat-bridge-yaw-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-bridge-yaw-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-bridge-yaw-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-bridge-yaw-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-bridge-yaw-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-bridge-yaw-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-bridge-yaw-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-bridge-yaw-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-bridge-yaw-related-card:hover .ysat-bridge-yaw-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-bridge-yaw-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-bridge-yaw-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-bridge-yaw-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-bridge-yaw-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-yaw-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-bridge-yaw-activities__slider {
    position: static;
  }

  .ysat-bridge-yaw-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-bridge-yaw-hero,
  .ysat-bridge-yaw-overview,
  .ysat-bridge-yaw-activities,
  .ysat-bridge-yaw-results,
  .ysat-bridge-yaw-related {
    padding: 40px 24px;
  }

  .ysat-bridge-yaw-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-yaw-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-yaw-hero__stat:nth-child(1),
  .ysat-bridge-yaw-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-yaw-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-bridge-yaw-overview__facts {
    position: static;
  }

  .ysat-bridge-yaw-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-bridge-yaw-result:nth-child(2) {
    border-right: none;
  }

  .ysat-bridge-yaw-result:nth-child(1),
  .ysat-bridge-yaw-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-bridge-yaw-hero,
  .ysat-bridge-yaw-overview,
  .ysat-bridge-yaw-activities,
  .ysat-bridge-yaw-results,
  .ysat-bridge-yaw-related {
    padding: 32px 16px;
  }

  .ysat-bridge-yaw-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-yaw-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-bridge-yaw-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-bridge-yaw-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-bridge-yaw-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-bridge-yaw-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   SECTION 1: PROJECT HERO
   ysat-learning-haven-hero
   Add this into ysat-brand.css
   ============================================================ */

.ysat-learning-haven-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-forest-green);
  position: relative;
}

.ysat-learning-haven-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.ysat-learning-haven-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-learning-haven-hero__img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    var(--color-forest-green) 0%,
    transparent 40%
  );
}

.ysat-learning-haven-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-learning-haven-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-learning-haven-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-learning-haven-hero__breadcrumb a:hover {
  color: var(--color-gold-amber);
}

.ysat-learning-haven-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.25);
}

.ysat-learning-haven-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.72);
}

.ysat-learning-haven-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}

.ysat-learning-haven-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ysat-learning-haven-hero__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.ysat-learning-haven-hero__status--active {
  background-color: rgba(127, 203, 155, 0.2);
  color: var(--color-soft-green);
  border: 1px solid rgba(127, 203, 155, 0.35);
}

.ysat-learning-haven-hero__status--active i {
  font-size: 0.42rem;
}

.ysat-learning-haven-hero__status--completed {
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-learning-haven-hero__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.55);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ysat-learning-haven-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-learning-haven-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.72);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-10);
}

.ysat-learning-haven-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.18);
}

.ysat-learning-haven-hero__stat {
  padding: 24px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: background-color var(--transition-base);
}

.ysat-learning-haven-hero__stat:last-child {
  border-right: none;
}

.ysat-learning-haven-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.ysat-learning-haven-hero__stat-number {
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-1);
}

.ysat-learning-haven-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ysat-learning-haven-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 300px auto;
    min-height: unset;
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ysat-learning-haven-hero__img {
    grid-column: 1;
    grid-row: 1;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ysat-learning-haven-hero__img::before {
    background: linear-gradient(
      to bottom,
      transparent 50%,
      var(--color-forest-green) 100%
    );
  }

  .ysat-learning-haven-hero__inner {
    grid-column: 1;
    grid-row: 2;
    padding: 32px 24px 48px !important;
    justify-content: flex-start;
  }

  .ysat-learning-haven-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-learning-haven-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-learning-haven-hero__stat:nth-child(1),
  .ysat-learning-haven-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
}

@media (max-width: 480px) {
  .ysat-learning-haven-hero {
    grid-template-rows: 240px auto;
  }

  .ysat-learning-haven-hero__inner {
    padding: 28px 16px 40px !important;
  }

  .ysat-learning-haven-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-learning-haven-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-learning-haven-hero__stat:last-child {
    border-bottom: none;
  }
}


/* ============================================================
   SECTION 2: PROJECT OVERVIEW
   ============================================================ */

.ysat-learning-haven-overview {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-learning-haven-overview__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-learning-haven-overview__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-learning-haven-overview__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-learning-haven-overview__title span {
  color: var(--color-brand-green);
}

.ysat-learning-haven-overview__text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-learning-haven-overview__text:last-child {
  margin-bottom: 0;
}

.ysat-learning-haven-overview__facts {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  position: sticky;
  top: 110px;
}

.ysat-learning-haven-overview__facts-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-soft-green);
}

.ysat-learning-haven-overview__facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-learning-haven-overview__facts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-learning-haven-overview__facts-list li:last-child {
  border-bottom: none;
}

.ysat-learning-haven-overview__facts-key {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.ysat-learning-haven-overview__facts-val {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-near-black);
  line-height: 1.5;
}


/* ============================================================
   SECTION 3: ACTIVITIES — LEARNING HAVEN
   Prefix: ysat-learning-haven-
   ============================================================ */

.ysat-learning-haven-activities {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-learning-haven-activities__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-learning-haven-activities__header {
  margin-bottom: 40px;
}

.ysat-learning-haven-activities__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-learning-haven-activities__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-learning-haven-activities__title span {
  color: var(--color-brand-green);
}

.ysat-learning-haven-activities__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ysat-learning-haven-activities__slider {
  position: sticky;
  top: 110px;
}

.ysat-learning-haven-activities__slides {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--color-near-black);
}

.ysat-learning-haven-activities__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.ysat-learning-haven-activities__slide.active {
  opacity: 1;
}

.ysat-learning-haven-activities__caption {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.4;
  padding: var(--space-3) 0 var(--space-2);
  font-style: italic;
}

.ysat-learning-haven-activities__dots {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.ysat-learning-haven-activities__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: var(--color-light-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-base), width var(--transition-base);
}

.ysat-learning-haven-activities__dot.active {
  background-color: var(--color-brand-green);
  width: 22px;
  border-radius: var(--radius-sm);
}

.ysat-learning-haven-activities__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ysat-learning-haven-activity {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-learning-haven-activity:hover,
.ysat-learning-haven-activity.active {
  background-color: var(--color-white);
  border-color: var(--color-soft-green);
}

.ysat-learning-haven-activity__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: var(--color-mint-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-learning-haven-activity:hover .ysat-learning-haven-activity__icon,
.ysat-learning-haven-activity.active .ysat-learning-haven-activity__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-learning-haven-activity__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-learning-haven-activity__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-learning-haven-activity__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: RESULTS
   ============================================================ */

.ysat-learning-haven-results {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-learning-haven-results__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-learning-haven-results__header {
  margin-bottom: 40px;
}

.ysat-learning-haven-results__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-learning-haven-results__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-learning-haven-results__title span {
  color: var(--color-brand-green);
}

.ysat-learning-haven-results__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-learning-haven-result {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: background-color var(--transition-base);
}

.ysat-learning-haven-result:last-child {
  border-right: none;
}

.ysat-learning-haven-result:hover {
  background-color: var(--color-pale-green);
}

.ysat-learning-haven-result__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-forest-green);
  line-height: 1;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-2);
}

.ysat-learning-haven-result__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-snug);
  margin: 0;
}


/* ============================================================
   SECTION 5: RELATED PROJECTS
   ============================================================ */

.ysat-learning-haven-related {
  padding: 56px 50px;
  background-color: var(--color-near-black);
}

.ysat-learning-haven-related__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-learning-haven-related__header {
  margin-bottom: 32px;
}

.ysat-learning-haven-related__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-soft-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 10px;
}

.ysat-learning-haven-related__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-learning-haven-related__title span {
  color: var(--color-gold-amber);
}

.ysat-learning-haven-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: var(--space-8);
}

.ysat-learning-haven-related-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-learning-haven-related-card:hover {
  background-color: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
}

.ysat-learning-haven-related-card__icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-soft-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base);
}

.ysat-learning-haven-related-card:hover .ysat-learning-haven-related-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-learning-haven-related-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.ysat-learning-haven-related-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-learning-haven-related-card__status--active {
  color: var(--color-soft-green);
}

.ysat-learning-haven-related-card__status--completed {
  color: rgba(255, 255, 255, 0.35);
}

.ysat-learning-haven-related-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-learning-haven-related-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.45;
  margin: 0;
}

.ysat-learning-haven-related-card__arrow {
  color: rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-learning-haven-related-card:hover .ysat-learning-haven-related-card__arrow {
  color: var(--color-gold-amber);
  transform: translateX(4px);
}

.ysat-learning-haven-related__back {
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ysat-learning-haven-related__back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast), gap var(--transition-fast);
}

.ysat-learning-haven-related__back-link:hover {
  color: var(--color-gold-amber);
  gap: var(--space-3);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-learning-haven-related__grid {
    grid-template-columns: 1fr;
  }

  .ysat-learning-haven-activities__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-learning-haven-activities__slider {
    position: static;
  }

  .ysat-learning-haven-activities__slides {
    height: 300px;
  }
}

@media (max-width: 768px) {
  .ysat-learning-haven-hero,
  .ysat-learning-haven-overview,
  .ysat-learning-haven-activities,
  .ysat-learning-haven-results,
  .ysat-learning-haven-related {
    padding: 40px 24px;
  }

  .ysat-learning-haven-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-learning-haven-hero__stat:nth-child(2) {
    border-right: none;
  }

  .ysat-learning-haven-hero__stat:nth-child(1),
  .ysat-learning-haven-hero__stat:nth-child(2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-learning-haven-overview__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .ysat-learning-haven-overview__facts {
    position: static;
  }

  .ysat-learning-haven-results__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ysat-learning-haven-result:nth-child(2) {
    border-right: none;
  }

  .ysat-learning-haven-result:nth-child(1),
  .ysat-learning-haven-result:nth-child(2) {
    border-bottom: 1px solid var(--color-light-gray);
  }
}

@media (max-width: 480px) {
  .ysat-learning-haven-hero,
  .ysat-learning-haven-overview,
  .ysat-learning-haven-activities,
  .ysat-learning-haven-results,
  .ysat-learning-haven-related {
    padding: 32px 16px;
  }

  .ysat-learning-haven-hero__stats {
    grid-template-columns: 1fr;
  }

  .ysat-learning-haven-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ysat-learning-haven-hero__stat:last-child {
    border-bottom: none;
  }

  .ysat-learning-haven-results__grid {
    grid-template-columns: 1fr;
  }

  .ysat-learning-haven-result {
    border-right: none;
    border-bottom: 1px solid var(--color-light-gray);
  }

  .ysat-learning-haven-result:last-child {
    border-bottom: none;
  }
}



/* ============================================================
   YSAT SPA5 — Organisational Capacity Strengthening
   ysat-spa5.css
   Place in: assets/css/ysat-spa5.css
   ============================================================ */


/* ============================================================
   SECTION 1: HERO
   ============================================================ */

.ysat-spa5-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
  background-color: var(--color-near-black);
  position: relative;
}

.ysat-spa5-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-spa5-hero__bg-grid {
  display: none;
}

.ysat-spa5-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.ysat-spa5-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-spa5-hero__spa-tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 5px 14px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.ysat-spa5-hero__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.45);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.ysat-spa5-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: 1.0;
  letter-spacing: -0.03em;
  margin: 0 0 var(--space-6);
}

.ysat-spa5-hero__title span {
  color: var(--color-gold-amber);
}

.ysat-spa5-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.65);
  line-height: var(--line-height-relaxed);
  max-width: 720px;
  margin: 0 0 var(--space-12);
}

.ysat-spa5-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.03);
  max-width: 860px;
}

.ysat-spa5-hero__stat {
  padding: 28px 32px;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  transition: background-color var(--transition-base);
}

.ysat-spa5-hero__stat:last-child {
  border-right: none;
}

.ysat-spa5-hero__stat:hover {
  background-color: rgba(255, 255, 255, 0.04);
}

.ysat-spa5-hero__stat-number {
  display: block;
  font-family: var(--font-primary);
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-2);
}

.ysat-spa5-hero__stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.4;
}


/* ============================================================
   SECTION 2: NARRATIVE
   ============================================================ */

.ysat-spa5-narrative {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-spa5-narrative__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}

.ysat-spa5-narrative__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-spa5-narrative__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-6);
}

.ysat-spa5-narrative__title span {
  color: var(--color-brand-green);
}

.ysat-spa5-narrative__text p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
}

.ysat-spa5-narrative__text p:last-child { margin-bottom: 0; }

.ysat-spa5-narrative__quote {
  background-color: var(--color-near-black);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin: 0;
  position: sticky;
  top: 110px;
}

.ysat-spa5-narrative__quote p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-white);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
  font-style: italic;
}

.ysat-spa5-narrative__quote p::before {
  content: '\201C';
  color: var(--color-gold-amber);
  font-size: 2rem;
  line-height: 0;
  vertical-align: -0.4em;
  margin-right: 4px;
}

.ysat-spa5-narrative__quote cite {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-style: normal;
}


/* ============================================================
   SECTION 3: TIMELINE
   ============================================================ */

.ysat-spa5-timeline {
  padding: 56px 50px;
  background-color: var(--color-near-black);
  position: relative;
  overflow: hidden;
}

.ysat-spa5-timeline::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 80% 30%, rgba(27, 77, 46, 0.2) 0%, transparent 55%);
  pointer-events: none;
}

.ysat-spa5-timeline__inner {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.ysat-spa5-timeline__header {
  text-align: center;
  margin-bottom: 40px;
}

.ysat-spa5-timeline__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-spa5-timeline__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-4);
}

.ysat-spa5-timeline__title span { color: var(--color-gold-amber); }

.ysat-spa5-timeline__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: rgba(255, 255, 255, 0.45);
  line-height: var(--line-height-relaxed);
  max-width: 540px;
  margin: 0 auto;
}

.ysat-spa5-timeline__track {
  position: relative;
  padding: 0 0 var(--space-8);
}

.ysat-spa5-timeline__line {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(255, 195, 44, 0.3) 5%,
    rgba(255, 195, 44, 0.3) 92%,
    transparent 100%
  );
  transform: translateX(-50%);
}

.ysat-spa5-timeline__item {
  display: grid;
  grid-template-columns: 1fr 48px 1fr;
  gap: 0 32px;
  margin-bottom: 48px;
  align-items: start;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.ysat-spa5-timeline__item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.ysat-spa5-timeline__item--left .ysat-spa5-timeline__card {
  grid-column: 1;
  grid-row: 1;
  text-align: left;
}

.ysat-spa5-timeline__item--left .ysat-spa5-timeline__node {
  grid-column: 2;
  grid-row: 1;
}

.ysat-spa5-timeline__item--right .ysat-spa5-timeline__node {
  grid-column: 2;
  grid-row: 1;
}

.ysat-spa5-timeline__item--right .ysat-spa5-timeline__card {
  grid-column: 3;
  grid-row: 1;
  text-align: left;
}

.ysat-spa5-timeline__node {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 4px;
}

.ysat-spa5-timeline__node::before {
  content: '';
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  background-color: var(--color-gold-amber);
  border: 3px solid var(--color-near-black);
  box-shadow: 0 0 0 2px var(--color-gold-amber);
  flex-shrink: 0;
  margin-bottom: 6px;
}

.ysat-spa5-timeline__node--future::before {
  background-color: transparent;
  border-color: rgba(255, 195, 44, 0.4);
  box-shadow: 0 0 0 2px rgba(255, 195, 44, 0.3);
}

.ysat-spa5-timeline__year {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  white-space: nowrap;
}

.ysat-spa5-timeline__card {
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  transition: background-color var(--transition-base), border-color var(--transition-base);
}

.ysat-spa5-timeline__card:hover {
  background-color: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 195, 44, 0.2);
}

.ysat-spa5-timeline__card--future {
  border-color: rgba(255, 195, 44, 0.15);
  background-color: rgba(255, 195, 44, 0.03);
}

.ysat-spa5-timeline__card-title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
  margin: 0 0 var(--space-2);
  line-height: var(--line-height-snug);
}

.ysat-spa5-timeline__card--future .ysat-spa5-timeline__card-title {
  color: var(--color-gold-amber);
}

.ysat-spa5-timeline__card-text {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.65);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================================================
   SECTION 4: PILLAR CARDS
   ============================================================ */

.ysat-spa5-pillars {
  padding: 56px 50px;
  background-color: var(--color-pale-green);
}

.ysat-spa5-pillars__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-spa5-pillars__header {
  margin-bottom: 40px;
}

.ysat-spa5-pillars__label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-spa5-pillars__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-4);
}

.ysat-spa5-pillars__title span { color: var(--color-brand-green); }

.ysat-spa5-pillars__subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-mid-gray);
  line-height: var(--line-height-relaxed);
  max-width: 640px;
  margin: 0;
}

.ysat-spa5-pillars__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.ysat-spa5-pillar {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-6);
  border: 1px solid var(--color-light-gray);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.ysat-spa5-pillar:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1);
}

.ysat-spa5-pillar--governance    { border-top-color: var(--color-light-gray); }
.ysat-spa5-pillar--systems       { border-top-color: var(--color-light-gray); }
.ysat-spa5-pillar--partnerships  { border-top-color: var(--color-light-gray); }
.ysat-spa5-pillar--people        { border-top-color: var(--color-light-gray); }

.ysat-spa5-pillar__icon-wrap {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  margin-bottom: var(--space-5);
}

.ysat-spa5-pillar--governance    .ysat-spa5-pillar__icon-wrap { background-color: rgba(16,35,94,0.08); color: #10235e; }
.ysat-spa5-pillar--systems       .ysat-spa5-pillar__icon-wrap { background-color: rgba(255,195,44,0.12); color: #b8860b; }
.ysat-spa5-pillar--partnerships  .ysat-spa5-pillar__icon-wrap { background-color: rgba(27,97,58,0.1); color: var(--color-brand-green); }
.ysat-spa5-pillar--people        .ysat-spa5-pillar__icon-wrap { background-color: rgba(19,65,38,0.1); color: var(--color-forest-green); }

.ysat-spa5-pillar__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-3);
}

.ysat-spa5-pillar__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-light-gray);
}

.ysat-spa5-pillar__initiatives {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ysat-spa5-pillar__initiatives li {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}

.ysat-spa5-pillar__initiatives li i { font-size: 0.8rem; flex-shrink: 0; margin-top: 2px; }

.ysat-spa5-pillar--governance    .ysat-spa5-pillar__initiatives li i { color: #10235e; }
.ysat-spa5-pillar--systems       .ysat-spa5-pillar__initiatives li i { color: #b8860b; }
.ysat-spa5-pillar--partnerships  .ysat-spa5-pillar__initiatives li i { color: var(--color-brand-green); }
.ysat-spa5-pillar--people        .ysat-spa5-pillar__initiatives li i { color: var(--color-forest-green); }


/* ============================================================
   SECTION 5: IMPACT NUMBERS
   ============================================================ */

.ysat-spa5-impact {
  padding: 56px 50px;
  background-color: var(--color-near-black);
  position: relative;
  overflow: hidden;
}

.ysat-spa5-impact::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 40%, rgba(27, 77, 46, 0.3) 0%, transparent 55%);
  pointer-events: none;
}

.ysat-spa5-impact__inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.ysat-spa5-impact__header {
  margin-bottom: 40px;
}

.ysat-spa5-impact__section-label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 12px;
}

.ysat-spa5-impact__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-spa5-impact__title span { color: var(--color-gold-amber); }

.ysat-spa5-impact__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-8);
}

.ysat-spa5-impact__stat {
  padding: var(--space-8) var(--space-6);
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  transition: background-color var(--transition-base);
}

.ysat-spa5-impact__stat:nth-child(3n)     { border-right: none; }
.ysat-spa5-impact__stat:nth-child(4),
.ysat-spa5-impact__stat:nth-child(5),
.ysat-spa5-impact__stat:nth-child(6)      { border-bottom: none; }

.ysat-spa5-impact__stat:hover { background-color: rgba(255, 255, 255, 0.04); }

.ysat-spa5-impact__number {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-2);
}

.ysat-spa5-impact__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.5);
  line-height: var(--line-height-snug);
  margin: 0;
}




/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1100px) {
  .ysat-spa5-pillars__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .ysat-spa5-hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    min-height: unset;
  }
  .ysat-spa5-hero__img {
    display: none;
  }
  .ysat-spa5-hero__inner {
    grid-column: 1;
    grid-row: 1;
    padding: 32px 24px 48px;
    justify-content: flex-start;
  }
  .ysat-spa5-hero__stats {
    grid-template-columns: repeat(2, 1fr);
  }
  .ysat-spa5-hero__stat:nth-child(2) { border-right: none; }
  .ysat-spa5-hero__stat:nth-child(1),
  .ysat-spa5-hero__stat:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.1); }

  .ysat-spa5-narrative__inner {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }
  .ysat-spa5-narrative__quote { position: static; }

  .ysat-spa5-timeline__line { left: 24px; transform: none; }
  .ysat-spa5-timeline__item { grid-template-columns: 48px 1fr; gap: 0 20px; }
  .ysat-spa5-timeline__item--left .ysat-spa5-timeline__card,
  .ysat-spa5-timeline__item--right .ysat-spa5-timeline__card { grid-column: 2; grid-row: 1; text-align: left; }
  .ysat-spa5-timeline__item--left .ysat-spa5-timeline__node,
  .ysat-spa5-timeline__item--right .ysat-spa5-timeline__node { grid-column: 1; grid-row: 1; }

  .ysat-spa5-impact__grid { grid-template-columns: repeat(2, 1fr); }
  .ysat-spa5-impact__stat:nth-child(3n) { border-right: 1px solid rgba(255,255,255,0.08); }
  .ysat-spa5-impact__stat:nth-child(2n) { border-right: none; }
  .ysat-spa5-impact__stat:nth-child(4),
  .ysat-spa5-impact__stat:nth-child(5),
  .ysat-spa5-impact__stat:nth-child(6) { border-bottom: 1px solid rgba(255,255,255,0.08); }
  .ysat-spa5-impact__stat:nth-child(5),
  .ysat-spa5-impact__stat:nth-child(6) { border-bottom: none; }
}

@media (max-width: 768px) {
  .ysat-spa5-hero__inner,
  .ysat-spa5-narrative,
  .ysat-spa5-timeline,
  .ysat-spa5-pillars,
  .ysat-spa5-impact { padding-left: 24px; padding-right: 24px; }
  .ysat-spa5-pillars__grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .ysat-spa5-hero__inner,
  .ysat-spa5-narrative,
  .ysat-spa5-timeline,
  .ysat-spa5-pillars,
  .ysat-spa5-impact { padding-left: 16px; padding-right: 16px; }

  .ysat-spa5-hero__stats { grid-template-columns: 1fr; }
  .ysat-spa5-hero__stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .ysat-spa5-hero__stat:last-child { border-bottom: none; }

  .ysat-spa5-impact__grid { grid-template-columns: 1fr; }
  .ysat-spa5-impact__stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); }
  .ysat-spa5-impact__stat:last-child { border-bottom: none; }
}


/* ============================================================
   CURRENT PROJECTS PAGE
   ysat-current-projects.css
   Place in: assets/css/ysat-current-projects.css
   ============================================================ */


/* ============================================================
   HERO
   ============================================================ */

.ysat-cp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 60vh;
  background-color: var(--color-near-black);
  position: relative;
}

.ysat-cp-hero__img {
  grid-column: 2;
  grid-row: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}

.ysat-cp-hero__inner {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 3;
  padding: 56px 50px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.ysat-cp-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-cp-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-cp-hero__breadcrumb a:hover { color: var(--color-gold-amber); }

.ysat-cp-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.2);
}

.ysat-cp-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.6);
}

.ysat-cp-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-4);
}

.ysat-cp-hero__title span { color: var(--color-gold-amber); }

.ysat-cp-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.6);
  line-height: var(--line-height-relaxed);
  max-width: 700px;
  margin: 0;
}


/* ============================================================
   BODY — SIDEBAR + CONTENT LAYOUT
   ============================================================ */

.ysat-cp-body {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-cp-body__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 48px;
  align-items: start;
}


/* ============================================================
   SIDEBAR
   ============================================================ */

.ysat-cp-sidebar {
  position: sticky;
  top: 110px;
}

.ysat-cp-sidebar__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-light-gray);
}

.ysat-cp-sidebar__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.ysat-cp-filter-btn {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.ysat-cp-filter-btn:hover {
  background-color: var(--color-pale-green);
  color: var(--color-brand-green);
}

.ysat-cp-filter-btn.active {
  background-color: var(--color-brand-green);
  color: var(--color-white);
  font-weight: var(--font-weight-bold);
}

.ysat-cp-filter-btn__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background-color: currentColor;
  flex-shrink: 0;
  opacity: 0.5;
  transition: opacity var(--transition-fast);
}

.ysat-cp-filter-btn.active .ysat-cp-filter-btn__dot,
.ysat-cp-filter-btn:hover .ysat-cp-filter-btn__dot {
  opacity: 1;
}

.ysat-cp-filter-btn--active-only {
  margin-top: var(--space-4);
  border-top: 1px solid var(--color-light-gray);
  padding-top: var(--space-4);
}


/* ============================================================
   CONTENT AREA
   ============================================================ */

.ysat-cp-content {
  min-width: 0;
}

.ysat-cp-spa-group {
  margin-bottom: 56px;
}

.ysat-cp-spa-group:last-child { margin-bottom: 0; }

.ysat-cp-spa-group__header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--color-light-gray);
}

.ysat-cp-spa-group__tag {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  flex-shrink: 0;
}

.ysat-cp-spa-group__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-cp-spa-group__count {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  margin-left: auto;
  flex-shrink: 0;
}

.ysat-cp-spa-group.is-hidden { display: none; }


/* ============================================================
   PROJECT GRID
   ============================================================ */

.ysat-cp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}


/* ============================================================
   PROJECT CARD
   ============================================================ */

.ysat-cp-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  text-decoration: none;
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}

.ysat-cp-card:hover {
  border-color: var(--color-soft-green);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transform: translateY(-3px);
}

.ysat-cp-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.ysat-cp-card__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background-color: var(--color-pale-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-brand-green);
  flex-shrink: 0;
  transition: background-color var(--transition-base), color var(--transition-base);
}

.ysat-cp-card:hover .ysat-cp-card__icon {
  background-color: var(--color-brand-green);
  color: var(--color-white);
}

.ysat-cp-card__status {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}

.ysat-cp-card__status--active {
  background-color: rgba(127, 203, 155, 0.15);
  color: var(--color-brand-green);
  border: 1px solid rgba(127, 203, 155, 0.3);
}

.ysat-cp-card__status--completed {
  background-color: var(--color-light-gray);
  color: var(--color-mid-gray);
  border: 1px solid var(--color-light-gray);
}

.ysat-cp-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  margin: 0;
}

.ysat-cp-card__desc {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  flex: 1;
}

.ysat-cp-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-light-gray);
  margin-top: auto;
}

.ysat-cp-card__spa {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-mid-gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ysat-cp-card__arrow {
  font-size: var(--font-size-sm);
  color: var(--color-mid-gray);
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.ysat-cp-card:hover .ysat-cp-card__arrow {
  color: var(--color-brand-green);
  transform: translateX(4px);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .ysat-cp-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  /* Hero */
  .ysat-cp-hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    min-height: unset;
    height: auto;
  }
  .ysat-cp-hero__img { display: none; }
  .ysat-cp-hero__inner {
    grid-column: 1;
    grid-row: 1;
    padding: 32px 24px 40px;
    justify-content: flex-start;
    height: auto;
  }

  /* Sidebar */
  .ysat-cp-body__inner { grid-template-columns: 1fr; }

  .ysat-cp-sidebar {
    position: static;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
  }

  .ysat-cp-sidebar__label {
    width: 100%;
    border-bottom: none;
    margin-bottom: var(--space-2);
    padding-bottom: 0;
  }

  .ysat-cp-sidebar__nav {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .ysat-cp-filter-btn {
    width: auto;
    padding: 7px 14px;
    border: 1px solid var(--color-light-gray);
    border-radius: var(--radius-full);
  }

  .ysat-cp-filter-btn.active { border-color: var(--color-brand-green); }

  .ysat-cp-filter-btn--active-only {
    margin-top: 0;
    border-top: none;
    padding-top: 7px;
  }
}

@media (max-width: 640px) {
  .ysat-cp-body { padding: 32px 24px; }
  .ysat-cp-grid { grid-template-columns: 1fr; }
  .ysat-cp-spa-group__header { flex-wrap: wrap; }
  .ysat-cp-spa-group__count { margin-left: 0; }
}

@media (max-width: 480px) {
  .ysat-cp-body { padding: 28px 16px; }
}



/* ============================================================
   OUR TEAM PAGE
   ysat-our-team.css
   Place in: assets/css/ysat-our-team.css
   ============================================================ */


/* ============================================================
   HERO
   ============================================================ */

/* ============================================================
   HERO IMAGE SECTION
   ============================================================ */

.ysat-team-hero-img {
  display: block;
  width: 100%;
  height: 75vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}


/* ============================================================
   HERO TEXT SECTION
   ============================================================ */

.ysat-team-hero-text {
  background-color: var(--color-forest-green);
  padding: 56px 50px;
}

.ysat-team-hero-text__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-team-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.ysat-team-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-team-hero__breadcrumb a:hover { color: var(--color-gold-amber); }

.ysat-team-hero__breadcrumb i {
  font-size: 0.55rem;
  color: rgba(255, 255, 255, 0.35);
}

.ysat-team-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-white);
}

.ysat-team-hero__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-4);
}

.ysat-team-hero__title span { color: var(--color-gold-amber); }

.ysat-team-hero__lead {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--line-height-relaxed);
  max-width: 640px;
  margin: 0;
}


/* ============================================================
   BODY LAYOUT
   ============================================================ */

.ysat-team-body {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-team-body__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 40px;
  align-items: start;
}


/* ============================================================
   LEFT: STICKY MEMBER CARD
   ============================================================ */

.ysat-team-card {
  position: sticky;
  top: 110px;
  background-color: var(--color-near-black);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ysat-team-card__photo-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background-color: var(--color-forest-green);
}

.ysat-team-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: opacity 0.18s ease;
}

.ysat-team-card__body {
  padding: var(--space-5);
}

.ysat-team-card__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-1);
  transition: opacity 0.18s ease;
}

.ysat-team-card__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-3);
  transition: opacity 0.18s ease;
}

.ysat-team-card__bio {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.6);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-4);
  transition: opacity 0.18s ease;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ysat-team-card__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 9px 18px;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background-color var(--transition-fast), gap var(--transition-fast);
}

.ysat-team-card__btn:hover {
  background-color: var(--color-white);
  gap: var(--space-3);
}

.ysat-team-card__btn i {
  font-size: 0.75rem;
  transition: transform var(--transition-fast);
}

.ysat-team-card__btn:hover i { transform: translateX(3px); }


/* ============================================================
   RIGHT: TEAM GRID
   ============================================================ */

.ysat-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  align-items: start;
}

.ysat-team-group {
  grid-column: 1 / -1;
  padding-bottom: 12px;
  border-bottom: 3px solid var(--color-brand-green);
  margin-top: var(--space-8);
}

.ysat-team-group:first-child { margin-top: 0; }

.ysat-team-group__label {
  font-family: var(--font-primary);
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  font-weight: var(--font-weight-black);
  color: var(--color-brand-green);
  letter-spacing: var(--letter-spacing-tight);
}


/* ============================================================
   TEAM THUMBNAIL
   ============================================================ */

.ysat-team-thumb {
  cursor: pointer;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 2px solid var(--color-light-gray);
  background-color: var(--color-white);
  transition: border-color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
}

.ysat-team-thumb:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  border-color: var(--color-soft-green);
}

.ysat-team-thumb.active {
  border-color: var(--color-brand-green);
  box-shadow: 0 4px 16px rgba(27, 97, 58, 0.15);
}

.ysat-team-thumb__img-wrap {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background-color: var(--color-pale-green);
}

.ysat-team-thumb__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.4s ease;
}

.ysat-team-thumb:hover .ysat-team-thumb__img-wrap img { transform: scale(1.05); }

.ysat-team-thumb__img-wrap--placeholder {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ysat-team-thumb__img-wrap--placeholder img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  z-index: 1;
}

.ysat-team-thumb__img-wrap--placeholder i {
  font-size: 2rem;
  color: var(--color-soft-green);
  z-index: 0;
}

.ysat-team-thumb__content { display: flex; flex-direction: column; }

.ysat-team-thumb__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  line-height: 1.3;
  margin: var(--space-2) var(--space-2) 2px;
}

.ysat-team-thumb__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-mid-gray);
  line-height: 1.3;
  margin: 0 var(--space-2) var(--space-2);
}

.ysat-team-thumb.active .ysat-team-thumb__name { color: var(--color-brand-green); }

.ysat-team-thumb__btn { display: none; }


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 860px) {
  .ysat-team-hero-img { height: 55vh; }
  .ysat-team-hero-text { padding: 40px 24px; }

  .ysat-team-body__inner { grid-template-columns: 1fr; }
  .ysat-team-card { display: none; }
  .ysat-team-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .ysat-team-hero-img { height: 45vh; }
  .ysat-team-body { padding: 40px 24px; }
  .ysat-team-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}

@media (max-width: 480px) {
  .ysat-team-hero-img { height: 40vh; }
  .ysat-team-body { padding: 32px 16px; }
  .ysat-team-group__label { font-size: 1.3rem; }

  .ysat-team-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .ysat-team-thumb {
    display: grid;
    grid-template-columns: 72px 1fr;
    align-items: center;
  }

  .ysat-team-thumb__img-wrap {
    width: 72px;
    height: 72px;
    border-radius: 0;
    flex-shrink: 0;
  }

  .ysat-team-thumb__name { margin: var(--space-2) var(--space-3) 2px; }
  .ysat-team-thumb__role { margin: 0 var(--space-3) 4px; }
}



/* ============================================================
   YSAT TEAM MEMBER PROFILE PAGE
   ysat-profile.css
   Place in: assets/css/ysat-profile.css
   ============================================================ */


/* ============================================================
   SECTION 1: HERO — full width text
   ============================================================ */

.ysat-profile-hero {
  background-color: var(--color-near-black);
  padding: 56px 50px 72px;
  position: relative;
}

.ysat-profile-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 10% 80%, rgba(27, 77, 46, 0.3) 0%, transparent 55%);
  pointer-events: none;
}

.ysat-profile-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.ysat-profile-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}

.ysat-profile-hero__breadcrumb a {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.4);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-profile-hero__breadcrumb a:hover { color: var(--color-gold-amber); }

.ysat-profile-hero__breadcrumb i {
  font-size: 0.5rem;
  color: rgba(255, 255, 255, 0.2);
}

.ysat-profile-hero__breadcrumb span {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.6);
}

.ysat-profile-hero__tag {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 5px 16px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-5);
}

.ysat-profile-hero__name {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: 1;
  letter-spacing: -0.03em;
  margin: 0 0 var(--space-8);
}

.ysat-profile-hero__name span { color: var(--color-gold-amber); }

.ysat-profile-hero__quote {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.65);
  line-height: var(--line-height-relaxed);
  font-style: italic;
  margin: 0 0 var(--space-8);
  max-width: 760px;
}

.ysat-profile-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.ysat-profile-hero__meta span {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.45);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.ysat-profile-hero__meta i { color: var(--color-gold-amber); }


/* ============================================================
   SECTION 2: BIO + STICKY PORTRAIT
   ============================================================ */

.ysat-profile-body {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-profile-body__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 56px;
  align-items: start;
}

/* BIO LABEL + TITLE */

.ysat-profile-bio__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-8);
}

.ysat-profile-bio__title span { color: var(--color-brand-green); }

/* BIO PARAGRAPHS */
.ysat-profile-bio__text p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-5);
}

.ysat-profile-bio__text p:last-child { margin-bottom: 0; }

/* RECOGNITION CARDS below bio */
.ysat-profile-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-top: var(--space-10);
}

.ysat-profile-card {
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}

.ysat-profile-card__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-near-black);
  margin: 0 0 var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.ysat-profile-card__title i { color: var(--color-brand-green); }

.ysat-profile-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ysat-profile-card__list li {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  padding-left: var(--space-5);
  position: relative;
}

.ysat-profile-card__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background-color: var(--color-brand-green);
}


/* ============================================================
   RIGHT: STICKY PORTRAIT
   ============================================================ */

.ysat-profile-portrait {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-light-gray);
}

.ysat-profile-portrait__img-wrap {
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background-color: var(--color-pale-green);
}

.ysat-profile-portrait__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.ysat-profile-portrait__caption {
  background-color: var(--color-near-black);
  padding: var(--space-4) var(--space-5);
}

.ysat-profile-portrait__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  margin: 0 0 4px;
}

.ysat-profile-portrait__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
}

.ysat-profile-portrait__at-ysat {
  background-color: var(--color-pale-green);
  padding: var(--space-4) var(--space-5);
}

.ysat-profile-portrait__at-ysat ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.ysat-profile-portrait__at-ysat ul li {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  padding-left: var(--space-4);
  position: relative;
  line-height: 1.4;
}

.ysat-profile-portrait__at-ysat ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: var(--radius-full);
  background-color: var(--color-brand-green);
}


/* ============================================================
   SECTION 3: BOTTOM CTA
   ============================================================ */

.ysat-profile-cta {
  background-color: var(--color-near-black);
  padding: 56px 50px;
}

.ysat-profile-cta__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.ysat-profile-cta__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-amber);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin: 0 0 var(--space-2);
}

.ysat-profile-cta__title {
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0;
}

.ysat-profile-cta__right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.ysat-profile-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  padding: 12px 24px;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background-color var(--transition-fast), color var(--transition-fast), gap var(--transition-fast);
}

.ysat-profile-cta__btn:hover { gap: var(--space-3); }

.ysat-profile-cta__btn--primary {
  background-color: var(--color-gold-amber);
  color: var(--color-near-black);
}

.ysat-profile-cta__btn--primary:hover {
  background-color: var(--color-white);
}

.ysat-profile-cta__btn--secondary {
  background-color: transparent;
  color: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.ysat-profile-cta__btn--secondary:hover {
  border-color: rgba(255, 255, 255, 0.5);
  color: var(--color-white);
}


/* Mobile portrait caption — global rules (element only shown on mobile) */
.ysat-profile-mobile-portrait {
  display: none;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-light-gray);
  margin: var(--space-6) 0;
}

.ysat-profile-mobile-portrait img {
  width: 100%;
  height: auto;
  display: block;
}

.ysat-profile-mobile-portrait__caption {
  background-color: var(--color-near-black) !important;
  padding: var(--space-4) var(--space-5);
}

.ysat-profile-mobile-portrait__caption p.ysat-profile-mobile-portrait__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-black);
  color: #ffffff !important;
  margin: 0 0 4px;
}

.ysat-profile-mobile-portrait__caption p.ysat-profile-mobile-portrait__role {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: #ffc32c !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
}

.ysat-profile-mobile-portrait__tenure {
  list-style: none;
  padding: var(--space-4) var(--space-5);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  background-color: var(--color-pale-green);
}

.ysat-profile-mobile-portrait__tenure li {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  padding-left: var(--space-4);
  position: relative;
  line-height: 1.5;
}

.ysat-profile-mobile-portrait__tenure li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: var(--radius-full);
  background-color: var(--color-brand-green);
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 960px) {
  .ysat-profile-body__inner {
    grid-template-columns: 1fr 260px;
    gap: 40px;
  }
}

@media (max-width: 768px) {
  .ysat-profile-hero { padding: 40px 24px 56px; }
  .ysat-profile-body,
  .ysat-profile-cta { padding: 40px 24px; }

  .ysat-profile-body__inner { grid-template-columns: 1fr; }

  /* Hide sticky portrait on mobile — we show the inline one instead */
  .ysat-profile-portrait { display: none; }

  /* Show mobile portrait after first paragraph */
  .ysat-profile-mobile-portrait {
    display: block;
    width: 100%;
  }

  .ysat-profile-cta__inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .ysat-profile-hero { padding: 32px 16px 48px; }
  .ysat-profile-body,
  .ysat-profile-cta { padding: 32px 16px; }

  .ysat-profile-hero__name { font-size: clamp(2.2rem, 10vw, 3rem); }
  .ysat-profile-portrait { max-width: 100%; }
}



/* =============================================================
   YSAT PARTNERS & DONORS
   ysat-partners-and-donors.css
   Place in: assets/css/ysat-partners-and-donors.css
   ============================================================= */

.ysat-partners-and-donors {
  background-color: var(--color-white);
  padding: 56px 50px;
}

.ysat-partners-and-donors__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

/* ── GRID — 4 per row ── */
.ysat-partners-and-donors__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}

/* ── CARD ── */
.ysat-partners-and-donors__card {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  transition: box-shadow var(--transition-base);
}

.ysat-partners-and-donors__card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

/* ── LOGO ── */
.ysat-partners-and-donors__logo-wrap {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.ysat-partners-and-donors__logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* ── CARD BODY — hidden ── */
.ysat-partners-and-donors__card-body {
  display: none;
}

/* ── CTA ── */
.ysat-partners-and-donors__cta {
  background-color: var(--color-forest-green);
  border-radius: var(--radius-md);
  padding: 40px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.ysat-partners-and-donors__cta-text {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.8);
  line-height: var(--line-height-relaxed);
  margin: 0;
  max-width: 640px;
}

.ysat-partners-and-donors__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-near-black);
  background-color: var(--color-gold-amber);
  padding: 12px 28px;
  border-radius: var(--radius-full);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background-color var(--transition-fast), gap var(--transition-fast);
}

.ysat-partners-and-donors__cta-btn:hover {
  background-color: var(--color-white);
  gap: var(--space-3);
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .ysat-partners-and-donors__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .ysat-partners-and-donors { padding: 40px 24px; }
  .ysat-partners-and-donors__grid { grid-template-columns: repeat(2, 1fr); }
  .ysat-partners-and-donors__cta { flex-direction: column; align-items: flex-start; padding: 32px 24px; }
}

@media (max-width: 480px) {
  .ysat-partners-and-donors { padding: 32px 16px; }
}

/* ── HERO — image free, text below on solid green ── */

.ysat-partners-and-donors__hero-img {
  display: block;
  width: 100%;
  height: 75vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.ysat-partners-and-donors__hero-text {
  background-color: var(--color-forest-green);
  padding: 56px 50px;
}

.ysat-partners-and-donors__hero-text-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-partners-and-donors__hero-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: 0;
  flex-wrap: wrap;
}

.ysat-partners-and-donors__hero-breadcrumb li {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.45);
}

.ysat-partners-and-donors__hero-breadcrumb li a {
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-partners-and-donors__hero-breadcrumb li a:hover { color: var(--color-gold-amber); }
.ysat-partners-and-donors__hero-breadcrumb li.active { color: rgba(255, 255, 255, 0.7); }
.ysat-partners-and-donors__hero-breadcrumb .sep { color: rgba(255, 255, 255, 0.2); }

.ysat-partners-and-donors__hero-title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-4);
}

.ysat-partners-and-donors__hero-title span { color: var(--color-gold-amber); }

.ysat-partners-and-donors__hero-sub {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255, 255, 255, 0.75);
  line-height: var(--line-height-relaxed);
  max-width: 680px;
  margin: 0 0 var(--space-8);
}

.ysat-partners-and-donors__hero-stats {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  flex-wrap: wrap;
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.ysat-partners-and-donors__hero-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ysat-partners-and-donors__hero-stat-num {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: var(--font-weight-black);
  color: var(--color-gold-amber);
  line-height: 1;
  letter-spacing: -0.03em;
}

.ysat-partners-and-donors__hero-stat-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: rgba(255, 255, 255, 0.55);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

@media (max-width: 860px) {
  .ysat-partners-and-donors__hero-img { height: 55vh; }
  .ysat-partners-and-donors__hero-text { padding: 40px 24px; }
}

@media (max-width: 480px) {
  .ysat-partners-and-donors__hero-img { height: 40vh; }
  .ysat-partners-and-donors__hero-text { padding: 32px 16px; }
  .ysat-partners-and-donors__hero-stats { gap: var(--space-6); }
}



/* =============================================================
   YSAT CONTACT PAGE
   ysat-contact.css
   Place in: assets/css/ysat-contact.css
   ============================================================= */

/* ── HERO ── */
.ysat-contact-hero-img {
  display: block;
  width: 100%;
  height: 60vh;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.ysat-contact-hero-text {
  background-color: var(--color-forest-green);
  padding: 56px 50px;
}

.ysat-contact-hero-text__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.ysat-contact-hero-text__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: 0;
  flex-wrap: wrap;
}

.ysat-contact-hero-text__breadcrumb li {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: rgba(255,255,255,0.45);
}

.ysat-contact-hero-text__breadcrumb li a {
  color: rgba(255,255,255,0.45);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.ysat-contact-hero-text__breadcrumb li a:hover { color: var(--color-gold-amber); }
.ysat-contact-hero-text__breadcrumb li.active { color: rgba(255,255,255,0.75); }
.ysat-contact-hero-text__breadcrumb .sep { color: rgba(255,255,255,0.2); }

.ysat-contact-hero-text__title {
  font-family: var(--font-primary);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-black);
  color: var(--color-white);
  letter-spacing: var(--letter-spacing-tight);
  line-height: var(--line-height-snug);
  margin: 0 0 var(--space-4);
}

.ysat-contact-hero-text__title span { color: var(--color-gold-amber); }

.ysat-contact-hero-text__sub {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: rgba(255,255,255,0.75);
  line-height: var(--line-height-relaxed);
  max-width: 680px;
  margin: 0;
}

/* ── BODY ── */
.ysat-contact-body {
  padding: 56px 50px;
  background-color: var(--color-white);
}

.ysat-contact-body__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

/* ── OFFICE INFO ── */
.ysat-contact-info {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.ysat-contact-info__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-5);
}

.ysat-contact-info__title span { color: var(--color-brand-green); }

.ysat-contact-info__office {
  margin-bottom: var(--space-5);
}

.ysat-contact-info__office-badge {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background-color: var(--color-brand-green);
  color: var(--color-white);
  margin-bottom: var(--space-2);
}

.ysat-contact-info__office-badge--coord {
  background-color: var(--color-near-black);
  color: var(--color-gold-amber);
}

.ysat-contact-info__office-badge--ss {
  background-color: var(--color-gold-amber);
  color: var(--color-near-black);
}

.ysat-contact-info__office-name {
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  margin: 0 0 var(--space-2);
}

.ysat-contact-info__office-addr {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
}

.ysat-contact-info__office-addr i {
  color: var(--color-brand-green);
  flex-shrink: 0;
  margin-top: 3px;
}

.ysat-contact-info__contact-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-5);
  background-color: var(--color-pale-green);
  border-radius: var(--radius-md);
}

.ysat-contact-info__contact-row a {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark-gray);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  transition: color var(--transition-fast);
}

.ysat-contact-info__contact-row a i { color: var(--color-brand-green); }
.ysat-contact-info__contact-row a:hover { color: var(--color-brand-green); }

/* ── FORM WRAP ── */
.ysat-contact-form-wrap {
  background-color: var(--color-off-white);
  border-radius: var(--radius-lg);
  padding: 40px 40px;
  position: sticky;
  top: 110px;
}

.ysat-contact-form-wrap__title {
  font-family: var(--font-primary);
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  letter-spacing: var(--letter-spacing-tight);
  margin: 0 0 var(--space-2);
}

.ysat-contact-form-wrap__title span { color: var(--color-brand-green); }

.ysat-contact-form-wrap__sub {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-mid-gray);
  line-height: var(--line-height-relaxed);
  margin: 0 0 var(--space-7);
}

/* ── STEPS ── */
.ysat-contact-step__label {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-extrabold);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-brand-green);
  margin-bottom: var(--space-5);
}

/* ── FIELDS ── */
.ysat-contact-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-5);
}

.ysat-contact-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.ysat-contact-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-near-black);
}

.ysat-contact-input {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-near-black);
  background-color: var(--color-white);
  border: 1.5px solid var(--color-light-gray);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  width: 100%;
}

.ysat-contact-input:focus {
  border-color: var(--color-brand-green);
  box-shadow: 0 0 0 3px rgba(0,148,68,0.12);
}

.ysat-contact-input--otp {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-black);
  text-align: center;
  letter-spacing: 0.4em;
}

.ysat-contact-select { cursor: pointer; }

.ysat-contact-textarea {
  resize: vertical;
  min-height: 140px;
}

.ysat-contact-field__error {
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: #e53e3e;
  display: none;
}

.ysat-contact-char-count {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  color: var(--color-mid-gray);
  text-align: right;
}

/* ── VERIFIED BADGE ── */
.ysat-contact-verified-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-green);
  background-color: rgba(0,148,68,0.08);
  border: 1px solid rgba(0,148,68,0.2);
  border-radius: var(--radius-full);
  padding: 4px 14px;
  margin-bottom: var(--space-6);
}

/* ── BUTTONS ── */
.ysat-contact-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  background-color: var(--color-brand-green);
  border: none;
  border-radius: var(--radius-full);
  padding: 13px 28px;
  cursor: pointer;
  width: 100%;
  transition: background-color var(--transition-fast), gap var(--transition-fast);
}

.ysat-contact-btn:hover:not(:disabled) {
  background-color: var(--color-forest-green);
  gap: var(--space-3);
}

.ysat-contact-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.ysat-contact-btn--ghost {
  background-color: transparent;
  color: var(--color-brand-green);
  border: 1.5px solid var(--color-brand-green);
}

.ysat-contact-btn--ghost:hover:not(:disabled) {
  background-color: var(--color-pale-green);
}

.ysat-contact-note {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-mid-gray);
  line-height: var(--line-height-relaxed);
  margin: var(--space-4) 0 0;
}

/* ── SUCCESS / ERROR ── */
.ysat-contact-success,
.ysat-contact-error-msg {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
  padding: var(--space-8) var(--space-6);
}

.ysat-contact-success i {
  font-size: 3rem;
  color: var(--color-brand-green);
}

.ysat-contact-success h3 {
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-black);
  color: var(--color-near-black);
  margin: 0;
}

.ysat-contact-success p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

.ysat-contact-error-msg i {
  font-size: 2.5rem;
  color: #e53e3e;
}

.ysat-contact-error-msg p {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-dark-gray);
  line-height: var(--line-height-relaxed);
  margin: 0;
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .ysat-contact-body__inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .ysat-contact-form-wrap { position: static; }
}

@media (max-width: 768px) {
  .ysat-contact-hero-img { height: 45vh; }
  .ysat-contact-hero-text,
  .ysat-contact-body { padding: 40px 24px; }
  .ysat-contact-field-row { grid-template-columns: 1fr; }
  .ysat-contact-form-wrap { padding: 28px 20px; }
}

@media (max-width: 480px) {
  .ysat-contact-hero-img { height: 35vh; }
  .ysat-contact-hero-text,
  .ysat-contact-body { padding: 32px 16px; }
}

