/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/4294df9f-8d38-44d4-8094-a5788de7072d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/ac59dc72-33a8-4dd1-94f6-7197c7972283.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/27745709-05d6-48c8-8aa9-c3ea1db978dd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/4294df9f-8d38-44d4-8094-a5788de7072d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/ac59dc72-33a8-4dd1-94f6-7197c7972283.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/27745709-05d6-48c8-8aa9-c3ea1db978dd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/4294df9f-8d38-44d4-8094-a5788de7072d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/ac59dc72-33a8-4dd1-94f6-7197c7972283.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/27745709-05d6-48c8-8aa9-c3ea1db978dd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/4294df9f-8d38-44d4-8094-a5788de7072d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/ac59dc72-33a8-4dd1-94f6-7197c7972283.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/fonts/27745709-05d6-48c8-8aa9-c3ea1db978dd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


  :root {
    --ink: #1F1A14;
    --paper: #FBF6EC;
    --cream: #F4EAD5;
    --honey: #E8A93C;
    --amber: #D26A1E;
    --terracotta: #A03E1A;
    --muted: #7A6F5C;
    --line: rgba(31,26,20,0.12);
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    background: var(--paper);
    color: var(--ink);
    font-family: 'Archivo', system-ui, sans-serif;
    font-size: 17px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
  }
  a { color: inherit; text-decoration: none; }
  img { display: block; max-width: 100%; }

  /* ====== Header ====== */
  header.nav {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in oklab, var(--paper) 92%, transparent);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--line);
  }
  .nav-inner {
    max-width: 1200px; margin: 0 auto;
    padding: 18px 32px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 24px;
  }
  .nav-logo { height: 32px; }
  .nav-links { display: flex; gap: 28px; align-items: center; }
  .nav-links a {
    font-size: 14px; font-weight: 500; color: var(--muted);
    transition: color .2s;
  }
  .nav-links a:hover { color: var(--ink); }
  .btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 20px; border-radius: 999px;
    font-size: 14px; font-weight: 600; letter-spacing: 0.2px;
    border: 1px solid transparent;
    transition: all .2s;
    cursor: pointer;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--amber); }
  .btn-secondary { background: transparent; color: var(--ink); border-color: var(--ink); }
  .btn-secondary:hover { background: var(--ink); color: var(--paper); }

  /* ====== Hero ====== */
  .hero {
    position: relative;
    max-width: 1200px; margin: 0 auto;
    padding: 112px 32px 96px;
    display: grid; grid-template-columns: 1.15fr 1fr;
    gap: 72px; align-items: center;
    isolation: isolate;
  }
  .hero-bg {
    position: absolute; inset: -40px -40px auto -40px;
    height: 760px; pointer-events: none; z-index: -1;
    overflow: hidden;
  }
  .hero-grid {
    position: absolute; inset: 0;
    background-image:
      linear-gradient(var(--line) 1px, transparent 1px),
      linear-gradient(90deg, var(--line) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black 30%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black 30%, transparent 75%);
    opacity: 0.5;
  }
  .hero-content { animation: hero-rise 0.9s cubic-bezier(.2,.7,.2,1) both; }
  .hero-visual { animation: hero-rise 0.9s cubic-bezier(.2,.7,.2,1) 0.15s both; }
  @keyframes hero-rise {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .eyebrow {
    font-size: 12px; font-weight: 600; letter-spacing: 1.6px;
    text-transform: uppercase; color: var(--muted);
    margin-bottom: 20px;
  }
  .hero-badge {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 8px 16px 8px 12px;
    border-radius: 999px;
    background: color-mix(in oklab, var(--paper) 70%, transparent);
    border: 1px solid var(--line);
    backdrop-filter: blur(8px);
    font-size: 13px; font-weight: 500; color: var(--ink);
    margin-bottom: 28px;
  }
  .hero-badge-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--amber);
  }

  .hero h1 {
    font-size: clamp(52px, 6.4vw, 92px);
    font-weight: 700;
    letter-spacing: -2.8px;
    line-height: 0.96;
    margin-bottom: 28px;
  }
  .hero h1 .accent {
    position: relative;
    background: linear-gradient(120deg, var(--amber), var(--honey) 60%, var(--terracotta));
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
  }
  .accent-underline {
    position: absolute;
    left: 0; right: 0; bottom: -4px;
    width: 100%; height: 0.18em;
    color: var(--amber); opacity: 0.6;
    stroke-dasharray: 240; stroke-dashoffset: 240;
    animation: draw 1.4s cubic-bezier(.5,0,.2,1) 0.6s forwards;
  }
  @keyframes draw { to { stroke-dashoffset: 0; } }

  .hero p.lede {
    font-size: 19px; color: var(--muted);
    max-width: 520px; margin-bottom: 36px;
  }
  .hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
  .btn-arrow svg { width: 16px; height: 16px; transition: transform .25s; }
  .btn-arrow:hover svg { transform: translateX(4px); }
  .btn-primary {
    box-shadow: 0 8px 24px -8px color-mix(in oklab, var(--ink) 50%, transparent);
  }
  .btn-primary:hover {
    box-shadow: 0 12px 28px -8px color-mix(in oklab, var(--amber) 60%, transparent);
    transform: translateY(-1px);
  }

  .hero-trust {
    display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
    padding-top: 28px;
    border-top: 1px solid var(--line);
  }
  .hero-trust-item { display: flex; flex-direction: column; gap: 2px; }
  .hero-trust-item strong {
    font-size: 22px; font-weight: 700;
    letter-spacing: -0.5px; color: var(--ink);
    line-height: 1;
  }
  .hero-trust-item span {
    font-size: 13px; color: var(--muted);
  }
  .hero-trust-divider {
    width: 1px; height: 32px; background: var(--line);
  }

  .hero-visual {
    position: relative;
    aspect-ratio: 1 / 1;
  }
  .hero-visual-frame {
    position: absolute; inset: 0;
    background: linear-gradient(160deg, var(--cream), color-mix(in oklab, var(--honey) 18%, var(--cream)));
    border-radius: 32px;
    border: 1px solid color-mix(in oklab, var(--ink) 6%, transparent);
    display: flex; align-items: center; justify-content: center;
    padding: 64px;
    box-shadow:
      0 30px 60px -30px color-mix(in oklab, var(--ink) 35%, transparent),
      inset 0 1px 0 color-mix(in oklab, white 40%, transparent);
    overflow: hidden;
  }
  .hero-visual-frame::before {
    content: ""; position: absolute; inset: -1px;
    background: radial-gradient(circle at 30% 20%, color-mix(in oklab, var(--honey) 30%, transparent), transparent 60%);
    pointer-events: none;
  }
  .hero-visual-frame img {
    max-width: 75%; position: relative;
    animation: float 7s ease-in-out infinite;
  }
  @keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
  }

  .hero-card {
    position: absolute;
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px;
    background: color-mix(in oklab, var(--paper) 88%, transparent);
    backdrop-filter: blur(14px);
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow: 0 12px 32px -12px color-mix(in oklab, var(--ink) 30%, transparent);
    animation: float-card 6s ease-in-out infinite;
  }
  .hero-card-tl { top: 8%; left: -6%; animation-delay: -1s; }
  .hero-card-br { bottom: 10%; right: -6%; animation-delay: -3.5s; }
  @keyframes float-card {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
  .hero-card-icon {
    width: 38px; height: 38px; flex-shrink: 0;
    border-radius: 10px;
    background: color-mix(in oklab, var(--amber) 12%, var(--paper));
    color: var(--amber);
    display: flex; align-items: center; justify-content: center;
  }
  .hero-card-icon svg { width: 20px; height: 20px; }
  .hero-card-label {
    font-size: 11px; font-weight: 500;
    letter-spacing: 0.4px; text-transform: uppercase;
    color: var(--muted); margin-bottom: 2px;
  }
  .hero-card-value {
    font-size: 15px; font-weight: 600; color: var(--ink);
    letter-spacing: -0.2px;
  }

  /* ====== Sections ====== */
  section { padding: 96px 32px; }
  .container { max-width: 1200px; margin: 0 auto; }
  .section-head { max-width: 720px; margin-bottom: 56px; }
  .section-head h2 {
    font-size: clamp(36px, 4vw, 56px);
    font-weight: 600;
    letter-spacing: -1.5px;
    line-height: 1.05;
    margin-bottom: 16px;
  }
  .section-head p {
    font-size: 18px; color: var(--muted);
  }

  /* Mission */
  .mission { background: var(--cream); }
  .mission-text {
    max-width: 820px;
    font-size: clamp(22px, 2.4vw, 32px);
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: -0.5px;
  }
  .mission-text em {
    color: var(--amber); font-style: normal; font-weight: 600;
  }

  /* Actions */
  .actions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .action-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 20px;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .3s, border-color .3s;
  }
  .action-card:hover {
    transform: translateY(-4px);
    border-color: var(--ink);
  }
  .action-placeholder {
    aspect-ratio: 4 / 3;
    background: var(--cream);
    background-image:
      repeating-linear-gradient(
        45deg,
        transparent 0 14px,
        rgba(31,26,20,0.04) 14px 15px
      );
    display: flex; align-items: center; justify-content: center;
    border-bottom: 1px solid var(--line);
    position: relative;
  }
  .action-placeholder span {
    font-family: 'Archivo', monospace;
    font-size: 11px; font-weight: 500;
    letter-spacing: 1px;
    color: var(--muted);
    text-transform: uppercase;
    background: var(--paper);
    padding: 6px 12px;
    border-radius: 4px;
    border: 1px solid var(--line);
  }
  .action-body { padding: 28px; }
  .action-num {
    font-size: 12px; font-weight: 600;
    color: var(--amber);
    letter-spacing: 1.2px;
    margin-bottom: 10px;
  }
  .action-card h3 {
    font-size: 26px; font-weight: 600;
    letter-spacing: -0.6px;
    margin-bottom: 10px;
  }
  .action-card p {
    color: var(--muted); font-size: 15px;
  }

  /* Bandeau */
  .quote {
    background: var(--terracotta);
    color: var(--paper);
    padding: 120px 32px;
  }
  .quote-inner { max-width: 1000px; margin: 0 auto; text-align: center; }
  .quote blockquote {
    font-size: clamp(28px, 3.4vw, 44px);
    font-weight: 500;
    letter-spacing: -0.8px;
    line-height: 1.25;
  }
  .quote cite {
    display: block;
    margin-top: 28px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    font-style: normal;
    opacity: 0.7;
  }

  /* Donate */
  .donate {
    padding: 120px 32px;
    background: var(--paper);
  }
  .section-head.text-center {
    margin: 0 auto 56px;
    text-align: center;
  }
  .donate-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1000px;
    margin: 0 auto 48px;
  }
  .donate-split-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    max-width: 800px;
    margin: 0 auto;
  }
  .donate-card {
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: 20px;
    padding: 40px 32px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .3s;
  }
  .donate-card:hover {
    transform: translateY(-4px);
  }
  .donate-card.highlight {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
  }
  .donate-card.highlight .impact {
    color: rgba(251,246,236,0.7);
  }
  .donate-card.highlight .btn-primary {
    background: var(--amber);
    color: var(--paper);
  }
  .donate-card.highlight .btn-primary:hover {
    background: var(--paper);
    color: var(--ink);
  }
  .donate-card .cause {
    font-size: clamp(26px, 3vw, 36px);
    font-weight: 700;
    letter-spacing: -1px;
    margin-bottom: 16px;
    line-height: 1.15;
  }
  .donate-card.highlight .cause {
    color: var(--amber);
  }
  .donate-card .impact {
    font-size: 15px;
    color: var(--muted);
    margin-bottom: 32px;
    flex-grow: 1;
  }
  .donate-custom {
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
    padding-top: 40px;
    border-top: 1px solid var(--line);
  }
  .donate-custom p {
    color: var(--muted);
    margin-bottom: 20px;
  }

  /* ====== Adhésion (Devenir membre) ====== */
  .member {
    background: var(--cream);
    padding: 120px 32px;
    position: relative;
    overflow: hidden;
  }
  .member::before {
    content: "";
    position: absolute; inset: 0;
    background-image:
      linear-gradient(var(--line) 1px, transparent 1px),
      linear-gradient(90deg, var(--line) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: radial-gradient(ellipse 60% 70% at 80% 20%, black 0%, transparent 65%);
    -webkit-mask-image: radial-gradient(ellipse 60% 70% at 80% 20%, black 0%, transparent 65%);
    opacity: 0.35;
    pointer-events: none;
  }
  .member-grid {
    display: grid;
    grid-template-columns: 1fr 1.05fr;
    gap: 72px;
    align-items: center;
    position: relative;
  }
  .member-visual {
    position: relative;
    aspect-ratio: 4 / 5;
    isolation: isolate;
  }
  .member-visual-halo {
    position: absolute;
    inset: -14%;
    z-index: 0;
    background:
      radial-gradient(circle at 30% 30%, color-mix(in oklab, var(--honey) 55%, transparent) 0%, transparent 55%),
      radial-gradient(circle at 75% 70%, color-mix(in oklab, var(--amber) 45%, transparent) 0%, transparent 60%);
    filter: blur(48px);
    opacity: 0.85;
    pointer-events: none;
    animation: halo-pulse 7s ease-in-out infinite;
  }
  @keyframes halo-pulse {
    0%, 100% { transform: scale(1) rotate(0deg); opacity: 0.75; }
    50% { transform: scale(1.08) rotate(8deg); opacity: 1; }
  }
  .member-visual-frame {
    position: relative;
    z-index: 1;
    width: 100%; height: 100%;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(160deg, var(--paper), color-mix(in oklab, var(--honey) 14%, var(--cream)));
    border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
    box-shadow:
      0 30px 60px -30px color-mix(in oklab, var(--ink) 35%, transparent),
      inset 0 1px 0 color-mix(in oklab, white 40%, transparent);
    display: flex; align-items: center; justify-content: center;
    animation: float 8s ease-in-out infinite;
  }
  .member-visual-frame::before {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(circle at 20% 10%, color-mix(in oklab, var(--honey) 22%, transparent), transparent 55%);
    pointer-events: none; z-index: 1;
  }
  .member-visual-frame img {
    width: 100%; height: 100%;
    object-fit: cover;
    position: relative;
  }
  .member-visual.is-empty .member-visual-frame {
    background-image:
      repeating-linear-gradient(
        45deg,
        transparent 0 14px,
        rgba(31,26,20,0.05) 14px 15px
      ),
      linear-gradient(160deg, var(--paper), color-mix(in oklab, var(--honey) 14%, var(--cream)));
  }
  .member-visual-tag {
    position: absolute;
    bottom: 18px; left: 18px;
    font-size: 11px; font-weight: 500;
    letter-spacing: 1px; text-transform: uppercase;
    color: var(--muted);
    background: var(--paper);
    padding: 6px 12px; border-radius: 4px;
    border: 1px solid var(--line);
    opacity: 0;
    transition: opacity .2s;
    z-index: 2;
  }
  .member-visual.is-empty .member-visual-tag { opacity: 1; }

  .member-card {
    position: absolute;
    z-index: 3;
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px;
    background: color-mix(in oklab, var(--paper) 88%, transparent);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow:
      0 12px 32px -12px color-mix(in oklab, var(--ink) 30%, transparent),
      0 0 0 1px color-mix(in oklab, var(--honey) 14%, transparent),
      0 0 40px -8px color-mix(in oklab, var(--honey) 50%, transparent);
    animation: float-card 6s ease-in-out infinite;
  }
  .member-card::before {
    content: "";
    position: absolute; inset: -2px;
    border-radius: 18px;
    background: linear-gradient(135deg, color-mix(in oklab, var(--honey) 40%, transparent), transparent 60%);
    z-index: -1;
    filter: blur(12px);
    opacity: 0.6;
  }
  .member-card-tl { top: 6%; left: -10%; animation-delay: -1s; }
  .member-card-br { bottom: 8%; right: -10%; animation-delay: -3.5s; }
  .member-card-icon {
    width: 38px; height: 38px; flex-shrink: 0;
    border-radius: 10px;
    background: color-mix(in oklab, var(--amber) 12%, var(--paper));
    color: var(--amber);
    display: flex; align-items: center; justify-content: center;
  }
  .member-card-icon svg { width: 20px; height: 20px; }
  .member-card-label {
    font-size: 11px; font-weight: 500;
    letter-spacing: 0.4px; text-transform: uppercase;
    color: var(--muted); margin-bottom: 2px;
  }
  .member-card-value {
    font-size: 15px; font-weight: 600; color: var(--ink);
    letter-spacing: -0.2px;
  }
  .member-content h2 {
    font-size: clamp(36px, 4.2vw, 56px);
    font-weight: 700;
    letter-spacing: -1.6px;
    line-height: 1.05;
    margin-bottom: 22px;
  }
  .member-content h2 .accent-soft {
    background: linear-gradient(120deg, var(--amber), var(--honey) 60%, var(--terracotta));
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .member-lede {
    font-size: 19px;
    color: var(--muted);
    margin-bottom: 28px;
    max-width: 520px;
  }
  .member-perks {
    list-style: none;
    margin: 0 0 36px;
    padding: 0;
    display: flex; flex-direction: column; gap: 12px;
  }
  .member-perks li {
    position: relative;
    padding-left: 28px;
    font-size: 15px;
    color: var(--ink);
    line-height: 1.5;
  }
  .member-perks li::before {
    content: "";
    position: absolute;
    left: 0; top: 9px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--amber);
    box-shadow: 0 0 0 4px color-mix(in oklab, var(--amber) 18%, transparent);
  }
  .member-perks li strong { font-weight: 600; }
  .member-note {
    margin-top: 16px;
    font-size: 12px;
    color: var(--muted);
    letter-spacing: 0.3px;
  }

  @media (max-width: 900px) {
    .member { padding: 80px 24px; }
    .member-grid { grid-template-columns: 1fr; gap: 40px; }
    .member-visual { aspect-ratio: 4 / 3; max-width: 520px; margin: 0 auto; width: 100%; }
    .member-card-tl { left: -2%; top: 4%; }
    .member-card-br { right: -2%; bottom: 6%; }
  }

  /* Rejoins-nous */
  .join { background: var(--ink); color: var(--paper); }
  .join .section-head h2 { color: var(--paper); }
  .join .section-head p { color: rgba(251,246,236,0.65); }
  .social-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
  }
  .social-card {
    background: rgba(251,246,236,0.04);
    border: 1px solid rgba(251,246,236,0.12);
    border-radius: 16px;
    padding: 28px;
    transition: all .25s;
    display: flex; flex-direction: column; gap: 14px;
    min-height: 180px;
  }
  .social-card:hover {
    background: var(--amber);
    border-color: var(--amber);
    color: var(--paper);
    transform: translateY(-3px);
  }
  .social-icon {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
  }
  .social-icon svg { width: 100%; height: 100%; }
  .social-card .label {
    font-size: 11px; font-weight: 600;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    opacity: 0.55;
  }
  .social-card .handle {
    font-size: 20px; font-weight: 600;
    letter-spacing: -0.4px;
    margin-top: auto;
  }

  /* Footer */
  footer {
    background: var(--ink);
    color: rgba(251,246,236,0.55);
    padding: 48px 32px;
    border-top: 1px solid rgba(251,246,236,0.08);
  }
  .footer-inner {
    max-width: 1200px; margin: 0 auto;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 20px;
    font-size: 13px;
  }
  .footer-inner img { height: 22px; opacity: 0.85; }

  /* Responsive */
  @media (max-width: 900px) {
    .hero { grid-template-columns: 1fr; padding: 80px 24px 56px; gap: 48px; }
    .hero-visual { max-width: 420px; margin: 0 auto; width: 100%; }
    .hero h1 { letter-spacing: -1.8px; }
    .hero-card-tl { left: -2%; top: 4%; }
    .hero-card-br { right: -2%; bottom: 6%; }
    .hero-trust { gap: 16px; }
    .hero-trust-divider { display: none; }
    .actions-grid { grid-template-columns: 1fr; }
    .social-grid { grid-template-columns: repeat(2, 1fr); }
    .donate-grid { grid-template-columns: 1fr; gap: 16px; }
    .donate-split-grid { grid-template-columns: 1fr; gap: 16px; }
    .nav-links a:not(.btn) { display: none; }
    section { padding: 72px 24px; }
    .quote { padding: 96px 24px; }
  }
  @media (max-width: 480px) {
    .social-grid { grid-template-columns: 1fr; }
  }

/* ===== Action page ===== */
.action-hero {
  padding: 80px 32px 64px;
  border-bottom: 1px solid var(--line);
}
.action-hero .container {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: center;
}
.action-hero .num {
  font-size: 13px; font-weight: 600;
  color: var(--amber); letter-spacing: 1.4px;
  margin-bottom: 18px;
}
.action-hero h1 {
  font-size: clamp(48px, 6vw, 80px);
  font-weight: 700;
  letter-spacing: -2.5px;
  line-height: 0.98;
  margin-bottom: 22px;
}
.action-hero p {
  font-size: 19px; color: var(--muted); max-width: 480px;
}
.action-visual {
  aspect-ratio: 4 / 5;
  border-radius: 24px;
  background-image:
    repeating-linear-gradient(
      45deg,
      transparent 0 14px,
      rgba(31,26,20,0.05) 14px 15px
    );
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
}
.action-visual span {
  font-size: 11px; font-weight: 500;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--muted);
  background: var(--paper);
  padding: 8px 14px; border-radius: 4px;
  border: 1px solid var(--line);
}
.action-visual.has-image {
  background-image: none;
  padding: 0;
  overflow: hidden;
}
.action-visual.has-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.action-body { padding: 96px 32px; }
.action-body .container { max-width: 1200px; margin: 0 auto; }
.action-body-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: start;
}
.action-body-grid .prose { margin: 0; }
.action-body-visual.action-visual {
  position: sticky; top: 120px;
  order: -1; /* Place le visuel à gauche */
}

.prose { max-width: 720px; margin: 0 auto; }
.prose h2 {
  font-size: clamp(32px, 3.6vw, 44px);
  font-weight: 600; letter-spacing: -1px;
  line-height: 1.1; margin: 56px 0 18px;
}
.prose h2:first-child { margin-top: 0; }
.prose p {
  font-size: 18px; color: var(--ink);
  margin-bottom: 16px;
}
.prose p.lede {
  font-size: 22px; color: var(--ink);
  font-weight: 500;
  letter-spacing: -0.3px;
  line-height: 1.4;
  margin-bottom: 32px;
}

.action-stats {
  background: var(--cream);
  padding: 80px 32px;
}
.stats-grid {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.stat .num {
  font-size: clamp(48px, 5vw, 72px);
  font-weight: 700;
  color: var(--amber);
  letter-spacing: -2px;
  line-height: 1;
}
.stat .label {
  font-size: 14px; color: var(--muted);
  margin-top: 10px;
}

.action-reviews {
  background: var(--cream);
  padding: 80px 32px;
}
.reviews-title {
  text-align: center;
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 600;
  letter-spacing: -0.8px;
  margin-bottom: 48px;
}
.reviews-grid {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.review-card {
  background: var(--paper);
  padding: 32px;
  border-radius: 16px;
  border: 1px solid var(--line);
  display: flex; flex-direction: column; justify-content: space-between;
}
.review-text {
  font-size: 16px; color: var(--ink);
  font-style: italic;
  margin-bottom: 24px;
}
.review-author {
  font-size: 14px; font-weight: 600; color: var(--amber);
}

.cta-band {
  background: var(--terracotta);
  color: var(--paper);
  padding: 96px 32px;
  text-align: center;
}
.cta-band h3 {
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 600;
  letter-spacing: -0.8px;
  line-height: 1.2;
  margin-bottom: 28px;
  max-width: 720px;
  margin-left: auto; margin-right: auto;
}
.cta-band .btn-primary {
  background: var(--paper); color: var(--ink);
}
.cta-band .btn-primary:hover {
  background: var(--amber); color: var(--paper);
}

.back-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600;
  color: var(--muted);
  letter-spacing: 0.4px;
  margin-bottom: 40px;
}
.back-link:hover { color: var(--ink); }

@media (max-width: 900px) {
  .action-hero .container { grid-template-columns: 1fr; padding: 0; }
  .action-hero { padding: 56px 24px 48px; }
  .action-body { padding: 72px 24px; }
  .action-body-grid { grid-template-columns: 1fr; gap: 48px; }
  .action-body-visual.action-visual {
    position: static;
    aspect-ratio: 16 / 9;
    order: 1; /* Sur mobile, le visuel repasse sous le texte */
  }
  .stats-grid { grid-template-columns: 1fr; gap: 24px; }
  .reviews-grid { grid-template-columns: 1fr; gap: 24px; }
}
