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

    :root {
      --gold: #C6A86B;
      --gold-dark: #b29357;
      --bg: #F1ECE4;
      --primary: #354D3F;
      --secondary: #1F4F4A;
      --nav-bg: rgba(31, 42, 38, 0.85);
      --dark-text: #1E2421;
      --overlay: rgba(30, 36, 33, 0.54);
      --white: #ffffff;
      --muted: rgba(255,255,255,0.72);
      --border-light: rgba(255,255,255,0.34);
      --section-max: 1440px;
      --section-min-h: 810px;
      --section-pad: 141px;
      --radius-lg: 15px;
      --nav-h: 125px;
      --font-h: 'Montserrat', sans-serif;
      --font-ui: 'Inter', sans-serif;
    }

    html {
      overflow-x: clip;
      scroll-behavior: smooth;
    }

    body {
      min-height: 100%;
      font-family: 'Montserrat', sans-serif;
      background: var(--bg);
      color: var(--white);
      overflow-x: hidden;
      line-height: 1.5;
      -webkit-overflow-scrolling: touch;
    }

    /* ─── NAVBAR ─── */
    .admin-bar nav { top: 32px; }

    nav {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 100;
      background: var(--nav-bg);
      backdrop-filter: blur(10px);
      border-bottom: 1px solid rgba(255,255,255,0.07);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 141px;
      height: 125px;
    }

    .nav-logo {
      display: inline-flex;
      align-items: center;
      text-decoration: none;
      flex-shrink: 0;
    }

    nav .nav-logo img {
      height: 75px;
      width: auto;
      max-width: 260px;
      display: block;
      object-fit: contain;
    }

    .site-footer .nav-logo img {
      height: 75px;
      width: auto;
      max-width: 180px;
      display: block;
      object-fit: contain;
    }

    .site-footer .nav-logo {
      display: inline-flex;
      align-items: flex-start;
      justify-content: flex-start;
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 28px;
      list-style: none;
    }

    .nav-links a {
      display: inline-flex;
      padding: 16px;
      justify-content: center;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      color: rgba(255,255,255,0.50);
      font-family: 'Montserrat', sans-serif;
      font-size: 14px;
      font-weight: 400;
      white-space: nowrap;
      transition: color 0.2s;
    }

    .nav-links a:hover { color: var(--white); }

    .nav-links a.active { color: var(--gold); }

    .btn-contact-nav {
      background: var(--gold);
      color: var(--white) !important;
      padding: 0 28px !important;
      height: 55px;
      line-height: 55px;
      border-radius: 999px;
      font-family: 'Montserrat', sans-serif !important;
      font-weight: 400 !important;
      font-size: 14px !important;
      letter-spacing: 0.4px;
      cursor: pointer;
      text-decoration: none;
      display: inline-block;
      transition: background 0.25s, border-color 0.25s, color 0.25s !important;
    }

    .btn-contact-nav:hover {
      background: var(--gold-dark) !important;
      color: var(--white) !important;
    }

    /* ─── HERO ─── */
    .hero {
      position: relative;
      width: 100%;
      min-height: 100svh;
      display: flex;
      align-items: flex-end;
      overflow: hidden;
      background: #9fb1a2;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      background-position: center bottom;
      background-size: cover;
      background-repeat: no-repeat;
      transform: scale(1.02);
      animation: slowZoom 18s ease-in-out infinite alternate;
      opacity: 0;
      z-index: 1;
      transition: opacity 1.2s ease;
    }

    .hero-bg.active { opacity: 1; z-index: 2; }

    .hero-bg:nth-child(1) { background-image: url('../../figma-assets/home_hero_02.webp'); }
    .hero-bg:nth-child(2) { background-image: url('../../figma-assets/home_hero_01.webp'); }
    .hero-bg:nth-child(3) { background-image: url('../../figma-assets/home_hero_03.webp'); }

    @keyframes slowZoom {
      from { transform: scale(1.02); }
      to   { transform: scale(1.07); }
    }

    .hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(
        180deg,
        rgba(151, 174, 158, 0.18) 0%,
        rgba(129, 152, 137, 0.42) 42%,
        rgba(27, 55, 44, 0.58) 100%
      );
    }

    .hero::before {
      content: '';
      position: absolute;
      top: 125px; left: 0; right: 0;
      height: 1px;
      background: rgba(255,255,255,0.04);
      z-index: 2;
    }

    .hero-content {
      position: relative;
      z-index: 3;
      width: min(620px, calc(100% - 96px));
      margin-left: 141px;
      margin-bottom: 92px;
      animation: fadeUp 1s ease both;
    }

    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(30px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    .hero-eyebrow {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 16px;
      opacity: 0;
      animation: fadeUp 0.8s 0.2s ease both;
    }

    .hero-eyebrow span {
      width: 32px;
      height: 2px;
      background: var(--gold);
      display: block;
    }

    .hero-eyebrow p {
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      font-weight: 600;
    }

    .hero-title {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 60px;
      line-height: 60px;
      text-transform: uppercase;
      letter-spacing: 0;
      color: var(--white);
      margin-bottom: 16px;
      opacity: 0;
      animation: fadeUp 0.8s 0.35s ease both;
    }

    .hero-desc {
      font-size: 20px;
      line-height: 1.6;
      color: var(--white);
      max-width: 480px;
      min-height: 96px;
      margin-bottom: 26px;
      opacity: 0;
      animation: fadeUp 0.8s 0.5s ease both;
      text-align: left;
    }

    .hero-buttons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      opacity: 0;
      animation: fadeUp 0.8s 0.65s ease both;
    }

    .btn {
      padding: 0 28px;
      height: 55px;
      line-height: 55px;
      border-radius: 999px;
      font-family: 'Montserrat', sans-serif;
      font-size: 14px;
      font-weight: 400;
      cursor: pointer;
      letter-spacing: 0.4px;
      transition: background 0.25s, border-color 0.25s, color 0.25s, font-weight 0.1s;
      text-decoration: none;
      display: inline-block;
    }

    .btn-primary {
      background: var(--gold);
      color: var(--white);
      border: 2px solid var(--gold);
    }

    .btn-primary:hover {
      background: var(--gold-dark);
      border-color: var(--gold-dark);
    }

    .btn-outline {
      background: transparent;
      color: var(--white);
      border: 1px solid rgba(255,255,255,0.75);
    }

    .btn-outline:hover {
      background: var(--gold);
      border-color: var(--gold);
      color: var(--white);
    }

    /* ─── SLIDE INDICATORS ─── */
    .slide-indicators {
      position: absolute;
      right: 52px;
      bottom: 92px;
      z-index: 90;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
    }

    .slide-dot {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 55px;
      height: 55px;
      border: none;
      border-radius: 50%;
      font-size: clamp(12px, 1.1vw, 16px);
      font-weight: 400;
      letter-spacing: 0.5px;
      cursor: pointer;
      transition: all 0.25s;
      color: var(--muted);
      position: relative;
      background: transparent;
      font-family: 'Montserrat', sans-serif;
    }

    .slide-dot.active {
      background: var(--gold);
      color: var(--white);
      box-shadow: none;
    }

    .slide-dot:not(.active):hover {
      color: var(--white);
    }

    .slide-connector {
      display: none;
    }

    /* ─── SCROLL HINT ─── */
    .scroll-hint { display: none; }

    .scroll-hint span {
      font-size: 10px;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--white);
    }

    .scroll-line {
      width: 40px;
      height: 1px;
      background: var(--white);
      position: relative;
      overflow: hidden;
    }

    .scroll-line::after {
      content: '';
      position: absolute;
      top: 0; left: -100%;
      width: 100%; height: 100%;
      background: var(--gold);
      animation: slideLine 2s ease-in-out infinite;
    }

    @keyframes slideLine {
      0%   { left: -100%; }
      100% { left: 100%; }
    }

    /* ─── SECTION: INTEGRATED STEWARDSHIP ─── */
    .section-stewardship {
      background: var(--secondary);
      padding: 100px var(--section-pad);
      min-height: var(--section-min-h);
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .stewardship-top {
      display: grid;
      grid-template-columns: 466fr 662fr;
      gap: 25px;
      align-items: end;
      margin: 0 0 60px;
    }

    .stewardship-left h2 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 50px;
      text-transform: uppercase;
      line-height: 1.0;
      letter-spacing: 0.8px;
      margin-bottom: 16px;
    }

    .stewardship-left .tagline {
      font-size: 24px;
      color: rgba(255,255,255,0.5);
      letter-spacing: 0.3px;
    }

    .stewardship-right {
      display: flex;
      flex-direction: column;
      gap: 25px;
      padding-top: 0;
    }

    .stewardship-right p {
      font-size: 16px;
      line-height: 1.5;
      color: var(--white);
    }

    /* OUR OFFICES */
    .offices-label {
      display: flex;
      align-items: center;
      gap: 16px;
      width: 100%;
      margin: 0 0 35px;
      font-size: 16px;
      letter-spacing: 4px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.55);
      font-weight: 600;
      white-space: nowrap;
    }

    .offices-label::before,
    .offices-label::after {
      content: '';
      flex: 1;
      border-top: 1px dotted rgba(255,255,255,0.25);
    }

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

    .office-item {
      display: flex;
      flex-direction: column;
      gap: 0;
      cursor: pointer;
    }

    .office-card {
      position: relative;
      border-radius: 12px;
      overflow: hidden;
      cursor: pointer;
      height: 256px;
    }

    .office-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.4s;
    }

    .office-card:hover img {
      transform: scale(1.04);
    }

    .office-card-overlay {
      position: absolute;
      inset: 0;
      background: transparent;
      mix-blend-mode: color;
      transition: background 0.4s;
    }

    .office-card:hover .office-card-overlay {
      background: var(--secondary);
    }

    .office-name {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: clamp(16px, 2vw, 30px);
      text-transform: uppercase;
      letter-spacing: 0.7px;
      color: var(--white);
      margin-top: -22px;
      position: relative;
      z-index: 1;
      padding: 0 20px;
    }

    /* ─── SECTION: ANCHORED IN SINGAPORE ─── */
    .section-anchored {
      background: var(--primary);
      display: grid;
      grid-template-columns: 429px 1fr;
      gap: 0;
      min-height: 810px;
      overflow: hidden;
      padding: 0 var(--section-pad);
      align-items: center;
    }

    .anchored-image {
      overflow: hidden;
      position: relative;
      align-self: stretch;
      /* border-radius: 12px; */
    }

    .anchored-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      /* filter: grayscale(55%) brightness(0.68) sepia(18%) hue-rotate(95deg); */
      display: block;
    }

    .anchored-content {
      padding: 72px var(--section-pad) 72px 132px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 20px;
    }

    .anchored-content h2 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 50px;
      text-transform: uppercase;
      line-height: 1.0;
      letter-spacing: 0.8px;
      color: var(--white);
      margin-bottom: 14px;
    }

    .anchored-content p {
      font-size: 16px;
      line-height: 1.5;
      color: var(--white);
    }

    /* ─── SECTION: GUIDED BY TRUSTED COUNCIL ─── */
    .section-council {
      background: var(--secondary);
      padding: 72px var(--section-pad);
      display: grid;
      grid-template-columns: 466fr 662fr;
      gap: 24px;
      align-items: start;
      min-height: var(--section-min-h);
      align-content: center;
    }

    .council-left h2 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 600;
      font-size: 50px;
      text-transform: uppercase;
      line-height: 1.0;
      letter-spacing: 0.8px;
      color: var(--white);
    }

    .council-right {
      display: flex;
      flex-direction: column;
    }

    .council-member {
      padding: 0 0 18px;
      margin-bottom: 18px;
      border-bottom: 1px dotted rgba(255,255,255,0.15);
    }

    .council-member:first-child {
      padding-top: 0;
    }

    .council-member h3 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 600;
      font-size: 30px;
      text-transform: uppercase;
      letter-spacing: 0.6px;
      color: var(--white);
      margin-bottom: 4px;
    }

    .council-member p {
      font-size: 25px;
      color: rgba(255,255,255,0.5);
      line-height: 1.55;
    }

    .council-note {
      margin-top: 4px;
      font-size: 16px;
      line-height: 1.7;
      color: var(--white);
      max-width: 480px;
    }

    /* ─── SECTION: INVESTMENT DOMAINS ─── */
    .section-domains {
      background: var(--secondary);
      padding: 100px var(--section-pad);
      min-height: var(--section-min-h);
      display: flex;
      flex-direction: column;
      justify-content: center;
    }


    .btn-thinking {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      height: 48px;
      padding: 0 24px;
      border-radius: 100px;
      border: 1.5px solid rgba(255,255,255,0.55);
      color: var(--white);
      font-family: 'Montserrat', sans-serif;
      font-size: 14px;
      font-weight: 400;
      white-space: nowrap;
      transition: background 0.2s, border-color 0.2s;
      text-decoration: none;
    }
    .btn-thinking:hover {
      background: rgba(255,255,255,0.1);
      border-color: var(--white);
    }

    .domains-header {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      width: 100%;
      margin: 0 0 26px;
    }

    .domains-header h2 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 50px;
      text-transform: uppercase;
      letter-spacing: 0.8px;
      color: var(--white);
    }

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

    .domain-card {
      position: relative;
      aspect-ratio: 388/546;
      cursor: pointer;
      perspective: 1200px;
    }

    .domain-card__inner {
      position: relative;
      width: 100%;
      height: 100%;
      transform-style: preserve-3d;
      transition: transform 0.65s ease;
    }

    .domain-card:hover .domain-card__inner,
    .domain-card.flipped .domain-card__inner {
      transform: rotateY(180deg);
    }

    .domain-card__front,
    .domain-card__back {
      position: absolute;
      inset: 0;
      border-radius: 12px;
      overflow: hidden;
      backface-visibility: hidden;
      -webkit-backface-visibility: hidden;
    }

    .domain-card__front {
      isolation: isolate;
      -webkit-mask-image: -webkit-radial-gradient(white, black);
      mask-image: radial-gradient(white, black);
    }

    .domain-card__front img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.5s ease;
    }

    .domain-card:hover .domain-card__front img {
      transform: scale(1.05);
    }

    .domain-card__front::before {
      content: '';
      position: absolute;
      inset: 0;
      background: transparent;
      mix-blend-mode: color;
      transition: background 0.4s;
      z-index: 1;
      pointer-events: none;
    }

    .domain-card__back {
      transform: rotateY(180deg);
      background: var(--secondary);
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      padding: 40px 36px;
      gap: 8px;
    }

    .domain-card__back-label {
      font-family: var(--font-h);
      font-size: 20px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 1.5px;
      line-height: 1;
      color: var(--white);
    }

    .domain-card__back-body {
      font-family: var(--font-h);
      font-size: 15px;
      font-weight: 400;
      line-height: 1.6;
      color: rgba(255,255,255,0.9);
    }

    .domain-card-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(
        to top,
        rgba(8, 30, 22, 0.92) 0%,
        rgba(8, 30, 22, 0.40) 45%,
        transparent 75%
      );
      z-index: 2;
    }

    .domain-card-content {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 3;
      padding: 60px 50px 50px;
    }

    .domain-card-content h3 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 30px;
      text-transform: uppercase;
      line-height: 1.0;
      letter-spacing: 0.5px;
      color: var(--white);
      margin-bottom: 8px;
    }

    .domain-card-content p {
      font-size: 16px;
      color: var(--white);
      line-height: 1.5;
      min-height: 48px;
    }

    /* ─── SECTION: MEET OUR TEAM ─── */
    .section-team {
      background: var(--primary);
      padding: 100px var(--section-pad);
      min-height: var(--section-min-h);
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .team-heading {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 50px;
      text-transform: uppercase;
      letter-spacing: 0.8px;
      color: var(--white);
      width: 100%;
      margin: 0 0 22px;
      text-align: left;
    }

    .team-layout {
      display: grid;
      grid-template-columns: 55fr 45fr;
      grid-template-rows: 200px 1fr;
      gap: 24px;
      width: 100%;
      position: relative;
    }

    /* Outer wrapper: rounds the outer corners of the L-shape */
    .team-image-outer {
      position: absolute;
      inset: 0;
      border-radius: 12px;
      overflow: hidden;
      pointer-events: none;
    }

    /* Inner wrapper: clips the image into an L-shape
       Left col ~55%, gap 24px → right col starts at calc(55% + 11px)
       Banner row 200px, gap 24px → row 2 starts at 224px             */
    .team-image-wrap {
      position: absolute;
      inset: 0;
      clip-path: polygon(
        0% 0%,
        100% 0%,
        100% 100%,
        calc(55% + 11px) 100%,
        calc(55% + 11px) 224px,
        0% 224px
      );
    }

    .team-image-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      /* filter: grayscale(50%) brightness(0.60) sepia(25%) hue-rotate(110deg); */
      display: block;
    }

    /* Invisible grid placeholders to maintain row/column sizing */
    .team-banner {
      grid-column: 1;
      grid-row: 1;
      visibility: hidden;
    }

    .team-side-placeholder {
      grid-column: 2;
      grid-row: 1 / 3;
      visibility: hidden;
    }

    .team-text {
      grid-column: 1;
      grid-row: 2;
      display: flex;
      flex-direction: column;
      gap: 16px;
      padding: 50px 50px 0 0;
      position: relative;
      z-index: 1;
    }

    .team-text .subtitle {
      font-size: 24px;
      color: rgba(255,255,255,0.5);
      font-weight: 400;
      line-height: 1.5;
    }

    .team-text p {
      font-size: 16px;
      line-height: 1.5;
      color: var(--white);
    }

    .team-text .btn-team {
      display: inline-flex;
      align-items: center;
      cursor: pointer;
      margin-top: 14px;
      padding: 0 28px;
      height: 55px;
      border: 1.5px solid rgba(255,255,255,0.55);
      border-radius: 999px;
      font-size: 14px;
      font-family: 'Montserrat', sans-serif;
      color: var(--white);
      text-decoration: none;
      width: fit-content;
      transition: border-color 0.25s, background 0.25s;
    }

    .team-text .btn-team:hover {
      border-color: var(--gold);
      background: var(--gold);
      color: var(--white);
    }


    /* ─── SECTION: CONTACT US ─── */
    .section-contact {
      background: var(--secondary);
      padding: 100px var(--section-pad);
      min-height: var(--section-min-h);
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .contact-header {
      text-align: right;
      width: 100%;
      margin: 0 0 28px;
    }

    .contact-header h2 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 50px;
      text-transform: uppercase;
      letter-spacing: 0.8px;
      color: var(--white);
    }

    .contact-body {
      display: grid;
      grid-template-columns: 1fr 1.6fr;
      gap: 56px;
      width: 100%;
      align-items: stretch;
    }

    /* Left info */
    .contact-info {
      display: flex;
      flex-direction: column;
      gap: 18px;
    }

    .contact-office {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .contact-office h3 {
      font-family: 'Montserrat', sans-serif;
      font-weight: 700;
      font-size: 30px;
      text-transform: uppercase;
      letter-spacing: 0.6px;
      color: var(--white);
    }

    .contact-office p {
      font-size: 16px;
      color: rgba(255,255,255,0.5);
      line-height: 1.6;
    }

    .contact-details {
      display: flex;
      flex-direction: column;
      gap: 6px;
      padding-top: 4px;
    }

    .contact-details p {
      font-size: 16px;
      color: var(--white);
    }

    .contact-details a {
      color: var(--gold);
      text-decoration: none;
      transition: opacity 0.2s;
    }

    .contact-details a:hover { opacity: 0.75; }

    .social-buttons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      padding-top: 12px;
      margin-top: auto;
    }

    .social-btn {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 0 22px;
      height: 55px;
      border: 1.5px solid rgba(255,255,255,0.40);
      border-radius: 999px;
      font-size: 14px;
      font-family: 'Montserrat', sans-serif;
      color: var(--white);
      text-decoration: none;
      cursor: pointer;
      transition: border-color 0.2s, color 0.2s;
    }

    .social-btn:hover {
      border-color: var(--gold);
      color: var(--gold);
      background: rgba(198,168,107,0.06);
    }

    .social-btn svg {
      width: 20px;
      height: 20px;
      fill: currentColor;
      flex-shrink: 0;
    }

    /* Right form */
    .contact-form-card {
      background: rgba(255,255,255,0.5);
      border-radius: 12px;
      padding: 40px 44px 44px;
    }

    .contact-form-card h3 {
      font-size: 25px;
      font-weight: 400;
      color: #354D3F;
      margin-bottom: 32px;
      font-family: 'Montserrat', sans-serif;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 32px;
      margin-bottom: 28px;
    }

    .form-field {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .form-field label {
      font-size: 16px;
      color: var(--dark-text);
      letter-spacing: 0.2px;
      opacity: 0.7;
    }

    .form-field input,
    .form-field textarea {
      background: transparent;
      border: none;
      border-bottom: 1px solid #000000;
      outline: none;
      font-size: 16px;
      color: var(--dark-text);
      padding: 8px 0;
      font-family: 'Montserrat', sans-serif;
      transition: border-color 0.2s;
      width: 100%;
    }

    .form-field input:focus,
    .form-field textarea:focus {
      border-bottom-color: var(--dark-text);
      color: var(--dark-text);
    }

    .form-field input:-webkit-autofill,
    .form-field input:-webkit-autofill:hover,
    .form-field input:-webkit-autofill:focus {
      -webkit-text-fill-color: var(--dark-text);
      -webkit-box-shadow: 0 0 0px 1000px rgba(255,255,255,0.5) inset;
      transition: background-color 5000s ease-in-out 0s;
    }

    .form-field textarea {
      resize: none;
      height: 100px;
    }

    .form-message {
      margin-bottom: 32px;
    }

    .form-submit {
      display: flex;
      justify-content: flex-end;
    }

    .btn-send {
      background: var(--gold);
      color: var(--white);
      border: none;
      padding: 0 28px;
      height: 55px;
      border-radius: 999px;
      font-size: 14px;
      cursor: pointer;
      font-family: 'Montserrat', sans-serif;
      transition: background 0.2s;
    }

    .btn-send:hover { background: var(--gold-dark); }

    /* ─── FOOTER ─── */
    .site-footer {
      background: var(--primary);
      padding: 28px var(--section-pad) 22px;
      border-top: 1px dotted rgba(255,255,255,0.08);
    }

    .footer-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 28px;
      width: 100%;
      margin: 0 0 18px;
    }

    .footer-nav {
      display: flex;
      align-items: center;
      gap: 24px;
      list-style: none;
    }

    .footer-nav a {
      font-size: 14px;
      font-family: 'Montserrat', sans-serif;
      font-weight: 400;
      color: rgba(255,255,255,0.50);
      text-decoration: none;
      transition: color 0.2s;
      padding: 16px;
    }

    .footer-nav a:hover { color: var(--white); }

    .footer-divider {
      height: 0;
      border-top: 1px dotted rgba(255,255,255,0.12);
      margin: 0 0 16px;
    }

    .footer-bottom {
      text-align: center;
    }

    .footer-bottom p {
      font-size: 12px;
      color: rgba(255,255,255,0.45);
      letter-spacing: 0.3px;
    }

    /* ─── HAMBURGER MENU ─── */
    .hamburger {
      display: none;
      flex-direction: column;
      justify-content: center;
      gap: 5px;
      cursor: pointer;
      padding: 6px;
      background: none;
      border: none;
      z-index: 200;
    }

    .hamburger span {
      display: block;
      width: 24px;
      height: 2px;
      background: var(--white);
      border-radius: 2px;
      transition: all 0.3s ease;
      transform-origin: center;
    }

    .hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
    .hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .mobile-menu {
      display: none;
      position: fixed;
      top: 125px;
      left: 0; right: 0;
      background: rgba(31, 46, 39, 0.98);
      backdrop-filter: blur(12px);
      z-index: 99;
      padding: 20px 24px 28px;
      border-bottom: 1px solid rgba(255,255,255,0.08);
      flex-direction: column;
      gap: 0;
    }

    .mobile-menu.open { display: flex; }

    .mobile-menu a {
      display: block;
      padding: 16px 0;
      font-size: 15px;
      color: rgba(255,255,255,0.80);
      text-decoration: none;
      border-bottom: 1px solid rgba(255,255,255,0.07);
      transition: color 0.2s;
    }

    .mobile-menu a:hover { color: var(--white); }
    .mobile-menu a.active { color: var(--gold); }

    .mobile-menu .btn-contact-mobile {
      margin-top: 16px;
      display: inline-block;
      background: var(--gold);
      color: var(--white) !important;
      border: none;
      padding: 12px 24px;
      border-radius: 999px;
      font-family: 'Montserrat', sans-serif;
      font-weight: 600;
      font-size: 14px;
      text-align: center;
      border-bottom: none !important;
    }

    /* ─── RESPONSIVE — LARGE SCREEN (≥1440px) ─── */
    @media (min-width: 1440px) {
      .section-anchored { grid-template-columns: 420px 1fr; min-height: 900px; }
    }

    /* ─── RESPONSIVE — MID SCREEN (1281px–1439px, e.g. 1366x768) ─── */
    @media (max-width: 1439px) and (min-width: 1281px) {
      .anchored-content { padding-right: 60px; }
    }

    /* ─── RESPONSIVE — LARGE NAV + SECTIONS (≤1280px, covers 1024px range) ─── */
    @media (max-width: 1280px) {
      :root { --section-pad: 80px; }
      nav { padding: 0 60px; }
      .nav-links a { padding: 12px 10px; font-size: 14px; }

      /* Section headings */
      .stewardship-left h2,
      .anchored-content h2,
      .domains-header h2,
      .team-heading,
      .contact-header h2 { font-size: clamp(32px, 3.5vw, 46px); }

      /* Section padding */
      .section-stewardship { padding: 100px var(--section-pad); }
      .section-domains     { padding: 100px var(--section-pad); }
      .section-team        { padding: 100px var(--section-pad); }
      .section-contact     { padding: 100px var(--section-pad); }
      .section-council     { padding: 56px var(--section-pad); }

      /* Anchored */
      .anchored-content { padding: 60px var(--section-pad) 60px 80px; }

      /* Domain cards */
      .domain-card-content p { font-size: 14px; }

      /* Contact form */
      .form-row { gap: 20px; }

      /* Footer — compact to prevent nav wrapping at ~1024px */
      .site-footer { padding: 24px 60px 20px; }
      .footer-nav { gap: 4px; }
      .footer-nav a { font-size: 14px; padding: 8px 10px; }
      .site-footer .nav-logo img { height: 60px; }
    }

    /* ─── SHORT + WIDE SCREENS (1024×600, landscape laptops) ─── */
    @media (max-height: 700px) and (min-width: 961px) {
      .section-stewardship,
      .section-domains,
      .section-team,
      .section-contact,
      .section-anchored,
      .section-council { min-height: auto; }

      .hero { min-height: 100svh; }
      .hero-content { margin-bottom: 48px; }
      .slide-indicators { bottom: 48px; }
      .hero-title { font-size: clamp(32px, 5vw, 48px); line-height: 1.05; }
      .hero-desc { font-size: 16px; min-height: auto; margin-bottom: 16px; }
    }

    /* ─── RESPONSIVE — TABLET (max 960px) ─── */
    @media (max-width: 960px) {
      /* Navbar */
      .nav-links { display: none; }
      .hamburger { display: flex; }
      nav { padding: 0 40px; }

      /* Hero */
      .hero { min-height: 680px; }
      .section-stewardship, .section-domains, .section-team, .section-contact { min-height: auto; height: auto; }
      .section-council { min-height: auto; }
      .section-anchored { min-height: auto; }
      .hero-content { margin-left: 40px; margin-bottom: 88px; max-width: calc(100% - 80px); }
      .hero-title { font-size: clamp(36px, 6vw, 48px); line-height: 1.0; }
      .hero-desc { font-size: 16px; }
      .slide-indicators { right: 18px; bottom: 88px; }

      /* Stewardship */
      .section-stewardship { padding: 100px 40px; }
      .stewardship-top { grid-template-columns: 1fr; gap: 32px; }
      .stewardship-left h2 { font-size: 36px; }
      .stewardship-left .tagline { font-size: 24px; }
      .offices-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
      .office-name { font-size: clamp(14px, 2.2vw, 22px); }

      /* Anchored */
      .section-anchored { grid-template-columns: 1fr; padding: 0 40px; min-height: auto; }
      .anchored-image { height: 320px; }
      .anchored-content { padding: 48px 0; }
      .anchored-content h2 { font-size: 36px; }

      /* Council */
      .section-council { grid-template-columns: 1fr; gap: 36px; padding: 56px 40px; }
      .council-left h2 { font-size: 36px; }
      .council-member h3 { font-size: 22px; }
      .council-member p { font-size: 18px; }
      .council-note { font-size: 14px; }

      /* Domains */
      .section-domains { padding: 100px 40px; }
      .domains-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
      .domain-card { aspect-ratio: 3/4; }
      .domains-header h2 { font-size: 36px; }
      /* Team */
      .section-team { padding: 100px 40px; }
      .team-heading { font-size: 36px; }
      .team-layout { grid-template-columns: 1fr; grid-template-rows: 180px auto; }
      .team-banner { grid-column: 1; grid-row: 1; }
      .team-side-placeholder { display: none; }
      .team-text { grid-column: 1; grid-row: 2; padding: 32px 0 0 0; }
      .team-image-outer { bottom: auto; height: 180px; border-radius: 12px; }
      .team-image-wrap { clip-path: none; }
      .team-text .subtitle { font-size: 24px; }

      /* Contact */
      .section-contact { padding: 100px 40px; }
      .contact-header { text-align: left; }
      .contact-header h2 { font-size: 36px; }
      .contact-body { grid-template-columns: 1fr; gap: 40px; }
      .contact-office h3 { font-size: 22px; }
      .form-row { gap: 20px; }

      /* Footer */
      .site-footer { padding: 28px 40px 24px; }
      .footer-top { flex-direction: column; align-items: flex-start; gap: 20px; }
      .footer-nav { flex-wrap: wrap; gap: 14px 20px; }
      .site-footer .nav-logo img { height: 62px; max-width: 200px; }
    }

    /* ─── RESPONSIVE — MOBILE (max 600px) ─── */
    @media (max-width: 600px) {
      /* Navbar */
      nav { padding: 0 20px; height: 90px; }
      .mobile-menu { top: 90px; }
      nav .nav-logo img { height: 54px; max-width: 170px; }
      .site-footer .nav-logo img { height: 64px; max-width: 210px; }

      /* Hero */
      .hero { min-height: 100svh; }
      .section-stewardship, .section-domains, .section-team, .section-contact,
      .section-council, .section-anchored { min-height: auto; height: auto; }
      .hero-content { width: calc(100% - 40px); margin-left: 20px; margin-bottom: 32px; }
      .hero-title { font-size: clamp(28px, 9vw, 40px); line-height: 1.02; }
      .hero-desc { font-size: 16px; min-height: 48px; }
      .hero-buttons { flex-direction: column; gap: 10px; }
      .hero-buttons .btn { text-align: center; }
      .slide-indicators { display: none; }

      /* Stewardship */
      .section-stewardship { padding: 100px 20px; }
      .stewardship-top { gap: 24px; margin-bottom: 60px; padding-bottom: 24px; }
      .stewardship-left h2 { font-size: clamp(22px, 6vw, 30px); }
      .stewardship-left .tagline { font-size: 24px; }
      .stewardship-right p { font-size: 16px; }
      .offices-grid { grid-template-columns: 1fr; }
      .office-card { height: 200px; }
      .office-name { font-size: 22px; margin-top: -16px; }

      /* Anchored */
      .section-anchored { padding: 0 20px; min-height: auto; }
      .anchored-image { height: 240px; }
      .anchored-content { padding: 36px 0; }
      .anchored-content h2 { font-size: clamp(22px, 6vw, 30px); }
      .anchored-content p { font-size: 16px; }

      /* Council */
      .section-council { padding: 48px 20px; }
      .council-left h2 { font-size: clamp(22px, 6vw, 30px); }
      .council-member h3 { font-size: 18px; }
      .council-member p { font-size: 15px; }
      .council-note { font-size: 13px; }

      /* Domains */
      .section-domains { padding: 100px 20px; }
      .domains-grid { grid-template-columns: 1fr; }
      .domain-card { aspect-ratio: 16/9; }
      .domains-header { text-align: left; }
      .domains-header h2 { font-size: clamp(22px, 6vw, 30px); }
      .domain-card-content h3 { font-size: 18px; }
      .domain-card-content p { font-size: 16px; }

      /* Team */
      .section-team { padding: 100px 20px; }
      .team-heading { font-size: clamp(22px, 6vw, 30px); }
      .team-banner { height: 160px; }
      .team-text .subtitle { font-size: 24px; }
      .team-text p { font-size: 16px; }
      .team-side-image { height: 220px; }

      /* Contact */
      .section-contact { padding: 100px 20px; }
      .contact-header h2 { font-size: clamp(22px, 6vw, 30px); }
      .contact-office h3 { font-size: 18px; }
      .contact-office p { font-size: 16px; }
      .contact-details p { font-size: 16px; }
      .form-row { grid-template-columns: 1fr; gap: 16px; }
      .contact-form-card { padding: 28px 20px; }
      .social-buttons { gap: 8px; }

      /* Footer */
      .site-footer { padding: 28px 20px 20px; }
      .footer-top { flex-direction: column; align-items: flex-start; gap: 16px; }
      .site-footer .nav-logo img { height: 54px; }
      .footer-nav { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 0; width: 100%; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
      .footer-nav::-webkit-scrollbar { display: none; }
      .footer-nav a { white-space: nowrap; font-size: 14px; padding: 6px 12px; }
      .footer-nav a { white-space: normal; font-size: 14px; }
      .footer-bottom p { font-size: 12px; }
    }

    /* ─── SHORT SCREENS (max-height 810px, e.g. 1366x768 laptops) ─── */
    @media (max-height: 810px) and (min-width: 961px) {
      .hero-content { margin-bottom: 56px; }
      .slide-indicators { bottom: 56px; }
      .hero-title { font-size: 48px; line-height: 52px; }
      .hero-desc { min-height: 96px; margin-bottom: 18px; }

      .section-stewardship,
      .section-anchored,
      .section-domains,
      .section-team,
      .section-contact { min-height: auto; }

      .section-stewardship { padding: 100px var(--section-pad); }
      .section-anchored    { padding: 0 var(--section-pad); }
      .section-domains     { padding: 100px var(--section-pad); }
      .section-team        { padding: 100px var(--section-pad); }
      .section-contact     { padding: 100px var(--section-pad); }
    }

    /* ─── RESPONSIVE — SMALL PHONE (max 390px) ─── */
    @media (max-width: 390px) {
      .hero-title { font-size: clamp(22px, 7.5vw, 28px); line-height: 1.05; }
      .hero-desc { font-size: 13px; min-height: 42px; }
      .hero-content { margin-bottom: 24px; }
      .hero-eyebrow { margin-bottom: 10px; }
      .hero-buttons { gap: 8px; }
      .btn { height: 48px; line-height: 48px; font-size: 14px; padding: 0 20px; }
    }

    /* ─── REDUCED MOTION ─── */
    /* ─── FOCUS STATES (keyboard nav) ─── */
    :focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 3px;
      border-radius: 4px;
    }

    .btn:focus-visible,
    .btn-send:focus-visible,
    .btn-team:focus-visible,
    .social-btn:focus-visible,
    .btn-contact-nav:focus-visible,
    .slide-dot:focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 3px;
      border-radius: 999px;
    }

    /* ─── REDUCED MOTION ─── */
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
      }
      .hero-bg { animation: none; transform: none; }
      .hero-content, .hero-eyebrow, .hero-title, .hero-desc, .hero-buttons {
        opacity: 1;
        animation: none;
      }
      html { scroll-behavior: auto; }
    }

    /* ─── OVERSCROLL (prevent pull-to-refresh on mobile) ─── */
    @media (max-width: 960px) {
      body { overscroll-behavior-x: none; }
    }
