 :root {
      --green:  #137053;
      --egg:    #FFFFFB;
      --grey:   #F3F3F3;
      --black:  #050505;
      --sans:   'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
      --serif:  'Playfair Display', 'Times New Roman', Georgia, serif;
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: var(--sans);
      background: var(--egg);
      color: var(--black);
      overflow-x: hidden;
      cursor: none;
    }

    /* ─── GRAIN ─────────────────────────────────────────── */
    .grain { position: relative; }
    .grain::before {
      content: '';
      position: absolute;
      inset: 0;
      pointer-events: none;
      z-index: 1;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      opacity: 0.055;
      mix-blend-mode: multiply;
    }
    /* Richer grain on coloured / dark backgrounds */
    .about.grain::before { mix-blend-mode: overlay; opacity: .22; }
    .hero.grain::before  { mix-blend-mode: overlay; opacity: .10; }

    /* ─── CURSOR ─────────────────────────────────────────── */
    #cur-dot {
      position: fixed; width: 8px; height: 8px;
      background: var(--green); border-radius: 50%;
      pointer-events: none; z-index: 9999;
      transform: translate(-50%,-50%);
      transition: transform .1s;
    }
    #cur-ring {
      position: fixed; width: 34px; height: 34px;
      border: 1.5px solid var(--green); border-radius: 50%;
      pointer-events: none; z-index: 9998;
      transform: translate(-50%,-50%);
      transition: transform .15s, width .2s, height .2s, opacity .2s;
      opacity: .55;
    }
    body:hover #cur-dot, body:hover #cur-ring { opacity: 1; }

    /* ─── NAV ─────────────────────────────────────────────── */
    nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 200;
      padding: 28px 56px;
      display: flex; align-items: center; justify-content: space-between;
      transition: background .4s, border-bottom-color .4s;
      border-bottom: 1px solid transparent;
    }
    nav.scrolled {
      background: rgba(255,255,251,.96);
      border-bottom-color: rgba(19,112,83,.15);
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
    }
    .nav-logo {
      display: flex; align-items: center; gap: 11px;
      text-decoration: none; color: var(--black);
    }
    .nav-logo svg { width: 26px; }
    .nav-wordmark {
      font-size: 13px; font-weight: 600;
      letter-spacing: .1em; text-transform: uppercase;
    }
    .nav-links { display: flex; gap: 44px; list-style: none; }
    .nav-links a {
      font-size: 12px; font-weight: 500;
      letter-spacing: .08em; text-transform: uppercase;
      color: var(--egg); text-decoration: none;
      opacity: .75; transition: opacity .2s, color .3s;
    }
    .nav-links a:hover { opacity: 1; }
    nav.scrolled .nav-links a { color: var(--black); opacity: .6; }
    nav.scrolled .nav-links a:hover { opacity: 1; }
    .nav-cta {
      background: var(--green) !important; color: var(--egg) !important;
      opacity: 1 !important; padding: 10px 24px;
      transition: background .2s !important;
    }
    .nav-cta:hover { background: var(--black) !important; }

    /* ─── HERO ───────────────────────────────────────────── */
    .hero {
      min-height: 100svh;
      display: flex; flex-direction: column; justify-content: flex-end;
      padding: 0 56px 88px;
      background: var(--black);
      overflow: hidden;
      position: relative;
    }
    .hero-video {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: cover; z-index: 0;
    }
    .hero-overlay {
      position: absolute; inset: 0; z-index: 1;
      background: linear-gradient(
        to bottom,
        rgba(5,5,5,.15) 0%,
        rgba(5,5,5,.5)  60%,
        rgba(5,5,5,.82) 100%
      );
    }
    .hero > *:not(.hero-video):not(.hero-overlay) { position: relative; z-index: 2; }
    .hero-eyebrow {
      font-size: 10px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--egg); margin-bottom: 40px;
      display: inline-flex; align-items: center; gap: 10px;
      align-self: flex-start;
      border: 1px solid rgba(255,255,251,.18);
      padding: 9px 18px 9px 13px;
      border-radius: 100px;
      background: rgba(255,255,251,.06);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
    }
    .hero-eyebrow::before {
      content: '';
      display: block;
      width: 7px; height: 7px;
      border-radius: 50%;
      background: var(--green);
      flex-shrink: 0;
      animation: eyebrow-pulse 2.5s ease-in-out infinite;
    }
    @keyframes eyebrow-pulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(19,112,83,.7); }
      60%       { box-shadow: 0 0 0 6px rgba(19,112,83,0); }
    }
    .hero-hl {
      font-family: var(--sans);
      font-size: clamp(56px, 7.5vw, 116px);
      font-weight: 600; line-height: .93;
      letter-spacing: -.025em; text-transform: uppercase;
      color: var(--egg);
    }
    .hero-hl em {
      font-family: var(--serif);
      font-style: italic; font-weight: 700;
      text-transform: none; color: var(--green);
      letter-spacing: -.01em;
    }
    .hero-bottom {
      margin-top: 52px;
      display: flex; align-items: flex-end;
      justify-content: space-between; gap: 40px;
    }
    .hero-desc {
      font-family: var(--serif);
      font-style: italic;
      font-size: clamp(16px, 1.4vw, 20px);
      line-height: 1.65;
      color: var(--egg);
      max-width: 560px;
      padding-left: 20px;
      border-left: 2px solid var(--green);
      opacity: .85;
    }
    .hero-actions { display: flex; align-items: center; gap: 28px; flex-shrink: 0; }
    .btn-primary {
      font-family: var(--sans); font-size: 12px; font-weight: 500;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg); background: var(--green);
      padding: 17px 40px; text-decoration: none;
      display: inline-block; transition: background .2s;
    }
    .btn-primary:hover { background: rgba(255,255,251,.15); }
    .btn-ghost {
      font-family: var(--sans); font-size: 12px; font-weight: 500;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg); text-decoration: none;
      opacity: .5; display: flex; align-items: center; gap: 10px;
      transition: opacity .2s;
    }
    .btn-ghost:hover { opacity: 1; }

    /* Scroll hint */
    .hero-scroll {
      position: absolute; right: 56px; top: 50%;
      transform: translateY(-50%) rotate(90deg);
      font-size: 10px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--egg); opacity: .25;
    }

    /* ─── CLIENTS BAND ──────────────────────────────────── */
    .clients-band {
      display: flex; align-items: stretch;
      border-top: 1px solid rgba(5,5,5,.1);
      border-bottom: 1px solid rgba(5,5,5,.1);
      background: var(--egg);
      overflow: hidden;
    }
    .clients-label {
      flex-shrink: 0;
      padding: 0 40px;
      border-right: 1px solid rgba(5,5,5,.1);
      display: flex; align-items: center;
      font-size: 10px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--black); opacity: .35;
      white-space: nowrap;
    }
    .clients-scroll { overflow: hidden; flex: 1; }
    .clients-track {
      display: flex; white-space: nowrap;
      animation: clientscroll 36s linear infinite;
    }
    .clients-track:hover { animation-play-state: paused; }
    .client-item {
      display: inline-flex; align-items: center;
      padding: 0 52px; height: 80px;
      border-right: 1px solid rgba(5,5,5,.07);
      text-decoration: none;
      transition: background .25s;
    }
    .client-item:hover { background: var(--grey); }
    /* ── Logo image (swap text for <img> when you have files) ── */
    .client-item img {
      height: 22px; width: auto; display: block;
      filter: grayscale(1); opacity: .45;
      transition: filter .3s, opacity .3s;
    }
    .client-item:hover img { filter: grayscale(0); opacity: .8; }
    /* Text fallback shown when no <img> is present */
    .client-name {
      font-family: var(--sans);
      font-size: 14px; font-weight: 500;
      letter-spacing: .04em; color: var(--black);
      opacity: .38; transition: opacity .25s;
      user-select: none;
    }
    .client-item:hover .client-name { opacity: .7; }
    @keyframes clientscroll {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }

    /* ─── SECTION SHELL ──────────────────────────────────── */
    .section-wrap { padding: 130px 56px; }
    .section-head {
      display: flex; align-items: baseline;
      justify-content: space-between;
      border-bottom: 1px solid rgba(5,5,5,.1);
      padding-bottom: 28px; margin-bottom: 80px;
    }
    .section-label {
      font-size: 11px; font-weight: 500;
      letter-spacing: .18em; text-transform: uppercase;
      color: var(--green);
    }
    .section-title {
      font-family: var(--sans);
      font-size: clamp(34px, 4vw, 62px);
      font-weight: 600; letter-spacing: -.025em;
      text-transform: uppercase; line-height: 1;
      color: var(--black);
    }
    .section-title em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }

    /* ─── SERVICES ───────────────────────────────────────── */
    .services-grid {
      display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    }
    .svc {
      padding: 52px 0; border-bottom: 1px solid rgba(5,5,5,.1);
      display: grid; grid-template-columns: 72px 1fr;
      gap: 20px; align-items: start;
      padding-right: 52px;
      transition: background .2s;
    }
    .svc:nth-child(even) {
      padding-left: 52px; padding-right: 0;
      border-left: 1px solid rgba(5,5,5,.1);
    }
    .svc:nth-last-child(-n+2) { border-bottom: none; }
    .svc-icon {
      padding-top: 6px;
      display: flex; align-items: flex-start;
    }
    .svc-icon svg { width: 28px; height: 28px; opacity: .3; transition: opacity .3s; flex-shrink: 0; }
    .svc:hover .svc-icon svg { opacity: .75; }
    .svc-name {
      font-size: 26px; font-weight: 600;
      letter-spacing: -.01em; text-transform: uppercase;
      color: var(--black); line-height: 1.1;
      margin-bottom: 14px;
      transition: color .2s;
    }
    .svc:hover .svc-name { color: var(--green); }
    .svc-desc {
      font-size: 14px; font-weight: 400;
      line-height: 1.7; color: var(--black); opacity: .5;
    }

    /* ─── WORK ───────────────────────────────────────────── */
    .work-wrap { padding: 130px 56px 0; }
    .projects-row-a {
      display: grid;
      grid-template-columns: 1.15fr .85fr;
      gap: 12px; margin-bottom: 12px;
    }
    .projects-row-b {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
    }
    .projects-row-c {
      display: grid;
      grid-template-columns: .85fr 1.15fr;
      gap: 12px; margin-top: 12px;
    }
    .proj-card {
      position: relative; overflow: hidden;
      display: block; text-decoration: none;
      background: var(--grey);
    }
    .proj-card.tall  { height: 640px; }
    .proj-card.short { height: 420px; }
    .proj-card img {
      width: 100%; height: 100%;
      object-fit: cover; display: block;
      transform: scale(1.07);
      transition: transform .9s cubic-bezier(.25,.46,.45,.94);
    }
    .proj-card:hover img { transform: scale(1); }
    .proj-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(transparent 30%, rgba(5,5,5,.84) 100%);
      display: flex; flex-direction: column;
      justify-content: flex-end; padding: 36px;
      transition: background .5s;
    }
    .proj-card:hover .proj-overlay {
      background: linear-gradient(transparent 15%, rgba(5,5,5,.9) 100%);
    }
    .proj-tag {
      font-size: 10px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--green);
      opacity: 0; transform: translateY(12px);
      transition: opacity .35s ease, transform .35s ease;
      margin-bottom: 8px;
    }
    .proj-card:hover .proj-tag { opacity: 1; transform: translateY(0); }
    .proj-title-card {
      font-family: var(--sans); font-weight: 600;
      font-size: clamp(22px, 2.4vw, 40px);
      letter-spacing: -.022em; text-transform: uppercase;
      line-height: 1; color: var(--egg);
      transform: translateY(22px);
      transition: transform .5s cubic-bezier(.25,.46,.45,.94);
    }
    .proj-card:hover .proj-title-card { transform: translateY(0); }
    .proj-cta-row {
      display: flex; align-items: center; gap: 14px;
      margin-top: 18px;
      font-size: 11px; font-weight: 500;
      letter-spacing: .14em; text-transform: uppercase;
      color: var(--egg);
      opacity: 0; transform: translateY(10px);
      transition: opacity .4s ease .06s, transform .4s ease .06s;
    }
    .proj-cta-line {
      display: block; flex: 0 0 36px;
      height: 1px; background: var(--egg); opacity: .5;
    }
    .proj-card:hover .proj-cta-row { opacity: 1; transform: translateY(0); }
    .proj-idx {
      position: absolute; top: 28px; left: 28px;
      font-size: 11px; font-weight: 500;
      letter-spacing: .15em; color: var(--egg); opacity: .35;
    }

    /* ─── ABOUT ──────────────────────────────────────────── */
    .about {
      padding: 140px 56px;
      background: var(--green);
      position: relative; overflow: hidden;
    }
    .about > * { position: relative; z-index: 2; }
    .about-eyebrow {
      font-size: 11px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--egg); opacity: .5; margin-bottom: 44px;
    }
    .about-hl {
      font-family: var(--sans);
      font-size: clamp(38px, 5vw, 76px);
      font-weight: 600; line-height: 1.0;
      letter-spacing: -.025em; text-transform: uppercase;
      color: var(--egg); max-width: 900px;
    }
    .about-hl em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none;
    }
    .about-foot {
      margin-top: 90px;
      padding-top: 44px;
      border-top: 1px solid rgba(255,255,251,.2);
      display: flex; align-items: flex-end;
      justify-content: space-between; gap: 40px;
    }
    .stats { display: flex; gap: 72px; }
    .stat-n {
      font-family: var(--sans); font-size: 52px;
      font-weight: 600; letter-spacing: -.03em;
      color: var(--egg); line-height: 1;
    }
    .stat-l {
      font-size: 11px; font-weight: 400;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg); opacity: .45; margin-top: 8px;
    }
    .btn-white {
      font-family: var(--sans); font-size: 12px; font-weight: 500;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--green); background: var(--egg);
      padding: 17px 40px; text-decoration: none;
      display: inline-block; flex-shrink: 0;
      transition: background .2s, color .2s;
    }
    .btn-white:hover { background: var(--black); color: var(--egg); }

    /* ─── ABOUT DETAIL ───────────────────────────────────── */
    .about-detail {
      padding: 120px 56px;
      background: var(--egg);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 88px;
      align-items: center;
    }
    .about-detail-img {
      width: 100%; aspect-ratio: 4/5;
      overflow: hidden; background: var(--grey);
      border: 1px dashed rgba(19,112,83,.25);
      display: flex; flex-direction: column;
      align-items: center; justify-content: center; gap: 12px;
      position: relative;
    }
    .about-detail-img img {
      width: 100%; height: 100%; object-fit: cover; display: block;
    }
    .about-detail-img-placeholder {
      display: flex; flex-direction: column;
      align-items: center; justify-content: center; gap: 12px;
    }
    .about-detail-img-placeholder svg { opacity: .2; }
    .about-detail-img-placeholder span {
      font-size: 10px; font-weight: 500;
      letter-spacing: .15em; text-transform: uppercase;
      color: var(--black); opacity: .3;
    }
    .about-detail-content { display: flex; flex-direction: column; gap: 32px; }
    .about-detail-eyebrow {
      font-size: 11px; font-weight: 500;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--green);
    }
    .about-detail-heading {
      font-family: var(--sans);
      font-size: clamp(32px, 3.5vw, 52px);
      font-weight: 600; letter-spacing: -.025em;
      text-transform: uppercase; line-height: 1.0;
      color: var(--black);
    }
    .about-detail-heading em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }
    .about-detail-body {
      font-size: 16px; line-height: 1.85;
      color: var(--black); opacity: .6;
    }
    .about-detail-body p + p { margin-top: 20px; }
    .about-detail-values {
      display: flex; flex-direction: column; gap: 0;
      border-top: 1px solid rgba(5,5,5,.1);
    }
    .about-value {
      display: flex; align-items: baseline; gap: 20px;
      padding: 18px 0;
      border-bottom: 1px solid rgba(5,5,5,.1);
    }
    .about-value-label {
      font-size: 11px; font-weight: 600;
      letter-spacing: .15em; text-transform: uppercase;
      color: var(--green); flex-shrink: 0; width: 120px;
    }
    .about-value-text {
      font-size: 14px; line-height: 1.6;
      color: var(--black); opacity: .55;
    }
    @media (max-width: 960px) {
      .about-detail { grid-template-columns: 1fr; padding: 80px 28px; gap: 48px; }
       
    }

    /* ─── CONTACT ────────────────────────────────────────── */
    .contact { padding: 140px 56px; background: var(--egg); }
    .contact-inner {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 80px; align-items: start;
    }
    .contact-hl {
      font-family: var(--sans);
      font-size: clamp(46px, 5.5vw, 86px);
      font-weight: 600; letter-spacing: -.025em;
      text-transform: uppercase; line-height: .93;
      color: var(--black);
    }
    .contact-hl em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }
    .contact-desc {
      margin-top: 32px; font-size: 15px;
      line-height: 1.7; color: var(--black); opacity: .5;
    }
    .form { display: flex; flex-direction: column; }
    .field {
      border-bottom: 1px solid rgba(5,5,5,.12);
      padding: 22px 0;
    }
    .field label {
      display: block; font-size: 10px; font-weight: 500;
      letter-spacing: .18em; text-transform: uppercase;
      color: var(--black); opacity: .35; margin-bottom: 10px;
    }
    .field input,
    .field textarea,
    .field select {
      width: 100%; background: none; border: none; outline: none;
      font-family: var(--sans); font-size: 16px;
      font-weight: 400; color: var(--black); resize: none;
    }
    .field select { appearance: none; cursor: none; }
    .field textarea { min-height: 88px; }
    .form-submit {
      margin-top: 44px; align-self: flex-start;
      font-family: var(--sans); font-size: 12px;
      font-weight: 500; letter-spacing: .1em;
      text-transform: uppercase; color: var(--egg);
      background: var(--green); border: none;
      padding: 18px 48px; cursor: none;
      transition: background .2s;
    }
    .form-submit:hover { background: var(--black); }

    /* ─── FOOTER ─────────────────────────────────────────── */
    footer {
      background: var(--black);
      padding: 60px 56px;
      display: flex; align-items: center;
      justify-content: space-between; gap: 32px;
    }
    .foot-logo {
      display: flex; align-items: center;
      gap: 10px; text-decoration: none;
    }
    .foot-logo svg { width: 22px; }
    .foot-wordmark {
      font-size: 13px; font-weight: 600;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg);
    }
    .foot-tag {
      font-family: var(--serif); font-style: italic;
      font-size: 14px; color: var(--egg); opacity: .3;
    }
    .foot-links { display: flex; gap: 32px; list-style: none;margin-bottom:0px; }
    .foot-links a {
      font-size: 11px; font-weight: 400;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg); opacity: .35;
      text-decoration: none; transition: opacity .2s;
    }
    .foot-links a:hover { opacity: 1; color: #ffffff;}
    .foot-copy {
      font-size: 11px; color: var(--egg); opacity: .2;
    }

    /* ─── TESTIMONIALS ───────────────────────────────────── */
    .testimonials { padding: 120px 56px; background: var(--black); }
    .testimonials .section-head { margin-bottom: 72px; }
    .testimonials .section-label { color: var(--egg); opacity: .35; }
    .testimonials .section-title { color: var(--egg); }
    .testimonials .section-title em { color: var(--green); }
    .testi-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 2px;
    }
    .testi-card {
      background: rgba(255,255,251,.04);
      border: 1px solid rgba(255,255,251,.08);
      padding: 52px 44px;
      display: flex; flex-direction: column;
      justify-content: space-between; gap: 40px;
      transition: background .3s;
    }
    .testi-card:hover { background: rgba(255,255,251,.07); }
    .testi-mark {
      font-family: var(--serif); font-size: 64px;
      line-height: .6; color: var(--green); opacity: .5;
    }
    .testi-quote {
      font-family: var(--serif); font-style: italic;
      font-size: clamp(17px, 1.5vw, 22px);
      line-height: 1.55; color: var(--egg); opacity: .85;
      flex: 1;
    }
    .testi-footer { border-top: 1px solid rgba(255,255,251,.1); padding-top: 28px; }
    .testi-name {
      font-size: 13px; font-weight: 600;
      letter-spacing: .05em; color: var(--egg);
    }
    .testi-role {
      font-size: 11px; font-weight: 400;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--egg); opacity: .3; margin-top: 5px;
    }

    /* ─── WORD MAGNIFY ───────────────────────────────────── */
    .hl-word {
      display: inline-block;
      transition: transform .38s cubic-bezier(.25,.46,.45,.94), color .25s;
      will-change: transform;
      cursor: default;
    }
    .hero-hl .hl-word:hover,
    .section-title .hl-word:hover,
    .contact-hl .hl-word:hover {
      transform: scale(1.1) translateY(-4px);
      color: var(--green);
    }
    .about-hl .hl-word:hover { transform: scale(1.1) translateY(-4px); }
    .hero-hl em .hl-word,
    .section-title em .hl-word,
    .contact-hl em .hl-word { color: var(--green); }

    /* ─── ANIMATIONS ─────────────────────────────────────── */
    .reveal {
      opacity: 0; transform: translateY(44px);
      transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1);
    }
    .reveal-left {
      opacity: 0; transform: translateX(-56px);
      transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1);
    }
    .reveal-right {
      opacity: 0; transform: translateX(56px);
      transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1);
    }
    .reveal-scale {
      opacity: 0; transform: scale(.93) translateY(24px);
      transition: opacity 1.1s cubic-bezier(.16,1,.3,1), transform 1.1s cubic-bezier(.16,1,.3,1);
    }
    .reveal-clip {
      clip-path: inset(0 0 100% 0);
      transition: clip-path 1.2s cubic-bezier(.16,1,.3,1);
    }
    .reveal.in, .reveal-left.in, .reveal-right.in, .reveal-scale.in {
      opacity: 1; transform: none;
    }
    .reveal-clip.in { clip-path: inset(0 0 0% 0); }
    .d1 { transition-delay: .1s; }
    .d2 { transition-delay: .22s; }
    .d3 { transition-delay: .34s; }
    .d4 { transition-delay: .46s; }

    /* ─── PAGE TRANSITION ────────────────────────────────── */
    #page-transition {
      position: fixed; inset: 0; z-index: 10000;
      background: var(--green);
      transform: translateY(0);
      transition: transform .8s cubic-bezier(.76,0,.24,1);
      pointer-events: all;
    }
    #page-transition.is-revealed { transform: translateY(-100%); pointer-events: none; }

    /* ─── SCROLL PROGRESS ────────────────────────────────── */
    #scroll-progress {
      position: fixed; top: 0; left: 0; right: 0; height: 2px;
      z-index: 9000; pointer-events: none; background: transparent;
    }
    #scroll-progress-fill {
      height: 100%; width: 0%; background: var(--green);
      transition: width .08s linear;
    }

    /* ─── IMAGE CURSOR ───────────────────────────────────── */
    #img-cursor {
      position: fixed; width: 130px; height: 130px; border-radius: 50%;
      overflow: hidden; pointer-events: none; z-index: 9996;
      transform: translate(-50%,-50%) scale(0);
      transition: transform .45s cubic-bezier(.16,1,.3,1);
      will-change: left, top, transform;
      border: 2px solid rgba(255,255,251,.25);
      box-shadow: 0 8px 40px rgba(5,5,5,.35);
    }
    #img-cursor.active { transform: translate(-50%,-50%) scale(1); }
    #img-cursor img { width: 100%; height: 100%; object-fit: cover; display: block; }
    #img-cursor-label {
      position: absolute; inset: 0;
      display: flex; align-items: center; justify-content: center;
      background: rgba(5,5,5,.45);
      font-size: 9px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
      color: var(--egg);
    }

    /* ─── GRAIN ANIMATION ────────────────────────────────── */
    @keyframes grain-move {
      0%  { transform: translate(0,0); }
      10% { transform: translate(-2%,1%); } 20% { transform: translate(2%,-2%); }
      30% { transform: translate(-1%,2%); } 40% { transform: translate(1%,-1%); }
      50% { transform: translate(-2%,2%); } 60% { transform: translate(2%,1%); }
      70% { transform: translate(-1%,-2%); } 80% { transform: translate(1%,2%); }
      90% { transform: translate(-2%,-1%); } 100% { transform: translate(0,0); }
    }
    .about.grain::before { inset: -8%; animation: grain-move 7s steps(1) infinite; }
    .hero.grain::before  { inset: -8%; animation: grain-move 9s steps(1) infinite; }

    /* ─── ACTIVE NAV ─────────────────────────────────────── */
    .nav-links a.active { opacity: 1; }
    nav.scrolled .nav-links a.active { opacity: 1; color: var(--green); }


    /* ─── RESPONSIVE ─────────────────────────────────────── */
    @media (max-width: 960px) {
      nav { padding: 20px 28px; }
      .nav-links { display: none; } 
      .hero-hl { font-size: clamp(44px, 11vw, 80px); }
      .hero-bottom { flex-direction: column; align-items: flex-start; gap: 28px; }
      .hero-scroll { display: none; }
      .section-wrap { padding: 80px 28px; }
      .section-head { flex-direction: column; gap: 12px; }
      .services-grid { grid-template-columns: 1fr; }
      .svc:nth-child(even) { padding-left: 0; border-left: none; }
      .svc { padding-right: 0; }
      .work-wrap { padding: 80px 28px 0; }
      .projects-row-a, .projects-row-b, .projects-row-c { grid-template-columns: 1fr; }
      .proj-card.tall, .proj-card.short { height: 72vw; }
      .about { padding: 80px 28px; }
      .about-foot { flex-direction: column; align-items: flex-start; gap: 32px; }
      .stats { gap: 40px; }
      .contact { padding: 80px 28px; }
      .contact-inner { grid-template-columns: 1fr; gap: 40px; }
      footer { padding: 40px 28px; flex-wrap: wrap; gap: 24px; }
      .foot-tag { display: none; }
      .testimonials { padding: 80px 28px; }
      .testi-grid { grid-template-columns: 1fr; gap: 2px; }
      .hero { padding: 0 0px 0px; }
		.heroWrapper {padding-left: 15px; padding-right: 15px;padding-bottom:60px}
    }

/* project details page css */
 :root {
      --green: #137053; --egg: #FFFFFB; --grey: #F3F3F3; --black: #050505;
      --sans: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
      --serif: 'Playfair Display', 'Times New Roman', Georgia, serif;
    }
    html { scroll-behavior: smooth; }
    body { font-family: var(--sans); background: var(--egg); color: var(--black); overflow-x: hidden; cursor: none; }

    #cur-dot { position: fixed; width: 8px; height: 8px; background: var(--green); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); transition: transform .1s; }
    #cur-ring { position: fixed; width: 34px; height: 34px; border: 1.5px solid var(--green); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: width .2s, height .2s, opacity .2s; opacity: .55; }

    nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; padding: 28px 56px; display: flex; align-items: center; justify-content: space-between; transition: background .4s, border-bottom-color .4s; border-bottom: 1px solid transparent; }
    nav.scrolled { background: rgba(255,255,251,.96); border-bottom-color: rgba(19,112,83,.15); backdrop-filter: blur(8px); }
    .nav-logo { display: flex; align-items: center; gap: 11px; text-decoration: none; color: var(--black); }
    .nav-logo svg { width: 26px; }
    .nav-wordmark { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; }
    .nav-back { display: flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--black); text-decoration: none; opacity: .5; transition: opacity .2s; }
    .nav-back:hover { opacity: 1; }
    .nav-back svg { width: 16px; }

    .proj-hero { height: 100svh; position: relative; overflow: hidden; }
    .proj-hero > img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .proj-hero-over { position: absolute; inset: 0; background: linear-gradient(transparent 30%, rgba(5,5,5,.8) 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 56px; }
    .proj-hero-cat { font-size: 11px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--green); margin-bottom: 16px; display: flex; align-items: center; gap: 12px; }
    .proj-hero-cat::before { content: ''; display: block; width: 28px; height: 1px; background: var(--green); }
    .proj-hero-title { font-family: var(--sans); font-size: clamp(52px, 8.5vw, 120px); font-weight: 600; letter-spacing: -.03em; text-transform: uppercase; line-height: .9; color: var(--egg); }
    .proj-hero-num { position: absolute; top: 100px; right: 56px; font-size: 11px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--egg); opacity: .3; }

    .proj-meta { display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid rgba(5,5,5,.1); }
    .meta-cell { padding: 40px 56px; border-right: 1px solid rgba(5,5,5,.1); }
    .meta-cell:last-child { border-right: none; }
    .meta-lbl { font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: var(--black); opacity: .3; margin-bottom: 10px; }
    .meta-val { font-size: 15px; font-weight: 500; color: var(--black); line-height: 1.4; }

    .proj-body { padding: 100px 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 88px; align-items: start; }
    .proj-stmt { font-family: var(--serif); font-style: italic; font-size: clamp(28px, 3vw, 48px); font-weight: 700; line-height: 1.15; color: var(--black); }
    .proj-copy { font-size: 16px; line-height: 1.8; color: var(--black); opacity: .6; }
    .proj-copy p + p { margin-top: 22px; }

    .proj-gallery { padding: 0 56px 100px; }
    .gal-main { width: 100%; height: 95vh; overflow: hidden; margin-bottom: 12px; }
    .gal-main img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .gal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
    .gal-slot {/* height: 300px; */ overflow: hidden; }
    .gal-slot img { width: 100%; height: 100%; object-fit: contain; display: block; background-color: #137053}
    /* ── Add more images: drop an <img> inside any .gal-slot below ── */
    .gal-slot-empty { height: 300px; background: var(--grey); border: 1px dashed rgba(19,112,83,.25); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; }
    .gal-slot-empty span { font-size: 10px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--black); opacity: .3; }
    .gal-slot-empty svg { opacity: .2; }

    .next-proj { display: block; text-decoration: none; background: var(--green); padding: 88px 56px; position: relative; overflow: hidden; transition: background .35s; }
    .next-proj:hover { background: var(--black); }
    .next-lbl { font-size: 11px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--egg); opacity: .45; margin-bottom: 18px; }
    .next-title { font-family: var(--sans); font-size: clamp(36px, 5.5vw, 88px); font-weight: 600; letter-spacing: -.025em; text-transform: uppercase; line-height: .9; color: var(--egg); }
    .next-arrow { position: absolute; right: 56px; top: 50%; transform: translateY(-50%); font-size: 52px; color: var(--egg); opacity: .3; transition: opacity .3s, right .3s; }
    .next-proj:hover .next-arrow { opacity: .8; right: 44px; }

    footer { background: var(--black); padding: 56px; display: flex; align-items: center; justify-content: space-between; gap: 32px; }
    .foot-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
    .foot-logo svg { width: 22px; }
    .foot-wordmark { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--egg); }
    .foot-copy { font-size: 11px; color: var(--egg); opacity: .2; }

    .grain { position: relative; }
    .grain::before { content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); opacity: .055; mix-blend-mode: multiply; }

    .reveal { opacity: 0; transform: translateY(28px); transition: opacity .85s ease, transform .85s ease; }
    .reveal.in { opacity: 1; transform: translateY(0); }
    .d1 { transition-delay: .12s; } .d2 { transition-delay: .24s; }

    @media (max-width: 900px) {
      nav { padding: 20px 24px; }
      .proj-hero-over { padding: 28px; }
      .proj-hero-num { display: none; }
      .proj-meta { grid-template-columns: 1fr 1fr; }
      .meta-cell { padding: 24px 28px; }
      .proj-body { padding: 60px 24px; grid-template-columns: 1fr; gap: 40px; }
      .proj-gallery { padding: 0 24px 60px; }
      .gal-main { height: 50vh; }
      .gal-grid { grid-template-columns: 1fr 1fr; }
      .next-proj { padding: 56px 24px; }
      .next-arrow { display: none; }
      footer { padding: 40px 24px; flex-wrap: wrap; }
    }

    #page-transition { position:fixed; inset:0; z-index:10000; background:var(--green); transform:translateY(0); transition:transform .8s cubic-bezier(.76,0,.24,1); pointer-events:all; }
    #page-transition.is-revealed { transform:translateY(-100%); pointer-events:none; }
    #scroll-progress { position:fixed; top:0; left:0; right:0; height:2px; z-index:9000; }
    #scroll-progress-fill { height:100%; background:var(--green); width:0%; transition:width .1s linear; }

/* =========================
   IMAGE POPUP
========================= */
.proj-gallery{
    padding:100px 40px;
}

.gal-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}

/* =========================
   IMAGE CARD
========================= */

.gal-slot{
    position:relative;
    overflow:hidden;
    border-radius:24px;
    cursor:pointer;
    aspect-ratio:4/5;
    background:#181818;
}

.gal-slot img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;

    transition:
        transform .8s cubic-bezier(.16,1,.3,1),
        filter .5s ease;
}

/* Hover */

.gal-slot:hover img{
    transform:scale(1.08);
    filter:brightness(.9);
}

/* =========================
   POPUP
========================= */

.img-popup{
    position:fixed;
    inset:0;
    width:100%;
    height:100%;

    background:rgba(0,0,0,.82);
    backdrop-filter:blur(14px);

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px;

    opacity:0;
    visibility:hidden;

    transition:
        opacity .45s ease,
        visibility .45s ease;

    z-index:99999;
}

/* Active */

.img-popup.active{
    opacity:1;
    visibility:visible;
}

/* Wrap */

.popup-wrap{
    position:relative;
    max-width:1200px;
    width:100%;

    transform:scale(.84) translateY(40px);
    opacity:0;

    transition:
        transform .65s cubic-bezier(.16,1,.3,1),
        opacity .65s ease;
}

.img-popup.active .popup-wrap{
    transform:scale(1) translateY(0);
    opacity:1;
}

/* Popup Image */

.popup-img{
    width:100%;
    max-height:88vh;
    object-fit:contain;

    border-radius:28px;

    box-shadow:
        0 20px 80px rgba(0,0,0,.45);

    display:block;
}

/* Close */

.popup-close{
    position:absolute;
    top:60px;
    right:180px;

    color:#fff;
    font-size:48px;
    line-height:1;

    cursor:pointer;

    transition:transform .35s ease;

    z-index:5;
}

.popup-close:hover{
    transform:rotate(90deg) scale(1.08);
}

/* =========================
   MOBILE
========================= */

@media(max-width:991px){

    .gal-grid{
        grid-template-columns:1fr 1fr;
    }

}

@media(max-width:767px){

    .proj-gallery{
        padding:60px 20px;
    }

    .gal-grid{
        grid-template-columns:1fr;
    }

    .img-popup{
        padding:20px;
    }

    .popup-img{
        border-radius:18px;
    }

    .popup-close{
        top:18px;
        right:20px;
        font-size:34px;
    }

}


/* about us page css code */

    /* ─── HERO ───────────────────────────────────────────── */
    .about-hero {
      min-height: 100svh; background: var(--black);
      display: flex; flex-direction: column; justify-content: flex-end;
      padding: 0 56px 88px; position: relative; overflow: hidden;
    }
    .about-hero-bg {
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 80% 60% at 70% 40%, rgba(19,112,83,.18) 0%, transparent 70%),
        radial-gradient(ellipse 50% 50% at 20% 80%, rgba(19,112,83,.1) 0%, transparent 60%);
    }
    .about-hero > *:not(.about-hero-bg) { position: relative; z-index: 2; }
    .about-hero-eyebrow {
      font-size: 10px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase;
      color: var(--egg); margin-bottom: 40px;
      display: inline-flex; align-items: center; gap: 10px; align-self: flex-start;
      border: 1px solid rgba(255,255,251,.18); padding: 9px 18px 9px 13px;
      border-radius: 100px; background: rgba(255,255,251,.06); backdrop-filter: blur(12px);
    }
    .about-hero-eyebrow::before {
      content: ''; display: block; width: 7px; height: 7px; border-radius: 50%;
      background: var(--green); flex-shrink: 0; animation: pulse 2.5s ease-in-out infinite;
    }
    @keyframes pulse {
      0%,100% { box-shadow: 0 0 0 0 rgba(19,112,83,.7); }
      60%      { box-shadow: 0 0 0 6px rgba(19,112,83,0); }
    }
    .about-hero-hl {
      font-family: var(--sans); font-size: clamp(56px, 8vw, 128px);
      font-weight: 600; line-height: .9; letter-spacing: -.03em;
      text-transform: uppercase; color: var(--egg);
    }
    .about-hero-hl em {
      font-family: var(--serif); font-style: italic; font-weight: 700;
      text-transform: none; color: var(--green); letter-spacing: -.01em;
    }
    .about-hero-foot {
      margin-top: 56px; padding-top: 40px;
      border-top: 1px solid rgba(255,255,251,.12);
      display: flex; align-items: flex-end; justify-content: space-between; gap: 40px;
    }
    .about-hero-desc {
      font-family: var(--serif); font-style: italic;
      font-size: clamp(16px, 1.4vw, 20px); line-height: 1.65;
      color: var(--egg); opacity: .75; max-width: 520px;
      padding-left: 20px; border-left: 2px solid var(--green);
    }
    .about-hero-scroll {
      font-size: 10px; font-weight: 500; letter-spacing: .2em;
      text-transform: uppercase; color: var(--egg); opacity: .25;
      flex-shrink: 0;
    }

    /* ─── MANIFESTO ──────────────────────────────────────── */
    .manifesto {
      padding: 130px 56px; display: grid;
      grid-template-columns: 1fr 1fr; gap: 88px; align-items: start;
    }
    .manifesto-quote {
      font-family: var(--serif); font-style: italic;
      font-size: clamp(32px, 3.5vw, 52px); font-weight: 700;
      line-height: 1.1; color: var(--black);
    }
    .manifesto-quote em { color: var(--green); font-style: normal; }
    .manifesto-body { padding-top: 8px; }
    .manifesto-label {
      font-size: 10px; font-weight: 500; letter-spacing: .2em;
      text-transform: uppercase; color: var(--green); margin-bottom: 28px;
      display: flex; align-items: center; gap: 12px;
    }
    .manifesto-label::before { content: ''; display: block; width: 28px; height: 1px; background: var(--green); }
    .manifesto-copy { font-size: 16px; line-height: 1.85; color: var(--black); opacity: .6; }
    .manifesto-copy p + p { margin-top: 22px; }

    /* ─── VALUES TICKER ──────────────────────────────────── */
    .values-band {
      border-top: 1px solid rgba(5,5,5,.1); border-bottom: 1px solid rgba(5,5,5,.1);
      background: var(--green); overflow: hidden; padding: 0;
      display: flex; align-items: center;
    }
    .values-track {
      display: flex; white-space: nowrap;
      animation: valscroll 28s linear infinite;
      padding: 22px 0;
    }
    .values-track:hover { animation-play-state: paused; }
    @keyframes valscroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
    .value-item {
      display: flex; align-items: center; gap: 32px;
      padding: 0 40px;
    }
    .value-item span {
      font-size: 11px; font-weight: 600; letter-spacing: .25em;
      text-transform: uppercase; color: var(--egg); opacity: .9;
    }
    .value-dot { width: 5px; height: 5px; border-radius: 50%; background: rgba(255,255,251,.35); flex-shrink: 0; }

    /* ─── APPROACH ───────────────────────────────────────── */
    .approach { padding: 130px 56px; background: var(--black); }
    .approach-head { margin-bottom: 80px; }
    .approach-label {
      font-size: 10px; font-weight: 500; letter-spacing: .2em;
      text-transform: uppercase; color: var(--egg); opacity: .35; margin-bottom: 20px;
    }
    .approach-title {
      font-family: var(--sans); font-size: clamp(36px, 4vw, 64px);
      font-weight: 600; letter-spacing: -.025em; text-transform: uppercase;
      line-height: .95; color: var(--egg);
    }
    .approach-title em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }
    .approach-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; }
    .approach-card {
      background: rgba(255,255,251,.04); border: 1px solid rgba(255,255,251,.07);
      padding: 52px 44px; display: flex; flex-direction: column; gap: 24px;
      transition: background .3s;
    }
    .approach-card:hover { background: rgba(255,255,251,.08); }
    .approach-num {
      font-size: 11px; font-weight: 500; letter-spacing: .15em;
      color: var(--green); font-variant-numeric: tabular-nums;
    }
    .approach-card-title {
      font-family: var(--sans); font-size: 22px; font-weight: 600;
      letter-spacing: -.01em; text-transform: uppercase; color: var(--egg);
      line-height: 1.1;
    }
    .approach-card-desc { font-size: 14px; line-height: 1.75; color: var(--egg); opacity: .45; }

    /* ─── TEAM ───────────────────────────────────────────── */
    .team { padding: 130px 56px; }
    .team-head { margin-bottom: 72px; }
    .team-label {
      font-size: 10px; font-weight: 500; letter-spacing: .2em;
      text-transform: uppercase; color: var(--green); margin-bottom: 20px;
    }
    .team-title {
      font-family: var(--sans); font-size: clamp(36px, 4vw, 64px);
      font-weight: 600; letter-spacing: -.025em; text-transform: uppercase;
      line-height: .95; color: var(--black);
    }
    .team-title em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }
    .team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
    .team-card { display: flex; flex-direction: column; gap: 20px; }
    .team-img {
      width: 100%; /* aspect-ratio: 3/4; */ overflow: hidden;
      background: var(--grey);
      border: 1px dashed rgba(19,112,83,.25);
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      gap: 10px; position: relative;
    }
    .team-img img { width: 100%; height: 400px; object-fit: cover; object-position: top; display: block; }
    .team-img-ph { display: flex; flex-direction: column; align-items: center; gap: 10px; }
    .team-img-ph svg { opacity: .2; }
    .team-img-ph span {
      font-size: 10px; font-weight: 500; letter-spacing: .15em;
      text-transform: uppercase; color: var(--black); opacity: .3;
    }
    .team-card-tag {
      font-size: 10px; font-weight: 500; letter-spacing: .18em;
      text-transform: uppercase; color: var(--green); margin-bottom: 4px;
    }
    .team-card-name {
      font-size: 22px; font-weight: 600; letter-spacing: -.01em;
      text-transform: uppercase; color: var(--black); line-height: 1;
    }
    .team-card-role { font-size: 13px; color: var(--black); opacity: .45; margin-top: 4px; }

    /* ─── STATS (green) ──────────────────────────────────── */
    .stats-band {
      padding: 120px 56px; background: var(--green);
      position: relative; overflow: hidden;
    }
    .stats-band > * { position: relative; z-index: 2; }
    .stats-band-label {
      font-size: 11px; font-weight: 500; letter-spacing: .2em;
      text-transform: uppercase; color: var(--egg); opacity: .5; margin-bottom: 72px;
    }
    .stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
    .stat-block {
      padding: 40px 0; border-right: 1px solid rgba(255,255,251,.15);
    }
    .stat-block:last-child { border-right: none; }
    .stat-block:not(:first-child) { padding-left: 52px; }
    .stat-n {
      font-family: var(--sans); font-size: clamp(52px, 5vw, 76px);
      font-weight: 600; letter-spacing: -.03em; color: var(--egg); line-height: 1;
    }
    .stat-l {
      font-size: 11px; font-weight: 400; letter-spacing: .1em;
      text-transform: uppercase; color: var(--egg); opacity: .45; margin-top: 10px;
    }

    /* ─── CTA ────────────────────────────────────────────── */
    .about-cta {
      padding: 130px 56px; background: var(--egg);
      display: flex; flex-direction: column; align-items: flex-start; gap: 48px;
      border-top: 1px solid rgba(5,5,5,.08);
    }
    .about-cta-hl {
      font-family: var(--sans); font-size: clamp(48px, 7vw, 110px);
      font-weight: 600; letter-spacing: -.03em; text-transform: uppercase;
      line-height: .9; color: var(--black);
    }
    .about-cta-hl em {
      font-family: var(--serif); font-style: italic;
      font-weight: 700; text-transform: none; color: var(--green);
    }
    .btn-primary {
      font-family: var(--sans); font-size: 12px; font-weight: 500;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--egg); background: var(--green);
      padding: 17px 44px; text-decoration: none;
      display: inline-block; transition: background .2s;
    }
    .btn-primary:hover { background: var(--black); }

     

    /* ─── ANIMATIONS ─────────────────────────────────────── */
    .reveal { opacity: 0; transform: translateY(44px); transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
    .reveal-left { opacity: 0; transform: translateX(-56px); transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
    .reveal-right { opacity: 0; transform: translateX(56px); transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
    .reveal-scale { opacity: 0; transform: scale(.93) translateY(24px); transition: opacity 1.1s cubic-bezier(.16,1,.3,1), transform 1.1s cubic-bezier(.16,1,.3,1); }
    .reveal-clip { clip-path: inset(0 0 100% 0); transition: clip-path 1.2s cubic-bezier(.16,1,.3,1); }
    .reveal.in, .reveal-left.in, .reveal-right.in, .reveal-scale.in { opacity: 1; transform: none; }
    .reveal-clip.in { clip-path: inset(0 0 0% 0); }
    .d1 { transition-delay: .1s; } .d2 { transition-delay: .22s; }
    .d3 { transition-delay: .34s; } .d4 { transition-delay: .46s; }

    /* ─── RESPONSIVE ─────────────────────────────────────── */
    @media (max-width: 960px) {
      nav { padding: 20px 28px; }
      .nav-links { display: none; }
      .about-hero { padding: 0 28px 64px; }
      .manifesto { padding: 80px 28px; grid-template-columns: 1fr; gap: 44px; }
      .approach { padding: 80px 28px; }
      .approach-grid { grid-template-columns: 1fr; }
      .team { padding: 80px 28px; }
      .team-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
      .stats-band { padding: 80px 28px; }
      .stats-grid { grid-template-columns: 1fr 1fr; gap: 0; }
      .stat-block { padding: 32px 0; border-right: none; border-bottom: 1px solid rgba(255,255,251,.15); }
      .stat-block:not(:first-child) { padding-left: 0; }
      .about-cta { padding: 80px 28px; }
      footer { padding: 40px 28px; flex-wrap: wrap; gap: 24px; }
      .foot-tag { display: none; }
    }
    @media (max-width: 600px) {
      .team-grid { grid-template-columns: 1fr; }
    }

    /* ─── PAGE TRANSITION ───────────────────────────────── */
    #page-transition {
      position: fixed; inset: 0; z-index: 10000; background: var(--green);
      transform: translateY(0); transition: transform .8s cubic-bezier(.76,0,.24,1);
      pointer-events: all;
    }
    #page-transition.is-revealed { transform: translateY(-100%); pointer-events: none; }

    /* ─── SCROLL PROGRESS ───────────────────────────────── */
    #scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 9000; background: transparent; }
    #scroll-progress-fill { height: 100%; background: var(--green); width: 0%; transition: width .1s linear; }