
  /* ============================================================
   * 110 chemin Larocque · Groupe RPA
   * Direction éditoriale, magazine d'architecture.
   * Brand book : Kepler Italic + Safiro · doré, bleu eau, crème
   * ============================================================ */
  :root {
    /* Beige / crème — la couleur secondaire de la marque */
    --cream:        #ece6d5;
    --cream-soft:   #f3eee0;
    --cream-warm:   #e2d8be;
    --cream-deep:   #d6c9a4;

    /* Vert sapin — la couleur primaire de la marque (logo) */
    --vert:         #113129;        /* exact RGB du logo */
    --vert-deep:    #0a1f18;        /* contraste max */
    --vert-mid:     #1f3d2f;
    --vert-soft:    #4a7a64;        /* accent lisible sur crème */
    --vert-grad:    linear-gradient(135deg, #1f3d2f 0%, #113129 60%, #0a1f18 100%);
    --vert-grad-h:  linear-gradient(90deg, #1f3d2f 0%, #113129 100%);

    /* Alias historiques (gold/blue) remappés vers la palette RPA */
    --gold:         #4a7a64;
    --gold-light:   #d6c9a4;
    --gold-deep:    #2d5848;
    --gold-grad:    linear-gradient(135deg, #1f3d2f 0%, #113129 60%, #0a1f18 100%);
    --gold-grad-h:  linear-gradient(90deg, #1f3d2f 0%, #113129 100%);
    --blue:         #1f3d2f;
    --blue-deep:    #0a1f18;
    --blue-mid:     #2d5848;

    /* Encre */
    --ink:          #0d1f1a;
    --ink-mute:     rgba(13, 31, 26, 0.62);
    --ink-faint:    rgba(13, 31, 26, 0.14);
    --ink-line:     rgba(13, 31, 26, 0.22);

    --on-dark:      #ece6d5;
    --on-dark-mute: rgba(236, 230, 213, 0.66);
    --on-dark-line: rgba(236, 230, 213, 0.18);

    /* Type */
    --serif: 'Cormorant Garamond', 'Kepler Std', 'EB Garamond', Georgia, serif;
    --sans:  'Plus Jakarta Sans', 'Safiro', -apple-system, BlinkMacSystemFont, sans-serif;

    --container-max:  1440px;
    --container-px:   56px;
    --container-px-m: 24px;
  }

  .projet-larocque-page * { box-sizing: border-box; margin: 0; padding: 0; }
  /* html { scroll-behavior: smooth; } retiré — conflit avec Lenis (smooth
     scroll JS de Jeg Elementor Kit) qui crée un glitch de scroll. Lenis
     gère déjà l'animation, le browser n'a pas à essayer en parallèle. */
  .projet-larocque-page {
    font-family: var(--sans);
    background: var(--cream);
    color: var(--ink);
    font-size: 17px;
    line-height: 1.7;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    /* overflow-x: hidden retiré — convertit overflow-y en auto et
       transforme le <main> en scroll container coincé. Le site a déjà
       overflow-x: hidden sur html, body via Jeg Elementor Kit. */
  }
  .projet-larocque-page img { display: block; max-width: 100%; }
  .projet-larocque-page a { color: inherit; }

  .projet-larocque-page .container{
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-px);
  }
  .projet-larocque-page .container-wide{
    max-width: 1720px;
    margin: 0 auto;
    padding: 0 var(--container-px);
  }

  /* ============================================================
   * Type primitives — italic serif rules
   * ============================================================ */
  .projet-larocque-page .serif{ font-family: var(--serif); font-style: italic; }
  .projet-larocque-page .display{ font-family: var(--serif); font-style: italic; font-weight: 500; line-height: 0.96; letter-spacing: -0.012em; }
  .projet-larocque-page .display-lg{ font-size: clamp(64px, 9vw, 168px); }
  .projet-larocque-page .display-md{ font-size: clamp(48px, 6.5vw, 104px); }
  .projet-larocque-page .display-sm{ font-size: clamp(34px, 4.2vw, 64px); }

  .projet-larocque-page p { font-size: 17px; line-height: 1.72; color: var(--ink-mute); text-wrap: pretty; }
  .projet-larocque-page p + p { margin-top: 18px; }
  .projet-larocque-page strong { font-weight: 500; color: var(--ink); }

  .projet-larocque-page .lede{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    font-size: clamp(22px, 2.4vw, 32px);
    line-height: 1.32;
    letter-spacing: -0.006em;
    color: var(--ink);
    text-wrap: balance;
  }

  .projet-larocque-page .dot{ color: var(--gold); font-style: italic; }
  .projet-larocque-page .gold-text{
    background: var(--gold-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  /* Editorial chapter marker — Roman numerals */
  .projet-larocque-page .chapter-num{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(72px, 9vw, 144px);
    line-height: 0.85;
    background: var(--gold-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    display: block;
    letter-spacing: -0.02em;
  }
  .projet-larocque-page .chapter-label{
    font-family: var(--sans);
    font-size: 11px;
    letter-spacing: 0.36em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-weight: 500;
    margin-top: 24px;
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .projet-larocque-page .chapter-label::before{
    content: '';
    display: inline-block;
    width: 28px;
    height: 1px;
    background: var(--gold);
  }
  .projet-larocque-page section.dark .chapter-label{ color: var(--on-dark-mute); }
  .projet-larocque-page section.dark .chapter-label::before{ background: var(--gold-light); }

  /* ============================================================
   * NAV — minimal editorial header
   * ============================================================ */
  .projet-larocque-page .nav{
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(236, 230, 213, 0.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--ink-faint);
    padding: 20px 0;
  }
  .projet-larocque-page .nav-inner{
    max-width: 1720px;
    margin: 0 auto;
    padding: 0 var(--container-px);
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 32px;
  }
  .projet-larocque-page .brand{
    display: inline-flex;
    align-items: center;
    text-decoration: none;
  }
  .projet-larocque-page .nav-links{
    display: flex;
    gap: 36px;
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 500;
    justify-self: center;
  }
  .projet-larocque-page .nav-links a{
    color: var(--ink-mute);
    text-decoration: none;
    transition: color 0.2s;
    padding-bottom: 2px;
  }
  .projet-larocque-page .nav-links a:hover{ color: var(--ink); }
  .projet-larocque-page .nav-links a.current{
    color: var(--ink);
    border-bottom: 1px solid var(--gold);
  }
  .projet-larocque-page .nav-actions{
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 24px;
  }
  .projet-larocque-page .nav-lang{
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--ink-mute);
    text-decoration: none;
    font-weight: 500;
  }
  .projet-larocque-page .nav-cta{
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--ink);
    text-decoration: none;
    border: 1px solid var(--ink);
    padding: 11px 22px;
    border-radius: 100px;
    transition: all 0.25s;
  }
  .projet-larocque-page .nav-cta:hover{ background: var(--ink); color: var(--cream); }

  /* ============================================================
   * HERO — full-bleed photo + editorial overlay
   * ============================================================ */
  .projet-larocque-page .hero{
    position: relative;
    min-height: 92vh;
    overflow: hidden;
    background: var(--blue-deep);
    color: var(--on-dark);
  }
  .projet-larocque-page .hero-bg{
    position: absolute;
    inset: 0;
    z-index: 1;
  }
  .projet-larocque-page .hero-bg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 65%;
    filter: brightness(0.78) saturate(1.05);
  }
  .projet-larocque-page .hero-bg::after{
    content: '';
    position: absolute;
    inset: 0;
    background:
      linear-gradient(180deg, rgba(10, 31, 24, 0.25) 0%, rgba(10, 31, 24, 0.1) 30%, rgba(10, 31, 24, 0.7) 100%),
      linear-gradient(90deg, rgba(10, 31, 24, 0.7) 0%, rgba(10, 31, 24, 0) 55%);
  }

  .projet-larocque-page .hero-inner{
    position: relative;
    z-index: 2;
    min-height: 92vh;
    display: grid;
    grid-template-rows: auto 1fr auto;
    padding-top: 56px;
    padding-bottom: 48px;
  }

  .projet-larocque-page .hero-top{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
  }
  .projet-larocque-page .hero-crumb{
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    font-weight: 500;
  }
  .projet-larocque-page .hero-crumb .arrow{ margin: 0 12px; opacity: 0.5; }
  .projet-larocque-page .hero-status{
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 9px 20px;
    border: 1px solid var(--gold-light);
    border-radius: 100px;
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--gold-light);
    background: rgba(10, 31, 24, 0.45);
    backdrop-filter: blur(8px);
  }
  .projet-larocque-page .hero-status::before{
    content: '';
    width: 7px; height: 7px;
    background: var(--gold-light);
    border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(214, 201, 164, 0.6);
    animation: pulse 2.5s infinite;
  }
  @keyframes pulse {
    0%   { box-shadow: 0 0 0 0 rgba(214, 201, 164, 0.6); }
    70%  { box-shadow: 0 0 0 12px rgba(214, 201, 164, 0); }
    100% { box-shadow: 0 0 0 0 rgba(214, 201, 164, 0); }
  }

  .projet-larocque-page .hero-center{
    align-self: end;
    max-width: 1300px;
  }
  .projet-larocque-page .hero-h1{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(64px, 11vw, 200px);
    line-height: 0.88;
    letter-spacing: -0.025em;
    color: var(--on-dark);
    margin-bottom: 32px;
  }
  .projet-larocque-page .hero-h1 .num{
    font-family: var(--sans);
    font-style: normal;
    font-weight: 200;
    letter-spacing: -0.05em;
    color: var(--gold-light);
    font-size: 0.78em;
  }
  .projet-larocque-page .hero-h1 .nl{ display: block; }
  .projet-larocque-page .hero-h1 .dot{ color: var(--gold-light); }

  .projet-larocque-page .hero-lede{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    font-size: clamp(20px, 2vw, 28px);
    line-height: 1.4;
    color: var(--on-dark);
    max-width: 28ch;
    margin-top: 8px;
  }

  .projet-larocque-page .hero-bottom{
    display: grid;
    grid-template-columns: 1.5fr repeat(4, 1fr);
    gap: 24px;
    align-items: end;
    border-top: 1px solid var(--on-dark-line);
    padding-top: 32px;
  }
  .projet-larocque-page .hero-scroll{
    font-size: 10px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .projet-larocque-page .hero-scroll .line{
    display: inline-block;
    width: 64px;
    height: 1px;
    background: var(--gold-light);
    position: relative;
    overflow: hidden;
  }
  .projet-larocque-page .hero-scroll .line::after{
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 50%; height: 100%;
    background: rgba(236, 230, 213, 0.95);
    animation: slide 3s infinite ease-in-out;
  }
  @keyframes slide { 50% { left: 100%; } 100% { left: 100%; } }

  .projet-larocque-page .hero-stat{
    text-align: right;
  }
  .projet-larocque-page .hero-stat .val{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(32px, 3.4vw, 56px);
    line-height: 1;
    color: var(--on-dark);
    letter-spacing: -0.02em;
    margin-bottom: 8px;
  }
  .projet-larocque-page .hero-stat .val .unit{
    font-family: var(--sans);
    font-style: normal;
    font-weight: 300;
    font-size: 0.4em;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    margin-left: 6px;
    vertical-align: 6px;
  }
  .projet-larocque-page .hero-stat .label{
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    font-weight: 500;
  }

  /* ============================================================
   * Chapter I — Le projet (cream, double col)
   * ============================================================ */
  .projet-larocque-page section{ position: relative; padding: 140px 0; }
  .projet-larocque-page section.cream{ background: var(--cream); }
  .projet-larocque-page section.cream-soft{ background: var(--cream-soft); color: var(--ink); }
  .projet-larocque-page section.cream-warm{ background: var(--cream-warm); color: var(--ink); }
  .projet-larocque-page section.dark{ background: var(--blue-deep); color: var(--on-dark); }

  .projet-larocque-page section.dark p{ color: var(--on-dark-mute); }
  .projet-larocque-page section.dark strong{ color: var(--on-dark); }

  /* Lisibilité — chiffres romains et marqueurs sur fond foncé :
     le gold-grad d'origine est en tons verts, donc invisible sur le vert sapin.
     On le remplace par un dégradé crème pour garantir le contraste. */
  .projet-larocque-page section.dark .chapter-num,
  .projet-larocque-page section.dark .demarche-card .num,
  .projet-larocque-page section.cta .chapter-num,
  .projet-larocque-page section.cta .cta-head .chapter-num,
  .projet-larocque-page .quote-band .chapter-num{
    background: linear-gradient(135deg, var(--cream) 0%, var(--gold-light) 60%, var(--cream-deep) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
  .projet-larocque-page section.dark .gold-rule,
  .projet-larocque-page section.cta .gold-rule,
  .projet-larocque-page .quote-band .gold-rule{
    background: var(--gold-light);
  }
  .projet-larocque-page .quote-band .chapter-label{ color: var(--on-dark-mute); }
  .projet-larocque-page .quote-band .chapter-label::before{ background: var(--gold-light); }

  /* Chapter I */
  .projet-larocque-page .chapter-1{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 120px;
  }
  .projet-larocque-page .chapter-1 .body p:first-of-type{
    margin-bottom: 32px;
  }

  /* Decorative gold rule */
  .projet-larocque-page .gold-rule{
    display: block;
    width: 80px;
    height: 1px;
    background: var(--gold-grad-h);
    margin: 32px 0;
  }

  /* ============================================================
   * Editorial pullquote band — Chapter II
   * ============================================================ */
  .projet-larocque-page .quote-band{
    background: var(--blue-deep);
    color: var(--on-dark);
    padding: 0;
    overflow: hidden;
    position: relative;
  }
  .projet-larocque-page .quote-band-grid{
    display: grid;
    grid-template-columns: 5fr 7fr;
    min-height: 80vh;
  }
  .projet-larocque-page .quote-band-image{
    position: relative;
    background: var(--blue-deep);
    min-height: 540px;
  }
  .projet-larocque-page .quote-band-image img{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.85) saturate(1.05);
  }
  .projet-larocque-page .quote-band-image-tag{
    position: absolute;
    bottom: 28px;
    left: 28px;
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--on-dark);
    font-weight: 500;
    background: rgba(10, 31, 24, 0.72);
    padding: 9px 16px;
    backdrop-filter: blur(6px);
    z-index: 2;
  }
  .projet-larocque-page .quote-band-text{
    padding: 120px 96px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .projet-larocque-page .quote-band-text .chapter-label{ color: var(--gold-light); margin-bottom: 32px; margin-top: 0; }
  .projet-larocque-page .pullquote{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(32px, 3.6vw, 56px);
    line-height: 1.12;
    letter-spacing: -0.015em;
    color: var(--on-dark);
    margin-bottom: 32px;
    text-wrap: balance;
  }
  .projet-larocque-page .pullquote .gold-emph{ color: var(--gold-light); }
  .projet-larocque-page .pullquote::before{
    content: '«';
    color: var(--gold-light);
    font-size: 1.3em;
    line-height: 0;
    margin-right: 0.1em;
    vertical-align: -0.15em;
  }
  .projet-larocque-page .pullquote::after{
    content: '»';
    color: var(--gold-light);
    margin-left: 0.1em;
  }
  .projet-larocque-page .pullquote-credit{
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--on-dark-mute);
    font-weight: 500;
  }
  .projet-larocque-page .pullquote-credit::before{
    content: '';
    display: inline-block;
    width: 20px;
    height: 1px;
    background: var(--gold-light);
    margin-right: 14px;
    vertical-align: middle;
  }

  /* ============================================================
   * Chapter III — Programme (3-col cards over cream)
   * ============================================================ */
  .projet-larocque-page .chapter-3{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 120px;
    margin-bottom: 96px;
  }
  .projet-larocque-page .programme-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .projet-larocque-page .programme-card{
    background: var(--cream-soft);
    border: 1px solid var(--ink-faint);
    padding: 48px 40px 44px;
    display: flex;
    flex-direction: column;
    min-height: 480px;
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
  }
  .projet-larocque-page .programme-card::before{
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 3px;
    background: var(--gold-grad-h);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.5s ease;
  }
  .projet-larocque-page .programme-card:hover::before{ transform: scaleX(1); }
  .projet-larocque-page .programme-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 30px 70px rgba(13, 31, 26, 0.12);
  }
  .projet-larocque-page .programme-card .marker{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 80px;
    line-height: 0.85;
    background: var(--gold-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 36px;
    display: block;
    letter-spacing: -0.02em;
  }
  .projet-larocque-page .programme-card h3{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 32px;
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--ink);
    margin-bottom: 18px;
  }
  .projet-larocque-page .programme-card p{
    font-size: 15px;
    line-height: 1.65;
    flex: 1;
  }
  .projet-larocque-page .programme-list{
    list-style: none;
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--ink-faint);
  }
  .projet-larocque-page .programme-list li{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 16px;
    padding: 8px 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--ink);
  }
  .projet-larocque-page .programme-list li .em{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    color: var(--gold-deep);
    font-size: 17px;
  }

  /* ============================================================
   * Building section SVG — schematic floor diagram
   * ============================================================ */
  .projet-larocque-page .floors{
    margin-top: 100px;
    padding-top: 96px;
    border-top: 1px solid var(--ink-faint);
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 96px;
    align-items: center;
  }
  .projet-larocque-page .floors-svg{
    width: 100%;
    height: auto;
  }
  .projet-larocque-page .floors h3{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 36px;
    line-height: 1.05;
    letter-spacing: -0.015em;
    margin-bottom: 18px;
  }

  /* ============================================================
   * Full-bleed image — between chapters
   * ============================================================ */
  .projet-larocque-page .interlude{
    position: relative;
    height: 80vh;
    min-height: 540px;
    overflow: hidden;
  }
  .projet-larocque-page .interlude img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .projet-larocque-page .interlude-overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(10, 31, 24, 0.65) 0%, rgba(10, 31, 24, 0.15) 60%);
    display: flex;
    align-items: flex-end;
    padding: 0 0 88px 0;
  }
  .projet-larocque-page .interlude-overlay .container{ color: var(--on-dark); }
  .projet-larocque-page .interlude-meta{
    font-family: var(--sans);
    font-size: 10px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--gold-light);
    font-weight: 500;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .projet-larocque-page .interlude-meta::before{
    content: '';
    width: 28px; height: 1px;
    background: var(--gold-light);
    display: inline-block;
  }
  .projet-larocque-page .interlude h2{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(42px, 5.4vw, 88px);
    line-height: 0.98;
    letter-spacing: -0.015em;
    color: var(--on-dark);
    max-width: 18ch;
    text-wrap: balance;
  }
  .projet-larocque-page .interlude h2 .dot{ color: var(--gold-light); }

  /* ============================================================
   * Chapter IV — Emplacement (map + features)
   * ============================================================ */
  .projet-larocque-page .chapter-4{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 96px;
    align-items: start;
  }
  .projet-larocque-page .empl-feature-list{
    list-style: none;
    border-top: 1px solid var(--ink-line);
  }
  .projet-larocque-page .empl-feature-list li{
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 28px;
    align-items: baseline;
    padding: 28px 0;
    border-bottom: 1px solid var(--ink-line);
  }
  .projet-larocque-page .empl-num{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    font-size: 22px;
    color: var(--gold);
    letter-spacing: -0.02em;
    min-width: 38px;
  }
  .projet-larocque-page .empl-name{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 24px;
    line-height: 1.15;
    color: var(--ink);
    letter-spacing: -0.012em;
  }
  .projet-larocque-page .empl-name small{
    display: block;
    font-family: var(--sans);
    font-style: normal;
    font-weight: 400;
    font-size: 13px;
    letter-spacing: 0;
    color: var(--ink-mute);
    margin-top: 6px;
  }
  .projet-larocque-page .empl-dist{
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-weight: 500;
    white-space: nowrap;
  }
  .projet-larocque-page .empl-map-wrap{
    position: relative;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border: 1px solid var(--ink-line);
  }
  .projet-larocque-page .empl-map-wrap img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .projet-larocque-page .empl-pin{
    position: absolute;
    top: 50%; left: 50%;
    width: 56px;
    height: 56px;
    transform: translate(-50%, -50%);
    pointer-events: none;
  }
  .projet-larocque-page .empl-pin .ring{
    position: absolute;
    inset: 0;
    border: 2px solid var(--gold-light);
    border-radius: 50%;
    animation: ring 2.4s infinite ease-out;
    opacity: 0;
  }
  .projet-larocque-page .empl-pin .ring:nth-child(2){ animation-delay: 0.8s; }
  .projet-larocque-page .empl-pin .dot{
    position: absolute;
    top: 50%; left: 50%;
    width: 14px; height: 14px;
    transform: translate(-50%, -50%);
    background: var(--gold-light);
    border: 2px solid var(--cream);
    border-radius: 50%;
  }
  @keyframes ring {
    0% { transform: scale(0.4); opacity: 0.9; }
    100% { transform: scale(1.4); opacity: 0; }
  }
  .projet-larocque-page .empl-pin-label{
    position: absolute;
    bottom: 22px;
    left: 22px;
    background: rgba(10, 31, 24, 0.72);
    color: var(--on-dark);
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    padding: 9px 14px;
    font-weight: 500;
    backdrop-filter: blur(6px);
  }

  /* ============================================================
   * Chapter V — Démarche (dark, 3 cards)
   * ============================================================ */
  .projet-larocque-page .demarche-head{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 120px;
    margin-bottom: 96px;
  }
  .projet-larocque-page .demarche-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 56px;
    padding-top: 56px;
    border-top: 1px solid var(--on-dark-line);
  }
  .projet-larocque-page .demarche-card .num{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 600;
    font-size: 40px;
    line-height: 1;
    background: var(--gold-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    display: block;
    margin-bottom: 24px;
  }
  .projet-larocque-page .demarche-card h3{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 28px;
    line-height: 1.15;
    color: var(--on-dark);
    letter-spacing: -0.012em;
    margin-bottom: 18px;
  }
  .projet-larocque-page .demarche-card p{ font-size: 15px; line-height: 1.65; }

  /* ============================================================
   * Chapter VI — Calendrier (vertical editorial timeline)
   * ============================================================ */
  .projet-larocque-page .calendrier-head{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 120px;
    margin-bottom: 80px;
  }
  .projet-larocque-page .calendrier{
    position: relative;
    border-top: 1px solid var(--ink-line);
  }
  .projet-larocque-page .cal-row{
    display: grid;
    grid-template-columns: 88px 1.4fr 1fr 180px;
    gap: 48px;
    align-items: center;
    padding: 36px 0;
    border-bottom: 1px solid var(--ink-line);
    transition: background 0.3s ease;
  }
  .projet-larocque-page .cal-row.current{
    background: var(--cream-soft);
    margin: 0 calc(-1 * var(--container-px));
    padding-left: var(--container-px);
    padding-right: var(--container-px);
  }
  .projet-larocque-page .cal-num{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 36px;
    line-height: 1;
    background: var(--gold-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
  .projet-larocque-page .cal-row.done .cal-num,
  .projet-larocque-page .cal-row.done .cal-phase{ opacity: 0.55; }
  .projet-larocque-page .cal-phase{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(24px, 2.6vw, 36px);
    line-height: 1.05;
    color: var(--ink);
    letter-spacing: -0.015em;
  }
  .projet-larocque-page .cal-desc{
    font-size: 14px;
    line-height: 1.6;
    color: var(--ink-mute);
  }
  .projet-larocque-page .cal-status{
    font-size: 10px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    padding: 9px 16px;
    border-radius: 100px;
    font-weight: 500;
    border: 1px solid var(--ink-line);
    color: var(--ink-mute);
    text-align: center;
    justify-self: end;
    white-space: nowrap;
  }
  .projet-larocque-page .cal-row.current .cal-status{
    background: var(--gold-grad);
    color: var(--ink);
    border-color: transparent;
  }

  /* ============================================================
   * Partenaires strip
   * ============================================================ */
  .projet-larocque-page .partners{
    background: var(--cream-warm);
    padding: 96px 0;
    color: var(--ink);
  }
  .projet-larocque-page .partners-inner{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 96px;
    align-items: center;
  }
  .projet-larocque-page .partners-label{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(32px, 3.4vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.015em;
    color: var(--ink);
    max-width: 8ch;
  }
  .projet-larocque-page .partners-list{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px;
    list-style: none;
    border-top: 1px solid var(--ink-line);
    padding-top: 36px;
  }
  .projet-larocque-page .partners-list dt{
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-weight: 500;
    margin-bottom: 14px;
  }
  .projet-larocque-page .partners-list dd{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 24px;
    line-height: 1.15;
    color: var(--ink);
    letter-spacing: -0.012em;
  }
  .projet-larocque-page .partners-list dd small{
    display: block;
    font-family: var(--sans);
    font-style: normal;
    font-weight: 400;
    font-size: 13px;
    color: var(--ink-mute);
    margin-top: 8px;
    letter-spacing: 0;
  }

  /* ============================================================
   * CTA — full bleed image w overlay + double card
   * ============================================================ */
  .projet-larocque-page .cta{
    position: relative;
    overflow: hidden;
    background: var(--blue-deep);
    color: var(--on-dark);
  }
  .projet-larocque-page .cta-bg{
    position: absolute;
    inset: 0;
    z-index: 0;
  }
  .projet-larocque-page .cta-bg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.55) saturate(0.95);
  }
  .projet-larocque-page .cta-bg::after{
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10, 31, 24, 0.6) 0%, rgba(10, 31, 24, 0.9) 100%);
  }
  .projet-larocque-page .cta-inner{
    position: relative;
    z-index: 1;
    padding: 140px 0 120px;
  }
  .projet-larocque-page .cta-head{
    text-align: center;
    max-width: 820px;
    margin: 0 auto 72px;
  }
  .projet-larocque-page .cta-head .chapter-num{ background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
  .projet-larocque-page .cta-head .chapter-label{ justify-content: center; color: var(--gold-light); }
  .projet-larocque-page .cta-head .chapter-label::before{ background: var(--gold-light); }
  .projet-larocque-page .cta-head h2{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(48px, 6vw, 96px);
    line-height: 0.98;
    letter-spacing: -0.018em;
    color: var(--on-dark);
    margin: 32px 0 28px;
  }
  .projet-larocque-page .cta-head h2 .dot{ color: var(--gold-light); }
  .projet-larocque-page .cta-head p{
    font-size: 19px;
    color: var(--on-dark-mute);
    max-width: 580px;
    margin: 0 auto;
  }
  .projet-larocque-page .cta-grid{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    max-width: 1080px;
    margin: 0 auto;
  }
  .projet-larocque-page .cta-card{
    background: rgba(236, 230, 213, 0.06);
    backdrop-filter: blur(12px);
    border: 1px solid var(--on-dark-line);
    padding: 56px 48px 48px;
    display: flex;
    flex-direction: column;
    min-height: 360px;
  }
  .projet-larocque-page .cta-card.featured{
    background: var(--cream);
    border-color: var(--cream-deep);
    color: var(--ink);
  }
  .projet-larocque-page .cta-card.featured .cta-tag{ color: rgba(13, 31, 26, 0.7); }
  .projet-larocque-page .cta-card.featured h3{ color: var(--ink); }
  .projet-larocque-page .cta-card.featured p{ color: rgba(13, 31, 26, 0.78); }
  .projet-larocque-page .cta-tag{
    font-size: 10px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--gold-light);
    font-weight: 500;
    margin-bottom: 32px;
  }
  .projet-larocque-page .cta-card h3{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(28px, 2.6vw, 38px);
    line-height: 1.05;
    letter-spacing: -0.015em;
    color: var(--on-dark);
    margin-bottom: 18px;
  }
  .projet-larocque-page .cta-card p{ color: var(--on-dark-mute); font-size: 15px; margin-bottom: 36px; flex: 1; }

  .projet-larocque-page .btn{
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 16px 26px;
    font-family: var(--sans);
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 500;
    text-decoration: none;
    border-radius: 100px;
    align-self: flex-start;
    transition: all 0.3s ease;
    border: 1px solid transparent;
  }
  .projet-larocque-page .btn-cream{
    background: var(--cream);
    color: var(--ink);
  }
  .projet-larocque-page .btn-cream:hover{ gap: 20px; background: var(--cream-soft); }
  .projet-larocque-page .btn-ink{
    background: var(--ink);
    color: var(--cream);
  }
  .projet-larocque-page .btn-ink:hover{ gap: 20px; }
  .projet-larocque-page .btn-outline{
    background: transparent;
    color: var(--on-dark);
    border-color: var(--on-dark-line);
  }
  .projet-larocque-page .btn-outline:hover{ border-color: var(--on-dark); gap: 20px; }
  .projet-larocque-page .btn .arrow{ font-size: 15px; }

  /* ============================================================
   * Footer
   * ============================================================ */
  .projet-larocque-page .footer{
    background: var(--vert-deep);
    color: var(--cream);
    padding: 96px 0 56px;
  }
  .projet-larocque-page .footer-inner{
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 120px;
    align-items: start;
    padding-bottom: 72px;
    border-bottom: 1px solid rgba(236, 230, 213, 0.18);
  }
/* footer-brand-logo styled below */
  .projet-larocque-page .footer-tagline{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    font-size: 17px;
    color: rgba(236, 230, 213, 0.7);
    margin-top: 14px;
    letter-spacing: 0;
  }
  .projet-larocque-page .footer-right h3{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(40px, 4.6vw, 64px);
    line-height: 1.05;
    letter-spacing: -0.018em;
    color: var(--cream);
    margin-bottom: 32px;
    text-wrap: balance;
  }
  .projet-larocque-page .footer-right h3 .dot{ color: var(--gold-light); }
  .projet-larocque-page .footer-mail{
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 28px;
    color: var(--cream);
    text-decoration: none;
    border-bottom: 1px solid var(--gold-light);
    padding-bottom: 6px;
    letter-spacing: -0.012em;
    display: inline-block;
    transition: color 0.2s ease;
  }
  .projet-larocque-page .footer-mail:hover{ color: var(--gold-light); }
  .projet-larocque-page .footer-meta{
    margin-top: 40px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }
  .projet-larocque-page .footer-meta dt{
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: rgba(236, 230, 213, 0.45);
    font-weight: 500;
    margin-bottom: 8px;
  }
  .projet-larocque-page .footer-meta dd{ font-size: 14px; color: rgba(236, 230, 213, 0.8); line-height: 1.5; }
  .projet-larocque-page .footer-bottom{
    display: flex;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding-top: 32px;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(241, 230, 206, 0.45);
    font-weight: 500;
  }
  .projet-larocque-page .footer-bottom a{ color: inherit; text-decoration: none; }
  .projet-larocque-page .footer-bottom a:hover{ color: var(--gold-light); }

  /* ============================================================
   * Reveal on scroll
   * ============================================================ */
  .projet-larocque-page .reveal{ opacity: 0; transform: translateY(20px); transition: opacity 0.9s ease, transform 0.9s ease; }
  .projet-larocque-page .reveal.in{ opacity: 1; transform: none; }

  /* ============================================================
   * Responsive
   * ============================================================ */
  @media (max-width: 1100px) {
    .projet-larocque-page .chapter-1, .projet-larocque-page .chapter-3, .projet-larocque-page .chapter-4, .projet-larocque-page .demarche-head, .projet-larocque-page .calendrier-head, .projet-larocque-page .footer-inner{
      grid-template-columns: 1fr;
      gap: 56px;
    }
    .projet-larocque-page .quote-band-grid{ grid-template-columns: 1fr; }
    .projet-larocque-page .quote-band-image{ aspect-ratio: 4 / 3; min-height: 0; }
    .projet-larocque-page .quote-band-text{ padding: 80px 56px; }
    .projet-larocque-page .programme-grid{ grid-template-columns: 1fr 1fr; }
    .projet-larocque-page .demarche-grid{ grid-template-columns: 1fr 1fr; gap: 48px; }
    .projet-larocque-page .floors{ grid-template-columns: 1fr; gap: 48px; }
    .projet-larocque-page .nav-links{ display: none; }
    .projet-larocque-page .nav-inner{ grid-template-columns: 1fr auto; }
    .projet-larocque-page .hero-bottom{ grid-template-columns: repeat(2, 1fr); gap: 32px; }
    .projet-larocque-page .hero-scroll{ grid-column: span 2; }
    .projet-larocque-page .partners-inner{ grid-template-columns: 1fr; gap: 48px; }
    .projet-larocque-page .partners-list{ grid-template-columns: 1fr; gap: 32px; }
  }
  @media (max-width: 720px) {
    :root { --container-px: var(--container-px-m); }
    .projet-larocque-page section{ padding: 80px 0; }
    .projet-larocque-page .hero{ min-height: 100vh; }
    .projet-larocque-page .hero-inner{ padding: 32px 0 32px; }
    .projet-larocque-page .hero-h1{ font-size: clamp(56px, 16vw, 96px); }
    .projet-larocque-page .programme-grid{ grid-template-columns: 1fr; }
    .projet-larocque-page .demarche-grid{ grid-template-columns: 1fr; }
    .projet-larocque-page .programme-card{ min-height: 0; padding: 36px 28px; }
    .projet-larocque-page .cal-row{ grid-template-columns: 1fr; gap: 14px; padding: 28px 0; }
    .projet-larocque-page .cal-row.current{ padding-left: 20px; padding-right: 20px; margin: 0 -20px; }
    .projet-larocque-page .cal-status{ justify-self: start; }
    .projet-larocque-page .cta-grid{ grid-template-columns: 1fr; }
    .projet-larocque-page .cta-card{ min-height: 0; padding: 40px 32px; }
    .projet-larocque-page .footer{ padding: 64px 0 40px; }
    .projet-larocque-page .footer-meta{ grid-template-columns: 1fr; }
    .projet-larocque-page .footer-bottom{ flex-direction: column; }
  }

  /* === Logo images === */
  .projet-larocque-page .brand img{
    height: 38px;
    width: auto;
    display: block;
  }
  .projet-larocque-page .footer-brand-logo{
    width: 100%;
    max-width: 280px;
    height: auto;
    display: block;
    margin-bottom: 18px;
  }
  @media (max-width: 720px) {
    .projet-larocque-page .brand img{ height: 30px; }
    .projet-larocque-page .footer-brand-logo{ max-width: 220px; }
  }
