
  /* ═══ POLICES ═══════════════════════════════════════════════════════ */
  @font-face { font-family:'Feeling Passionate'; src:url("../photos_site/02. TYPOS/Feeling Passionate Personal Use Only.ttf") format('truetype'); font-weight:400; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-Regular.ttf") format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-Italic.ttf") format('truetype'); font-weight:400; font-style:italic; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-Medium.ttf") format('truetype'); font-weight:500; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-SemiBold.ttf") format('truetype'); font-weight:600; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-Bold.ttf") format('truetype'); font-weight:700; font-display:swap; }
  @font-face { font-family:'Montserrat'; src:url("../photos_site/02. TYPOS/Montserrat-Black.ttf") format('truetype'); font-weight:900; font-display:swap; }

  /* ════════════════════════════════════════════════════════════════
     ═══ VARIABLES — 🔧 CHARTE GRAPHIQUE MODIFIABLE ICI ════════════
     Toutes les couleurs et polices du site sont définies ici.
     Modifiez ces valeurs pour changer l'apparence globale.
     ════════════════════════════════════════════════════════════════ */
  :root {
    --orange: #f76f27;    /* 🔧 Couleur principale (boutons, accents) */
    --blue:   #1f2ed4;    /* 🔧 Couleur bleue (bordures icônes services) */
    --beige:  #efe9e1;    /* 🔧 Couleur de fond sections claires */
    --dark:   #1e1e1e;    /* 🔧 Couleur sombre (titres, footer) */
    --ink:    #2d2d2d;    /* 🔧 Couleur du texte courant */
    --muted:  #888078;    /* 🔧 Couleur du texte secondaire (paragraphes) */
    --white:  #ffffff;
    --line:   rgba(30,30,30,.1);
    --fh:     'Feeling Passionate', cursive; /* 🔧 Police manuscrite */
    --fb:     'Montserrat', sans-serif;      /* 🔧 Police principale */
    --t:      .25s ease;  /* 🔧 Vitesse des transitions (hover etc.) */
    --maxw:   1380px;     /* 🔧 Largeur max du contenu sur grands écrans */
    --pad:    clamp(24px, 4.5vw, 72px); /* 🔧 Marges latérales */
  }

  /* ═══ RESET ══════════════════════════════════════════════════════════ */
  *, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
  html { scroll-behavior:smooth; }
  body { font-family:var(--fb); background:var(--white); color:var(--ink); line-height:1.7; overflow-x:hidden; }
  img { display:block; }
  a { text-decoration:none; color:inherit; }
  ul { list-style:none; }
  button { border:none; cursor:pointer; font-family:var(--fb); }
  ::-webkit-scrollbar { width:3px; }
  ::-webkit-scrollbar-track { background:var(--beige); }
  ::-webkit-scrollbar-thumb { background:var(--orange); }

  /* ═══ NAVIGATION ═════════════════════════════════════════════════════ */
  #nav {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    height:64px;                                          /* 🔧 Hauteur bandeau */
    background:rgba(239,233,225,.96);                     /* fond beige semi-transparent */
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--line);
    transition:box-shadow var(--t);
  }
  #nav.scrolled { box-shadow:0 2px 24px rgba(30,30,30,.09); }
  .nav-inner {
    display:flex; align-items:center; justify-content:space-between;
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); height:100%;
    position:relative;
  }
  .nav-logo { cursor:pointer; flex-shrink:0; }
  .nav-logo img { height:28px; width:auto; object-fit:contain; } /* 🔧 Taille du logo */

  .nav-links {
    display:flex; gap:40px;
    position:absolute; left:50%; transform:translateX(-50%);
  }
  .nav-links a {
    font-size:.65rem; font-weight:600; letter-spacing:.09em; text-transform:uppercase;
    color:var(--dark); opacity:.5; cursor:pointer; position:relative;
    transition:opacity var(--t);
  }
  .nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px; background:var(--orange); transition:width var(--t); }
  .nav-links a:hover, .nav-links a.active { opacity:1; }
  .nav-links a.active::after, .nav-links a:hover::after { width:100%; }

  .nav-right { display:flex; align-items:center; gap:16px; flex-shrink:0; }
  .nav-socials { display:flex; align-items:center; gap:14px; }
  .nav-socials a { color:var(--dark); opacity:.5; font-size:1rem; transition:opacity var(--t); }
  .nav-socials a:hover { opacity:1; }
  .btn-orange {
    background:var(--orange); color:var(--white);
    font-family:var(--fb); font-weight:700; font-size:.65rem; letter-spacing:.09em; text-transform:uppercase;
    padding:8px 18px; border-radius:8px; transition:background var(--t); cursor:pointer;
  }
  .btn-orange:hover { background:#d85d18; }
  .btn-cta {
    display:inline-flex; align-items:center;
    background:var(--orange); color:var(--white);
    font-family:var(--fb); font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
    padding:10px 22px; border-radius:8px; transition:background var(--t); border:none; cursor:pointer;
  }
  .btn-cta:hover { background:#d85d18; }

  /* Hamburger mobile */
  .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; margin-right:-8px; }
  .hamburger span { display:block; width:22px; height:2px; background:var(--dark); transition:var(--t); }
  .hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
  .hamburger.open span:nth-child(2) { opacity:0; }
  .hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
  #mobile-menu {
    display:none; position:fixed; top:64px; left:0; right:0;
    background:var(--white); border-bottom:2px solid var(--orange);
    z-index:999; padding:20px var(--pad); flex-direction:column;
  }
  #mobile-menu.open { display:flex; }
  #mobile-menu a {
    font-size:.88rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:var(--ink); cursor:pointer; padding:13px 0;
    border-bottom:1px solid var(--line); transition:color var(--t);
  }
  #mobile-menu a:last-child { border-bottom:none; }
  #mobile-menu a:hover { color:var(--orange); }
  .mob-menu-socials { display:flex; gap:20px; padding:16px 0; }
  #mobile-menu .mob-menu-socials a { font-size:1.2rem; color:var(--dark); opacity:1; border-bottom:none !important; }

  .mob-br { display:none; }

  /* ═══ UTILITAIRES ════════════════════════════════════════════════════ */
  /* Trait épais avant le label */
  .sec-label {
    display:flex; align-items:center; gap:12px;
    font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
    color:var(--dark); margin-bottom:14px;
  }
  .sec-label::before {
    content:''; display:block;
    width:32px; height:2px;          /* TRAIT ÉPAIS 2px */
    background:var(--dark); flex-shrink:0;
  }
  .sec-big-title {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(3rem, 5.5vw, 6rem);
    text-transform:uppercase; letter-spacing:-.02em; color:var(--dark); line-height:.95;
  }
  .reveal { opacity:0; transform:translateY(22px); transition:opacity .55s ease, transform .55s ease; }
  .reveal.in { opacity:1; transform:none; }

  /* ═══════════════════════════════════════════════════════════════════
     PAGE ACCUEIL
  ═══════════════════════════════════════════════════════════════════ */

  /* ════════════════════════════════════════════════════════════════
     ── 1. HERO ──────────────────────────────────────────────────
     🔧 MODIFIABLE — ce bloc contrôle toute la section hero
     ════════════════════════════════════════════════════════════════ */
  #hero {
    position:relative; overflow:hidden;  /* hidden = masque ce qui dépasse */
    background:var(--beige);             /* 🔧 Couleur si la photo ne charge pas */
    height:calc(100vh - 64px);           /* = hauteur fenêtre - hauteur nav → s'adapte automatiquement */
    min-height:480px;                    /* 🔧 Hauteur minimum sur très petits écrans */
  }
  /*
   * object-fit:cover  → l'image remplit 100% du hero sans bords blancs
   *                      (elle peut être légèrement recadrée sur les bords)
   * object-position   → choisit quel endroit de la photo est visible en priorité
   * La taille du hero est fixée par height:calc(100vh - 64px),
   * donc l'image SUIT la taille de la fenêtre automatiquement.
   */
  .hero-img {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover;
    opacity:1;                           /* 🔧 Luminosité : 0=invisible → 1=pleine */
  }
  .hero-overlay { display:none; }

  /*
   * Le bloc texte est positionné absolument dans le hero
   * (il suit donc sa hauteur automatiquement).
   * justify-content:flex-start = poussé vers la gauche du hero,
   * puis margin-left sur .hero-text-block le décale à droite.
   */
  .hero-content {
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:flex-start;
    padding:0 var(--pad);
    margin-left:30%;
    padding-bottom:8%;               /* 🔧 Remonte le bloc : augmenter % pour monter davantage */
  }
  /*
   * margin-left:15%  → décale le bloc à droite (15% de la largeur du hero)
   * align-items:flex-start → logo, titre, sous-titre tous alignés à gauche
   * gap:clamp(...)   → l'espace entre les éléments se réduit sur mobile
   */
  .hero-text-block {
    display:flex; flex-direction:column;
    align-items:flex-start;              /* alignement gauche à l'intérieur du bloc */
    gap:clamp(4px, 0.6vw, 8px);         /* 🔧 Espace entre logo / titre / sous-titre — réduire pour rapprocher */
    padding:clamp(20px, 3vw, 44px) clamp(20px, 3.5vw, 52px); /* 🔧 Hauteur du bloc : augmenter les px */
    max-width:clamp(400px, 90%, 1400px); /* 🔧 Largeur max du bloc texte — augmenter si le titre coupe */
  }

  /*
   * clamp(min, préféré, max) = la taille s'adapte à la largeur de fenêtre
   * entre un minimum et un maximum fixes.
   * Ex : clamp(36px, 5.5vw, 78px) → 36px sur mobile, 78px max sur grand écran
   */
  .hero-logo-img {
    height:clamp(36px, 5.5vw, 78px);    /* 🔧 Taille logo : changer 78px pour agrandir/réduire */
    width:auto; object-fit:contain;
    animation:hUp .65s ease both;
  }

  .hero-tagline {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.1rem, 2.8vw, 3rem); /* 🔧 Titre : changer 3rem pour agrandir */
    color:var(--dark);                  /* 🔧 Couleur : var(--dark)=noir, var(--orange)=orange */
    text-transform:uppercase; letter-spacing:.1em; line-height:1.2;
    animation:hUp .65s .1s ease both;
  }

  .hero-sub {
    font-family:var(--fh);
    font-size:clamp(1.1rem, 2.4vw, 2.8rem); /* 🔧 Sous-titre : changer 2.8rem pour agrandir/réduire */
    color:var(--dark);                     /* 🔧 Couleur : var(--dark)=noir, var(--orange)=orange */
    line-height:1.2;
    animation:hUp .65s .18s ease both;
  }

  @keyframes hUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:none} }

  /* ── 2. À PROPOS ─────────────────────────────────────────────────── */
  .home-about {
    background:var(--white); padding:80px 0; /* même padding que .home-services */
    overflow:hidden;
  }
  .home-about-inner {
    display:grid;
    grid-template-columns:auto 1fr auto;
    gap:clamp(24px, 3vw, 48px); align-items:center;
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  }
  /* Texte rotatif — "À" en bas, lecture de bas en haut (lignes 237-238) */
  .rotated-label {
    writing-mode:vertical-rl;      /* texte en colonne */
    transform:rotate(180deg);      /* "À" en bas, lecture de bas en haut */
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.5rem, 7vw, 6rem); /* 🔧 taille du titre rotatif */
    text-transform:uppercase; letter-spacing:-.03em;
    color:var(--dark); line-height:1;
    user-select:none; flex-shrink:0;
  }
  .about-body .sec-label { margin-bottom:14px; white-space:nowrap; font-size:.72rem; }
  .about-body p {
    font-family:var(--fb); font-size:clamp(.88rem, 1vw, 1rem); color:var(--dark); /* même taille que .port-desc */
    line-height:1.85; margin-bottom:10px; max-width:420px;
  }
  .about-body p:last-of-type { margin-bottom:24px; }
  .about-photo {
    width:clamp(220px, 28vw, 440px); aspect-ratio:3/4;   /* 🔧 photo plus grande */
    overflow:hidden; flex-shrink:0;
  }
  .about-photo img { width:100%; height:100%; object-fit:cover; object-position:top center; }

  /* ── 3. SERVICES ─────────────────────────────────────────────────── */
  .home-services { background:var(--beige); padding:80px 0; }
  .srv-header {
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad) 52px;
    display:flex; flex-direction:column; align-items:center; text-align:center;
  }
  .srv-grid-3 {
    display:grid; grid-template-columns:repeat(3, 1fr);
    gap:clamp(16px, 2vw, 28px);
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  }
  /* CARTES ARRONDIES */
  .srv-card {
    background:var(--white);
    padding:clamp(24px, 3vw, 40px) clamp(20px, 2.5vw, 32px);
    border-radius:18px;
    transition:box-shadow var(--t), transform var(--t);
  }
  .srv-card:hover { box-shadow:0 10px 40px rgba(30,30,30,.09); transform:translateY(-4px); }
  /* ICÔNE : picto seul, sans boîte, aligné à gauche */
  .srv-icon-box {
    width:auto; height:auto;
    background:none; border:none; border-radius:0; box-shadow:none;
    display:flex; align-items:center; justify-content:flex-start;
    margin-bottom:18px;
  }
  .srv-icon-box img {
    width:46px; height:46px; object-fit:contain; /* 🔧 taille picto */
  }
  /* TITRE CARTE */
  .srv-card-title {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.05rem, 1.4vw, 2.45rem); /* 🔧 légèrement agrandi */
    text-transform:uppercase; letter-spacing:.06em; color:var(--dark);
    margin-bottom:14px; line-height:1.25;
  }
  .srv-card p { font-size:clamp(.84rem, .9vw, .95rem); color:var(--dark); line-height:1.82; margin-bottom:22px; }
  .srv-card-link {
    display:inline-flex; align-items:center; gap:7px;
    font-size:.76rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
    color:#f76f27; cursor:pointer; transition:gap var(--t);
  }
  .srv-card-link:hover { gap:12px; }

  /* ── 4. PORTFOLIO ────────────────────────────────────────────────── */
  .home-portfolio { background:var(--white); padding:80px 0 clamp(60px, 8vw, 120px); }
  /* Header portfolio */
  .port-header {
    display:flex; align-items:flex-end; justify-content:space-between;
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad) 36px;
    gap:40px;
  }
  .port-header-left { flex:0 0 35%; }
  .port-header-left .port-desc { margin-bottom:24px; }
  .port-header-right { text-align:right; flex-shrink:0; }
  .port-header-right .sec-label { justify-content:flex-end; }
  .port-header .sec-big-title { margin-bottom:0; }
  /* Flèches carrousel */
  .port-strip-wrap { position:relative; padding:0 100px; overflow:hidden; margin-top:48px; }
  .port-arrow {
    position:absolute; top:50%; transform:translateY(-50%); z-index:10;
    width:44px; height:44px; border-radius:50%;
    background:var(--white); border:1.5px solid var(--line);
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; transition:background var(--t), border-color var(--t);
    font-size:1rem; color:var(--dark);
  }
  .port-arrow:hover { background:var(--orange); border-color:var(--orange); color:var(--white); }
  .port-arrow-prev { left:28px; }
  .port-arrow-next { right:28px; }
  .port-desc {
    font-size:clamp(.88rem, 1vw, 1rem); color:var(--dark);
    line-height:1.85; margin-bottom:32px;
  }
  /* Bande portfolio — défilement horizontal */
  .port-strip {
    display:flex;
    padding:0;
    gap:30px; /* ← écart entre les photos — modifiez cette valeur */
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none; /* scrollbar cachée sur ordi */
  }
  .port-strip::-webkit-scrollbar { display:none; }
  .ps { flex:0 0 clamp(220px, 28vw, 380px); aspect-ratio:1/1; overflow:hidden; position:relative; background:var(--beige); scroll-snap-align:start; }
  .ps img {
    width:100%; height:100%; object-fit:cover;
    filter:grayscale(100%); transition:transform .55s ease, filter .5s ease;
  }
  .ps:hover img { transform:scale(1.05); filter:grayscale(0%); }
  .ps-over {
    position:absolute; inset:0;
    background:linear-gradient(to top, rgba(30,30,30,.55) 0%, transparent 55%);
    opacity:0; transition:opacity .3s ease;
    display:flex; align-items:flex-end; padding:14px 16px;
  }
  .ps:hover .ps-over { opacity:1; }
  .ps-name {
    font-family:var(--fb); font-size:.68rem; font-weight:700;
    letter-spacing:.12em; text-transform:uppercase; color:var(--white);
  }
  @media (max-width:768px) {
    .ps-name { text-decoration:underline; text-underline-offset:4px; text-decoration-thickness:1px; cursor:pointer; }
  }

  /* ── 5. CTA TRAVAILLONS ──────────────────────────────────────────── */
  .home-cta {
    background:var(--beige);
    padding:80px var(--pad); /* même padding que .home-services */
    text-align:center;
  }
  /* Wrapper inline-block pour alignement à droite de "ensemble" */
  .cta-combo-outer { display:flex; justify-content:center; margin-bottom:28px; }
  .cta-combo { display:inline-block; text-align:right; }
  .cta-big {
    display:block;
    font-family:var(--fb); font-weight:900;
    font-size:clamp(3rem, 5.5vw, 6rem);   /* même taille que "Portfolio" */
    text-transform:uppercase; letter-spacing:-.02em; color:var(--dark); line-height:1;
  }
  /* "ensemble" aligné à droite, chevauchement */
  .cta-script {
    display:block;
    font-family:var(--fh);
    font-size:clamp(2.6rem, 5vw, 5.5rem);
    color:var(--orange); line-height:1;
    margin-top:-0.18em;                    /* CHEVAUCHEMENT */
    padding-right:0.04em;
  }
  .home-cta > p {
    font-size:clamp(.9rem, 1vw, 1rem); color:var(--dark);
    margin-bottom:36px; max-width:500px; margin-left:auto; margin-right:auto;
  }
  .home-cta .btn-cta { margin:0 auto 52px; display:block; width:fit-content; }

  /* Liens de navigation centrés sous le CTA */
  .cta-footer-nav {
    display:flex; gap:clamp(20px, 3vw, 44px); justify-content:center;
    flex-wrap:wrap;
  }
  .cta-footer-nav a {
    font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
    color:var(--muted); cursor:pointer; transition:color var(--t);
  }
  .cta-footer-nav a:hover { color:var(--dark); }

  /* ── 6. FOOTER PHOTO ────────────────────────────────────────────── */
  .site-footer {
    position:relative; overflow:hidden; background:var(--dark);
    height:clamp(300px, 35vw, 480px);
  }
  .footer-photo {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; object-position:center 30%;
    filter:grayscale(100%);
    opacity:.6;                 /* Photo visible sans bandeau */
  }
  /* Dégradé léger en bas seulement pour lisibilité du copyright */
  .footer-photo::after { display:none; }
  .footer-content {
    position:absolute; inset:0; z-index:1;
    display:flex; flex-direction:column; justify-content:flex-end;
    padding:clamp(24px, 3.5vw, 52px);
  }
  /* LOGO GRAND sur la photo */
  .footer-logo-big { margin-bottom:10px; }
  .footer-logo-big img {
    height:clamp(36px, 4vw, 60px); width:auto; object-fit:contain;
    filter:brightness(10); opacity:.9;  /* Logo blanc sur photo */
  }
  .footer-copy-txt {
    font-size:.68rem; color:rgba(255,255,255,.22); letter-spacing:.07em;
  }
  .footer-legal-links {
    margin-top:8px; display:flex; gap:10px; align-items:center;
    font-size:.62rem; color:rgba(255,255,255,.22); letter-spacing:.07em;
  }
  .footer-legal-links a { color:rgba(255,255,255,.22); transition:color var(--t); }
  .footer-legal-links a:hover { color:rgba(255,255,255,.7); }
  /* ── PAGE MENTIONS LÉGALES ──────────────────────────────────────── */
  .mentions-body { max-width:760px; margin:0 auto; padding:80px var(--pad) 120px; }
  .mentions-body h1 { font-family:var(--fb); font-weight:900; font-size:clamp(2rem,4vw,3rem); color:var(--dark); margin-bottom:48px; }
  .mentions-body h2 { font-family:var(--fb); font-weight:700; font-size:1rem; text-transform:uppercase; letter-spacing:.12em; color:var(--dark); margin:40px 0 12px; }
  .mentions-body p, .mentions-body li { font-size:.9rem; color:var(--ink); line-height:1.85; }
  .mentions-body ul { padding-left:20px; margin-bottom:12px; }
  .mentions-body a { color:var(--orange); text-decoration:underline; }

  /* ═══════════════════════════════════════════════════════════════════
     PAGES SERVICES / PORTFOLIO / ABOUT / CONTACT
     (reprises de la v0 — seront peaufinées à la prochaine étape)
  ═══════════════════════════════════════════════════════════════════ */
  /* Header image (page Services) */
  .page-hero-img {
    position:relative; height:clamp(220px, 32vw, 420px); overflow:hidden;
    background:var(--dark);
  }
  .page-hero-img img {
    width:100%; height:100%; object-fit:cover; object-position:center 50%;
    filter:grayscale(100%) contrast(1.05); opacity:.75;
  }
  .page-hero-img::after {
    content:''; position:absolute; inset:0;
    background:linear-gradient(to top, rgba(30,30,30,.45) 0%, transparent 60%);
  }
  .page-hero-img-title {
    position:absolute; inset:0; z-index:1;
    display:flex; align-items:center; justify-content:center;
  }
  .page-hero-img-title h1 {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(3.5rem, 8vw, 9rem);
    text-transform:uppercase; letter-spacing:-.02em;
    color:var(--white); line-height:1;
  }
  .page-hero-sub {
    text-align:center; padding:44px var(--pad) 0;
    max-width:var(--maxw); margin:0 auto;
  }
  .page-hero-sub p { font-size:clamp(.88rem, 1vw, 1rem); color:var(--dark); max-width:800px; margin:0 auto; line-height:1.85; }

  /* Header générique (autres pages) */
  .page-hero {
    background:var(--beige); padding:80px var(--pad) 56px;
    text-align:center; border-bottom:1px solid var(--line);
    max-width:100%;
  }
  .page-hero .sec-label { justify-content:center; margin-bottom:12px; }
  .page-hero .sec-big-title { margin-bottom:14px; }
  .page-hero p { font-size:.95rem; color:var(--muted); max-width:560px; margin:0 auto; }

  /* Services full */
  .srv-full { padding:64px 0; }
  .srv-full-grid {
    display:grid; grid-template-columns:repeat(2,1fr);
    gap:28px; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  }
  .srv-full-card {
    background:rgba(239,233,225,0.50); padding:40px 36px; border:1px solid var(--line);
    border-radius:4px; position:relative;
    transition:border-color var(--t), box-shadow var(--t);
  }
  .srv-full-card:hover { border-color:var(--orange); box-shadow:0 4px 24px rgba(247,111,39,.07); }
  .srv-full-card .srv-icon-box { margin-bottom:20px; }
  .srv-full-card-num { position:absolute; top:20px; right:24px; font-size:.68rem; font-weight:700; color:rgba(30,30,30,.1); letter-spacing:.08em; }
  .srv-full-card h3 { font-family:var(--fb); font-weight:900; font-size:1.05rem; text-transform:uppercase; letter-spacing:.08em; color:var(--dark); margin-bottom:10px; line-height:1.3; }
  .srv-full-card .srv-accroche { font-size:.88rem; color:var(--muted); font-style:italic; line-height:1.7; margin-bottom:18px; }
  .srv-full-card .srv-sub-label { font-size:.65rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--orange); margin-bottom:8px; display:block; }
  .srv-full-card ul { margin-bottom:18px; }
  .srv-full-card ul li { font-size:.86rem; color:var(--dark); display:flex; gap:8px; align-items:flex-start; margin-bottom:7px; }
  .srv-full-card ul li::before { content:'—'; color:var(--orange); flex-shrink:0; font-weight:700; }
  .srv-full-card .srv-objectif { font-family:var(--fb); font-size:.82rem; font-weight:700; color:var(--dark); line-height:1.6; }
  .srv-conclusion {
    max-width:var(--maxw); margin:0 auto; padding:56px var(--pad);
    border-top:1px solid var(--line);
  }
  .srv-conclusion p {
    font-family:var(--fb); font-size:clamp(.88rem,1vw,1rem);
    color:var(--dark); line-height:1.85; margin-bottom:10px;
  }
  /* ── FORFAITS ── */
  .srv-forfaits {
    padding:80px 0; background:var(--beige);
  }
  .srv-forfaits-inner {
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  }
  .srv-forfaits-header { text-align:center; margin-bottom:48px; }
  .srv-forfaits-label {
    font-size:.72rem; font-weight:700; letter-spacing:.18em;
    text-transform:uppercase; color:var(--orange); margin-bottom:10px;
  }
  .srv-forfaits-title {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.6rem,3vw,3rem);
    text-transform:uppercase; letter-spacing:-.01em; color:var(--dark);
    margin-bottom:10px;
  }
  .srv-forfaits-sub {
    font-family:var(--fp); font-size:clamp(.88rem,1vw,1rem);
    color:var(--dark); line-height:1.8;
  }
  .srv-forfaits-grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:clamp(16px,2vw,28px); align-items:stretch;
  }
  .srv-forfait-card {
    background:var(--white); border-radius:16px;
    border:1.5px solid var(--line);
    padding:clamp(28px,3vw,40px) clamp(22px,2.5vw,32px);
    display:flex; flex-direction:column; gap:14px;
    position:relative; transition:box-shadow var(--t), border-color var(--t);
  }
  .srv-forfait-card:hover { box-shadow:0 6px 32px rgba(30,30,30,.09); }
  .srv-forfait-card.featured {
    border-color:var(--orange); border-width:2px;
    box-shadow:0 8px 40px rgba(247,111,39,.12);
  }
  .srv-forfait-badge {
    display:inline-flex; align-items:center; gap:6px;
    font-size:.65rem; font-weight:700; letter-spacing:.14em;
    text-transform:uppercase; color:var(--orange); margin-bottom:2px;
  }
  .srv-forfait-badge.featured-badge {
    background:var(--orange); color:var(--white);
    padding:4px 10px; border-radius:20px; width:fit-content;
  }
  .srv-forfait-name {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.1rem,1.8vw,1.5rem);
    text-transform:uppercase; color:var(--dark); line-height:1.1;
  }
  .srv-forfait-tagline {
    font-size:.86rem; color:var(--muted); font-style:italic; line-height:1.6;
  }
  .srv-forfait-price {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.8rem,3vw,2.4rem); color:var(--dark); line-height:1;
  }
  .srv-forfait-price span { font-size:1rem; font-weight:600; color:var(--muted); }
  .srv-forfait-note { font-size:.78rem; color:var(--muted); margin-top:-8px; }
  .srv-forfait-list {
    list-style:none; display:flex; flex-direction:column; gap:8px;
    border-top:1px solid var(--line); padding-top:16px; margin-top:4px;
  }
  .srv-forfait-list li {
    display:flex; align-items:flex-start; gap:10px;
    font-size:.86rem; color:var(--dark); line-height:1.55;
  }
  .srv-forfait-list li::before { content:'—'; color:var(--orange); font-weight:700; flex-shrink:0; }
  .srv-forfait-footer {
    font-size:.75rem; color:var(--muted); margin-top:auto;
    padding-top:14px; border-top:1px solid var(--line);
  }
  @media (max-width:768px) {
    .srv-forfaits-grid { grid-template-columns:1fr; }
  }

  .srv-devis { background:var(--dark); padding:64px var(--pad); text-align:center; }
  .srv-devis h2 { font-family:var(--fb); font-weight:900; font-size:clamp(1.6rem,4vw,3.2rem); text-transform:uppercase; color:var(--white); margin-bottom:6px; }
  .srv-devis .sub { font-family:var(--fh); font-size:clamp(1.4rem,3vw,2.6rem); color:var(--orange); margin-bottom:18px; display:block; }
  .srv-devis p { font-size:.9rem; color:rgba(255,255,255,.3); margin-bottom:32px; }

  /* Portfolio full — lignes alternées image + texte */
  .portfolio-full { padding:48px 0 80px; }
  .port-rows { display:flex; flex-direction:column; gap:6px; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
  .port-prj {
    display:grid; grid-template-columns:1fr 1fr;
    min-height:380px; overflow:hidden;
  }
  /* Alternance : image à droite sur les lignes paires */
  .port-prj:nth-child(even) .port-prj-img { order:2; }
  .port-prj:nth-child(even) .port-prj-info { order:1; }
  .port-prj-img { position:relative; overflow:hidden; }
  .port-prj-img img {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; transition:transform .6s ease;
    filter:grayscale(100%);
  }
  .port-prj:hover .port-prj-img img { transform:scale(1.04); filter:grayscale(0%); }
  .port-prj-info {
    background:var(--white); padding:56px 48px;
    display:flex; flex-direction:column; justify-content:center;
  }
  .port-prj:nth-child(even) .port-prj-info { background:var(--beige); }
  .port-cat { font-size:.63rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--orange); margin-bottom:12px; display:block; }
  .port-prj-title { font-family:var(--fh); font-size:clamp(1.6rem,2.4vw,2.4rem); color:var(--dark); line-height:1.1; margin-bottom:16px; }
  .port-prj-desc { font-size:.92rem; color:var(--dark); line-height:1.8; }

  /* Bloc client 2×2 (La Tiny d'Astrid) */
  .port-client-block { position:relative; }
  .port-quad {
    display:grid; grid-template-columns:1fr 1fr;
    grid-template-rows:340px 340px; gap:0;
    overflow:hidden;
  }
  .pq { overflow:hidden; position:relative; }
  .pq-img img {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; filter:grayscale(100%);
    transition:transform .6s ease, filter .4s ease;
  }
  .pq-img:hover img { transform:scale(1.04); filter:grayscale(0%); }
  .pq-logo img {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; filter:grayscale(100%);
    transition:filter .4s ease;
  }
  .pq-logo:hover img { filter:grayscale(0%); }
  .pq-color img { filter:grayscale(0%) !important; }
  .pq-color:hover img { filter:grayscale(0%) !important; }
  .pq-info {
    display:flex; flex-direction:column; justify-content:center;
    padding:40px 44px;
  }
  .pq-white { background:var(--white); }
  .pq-beige { background:var(--white); }
  .pq-beige-soft { background:var(--beige); }
  .pq-socials { display:flex; gap:10px; margin-top:18px; }
  .pq-soc-link {
    width:32px; height:32px; border:1px solid rgba(30,30,30,.15);
    border-radius:8px; display:flex; align-items:center; justify-content:center;
    color:var(--dark); font-size:.95rem;
    transition:background var(--t), border-color var(--t), color var(--t);
  }
  .pq-soc-link:hover { background:var(--orange); border-color:var(--orange); color:var(--white); }

  /* ── About v2 ─────────────────────────────────────────────────── */
  /* 1. Hero split photo / texte */
  .ab-hero { display:grid; grid-template-columns:42% 1fr; min-height:calc(100vh - 64px); max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
  .ab-hero-photo { overflow:hidden; }
  .ab-hero-photo img { width:100%; height:100%; object-fit:cover; object-position:center center; filter:grayscale(100%); }
  .ab-hero-text { display:flex; flex-direction:column; justify-content:center; padding:60px 0 60px 64px; gap:18px; }
  .ab-iam { font-family:var(--fh); font-size:clamp(2rem,3vw,3.2rem); color:var(--dark); line-height:1; }
  .ab-name { font-family:var(--fb); font-weight:900; font-size:clamp(2.4rem,5vw,5.2rem); text-transform:uppercase; letter-spacing:-.02em; color:var(--dark); line-height:.95; margin-bottom:4px; }
  .ab-hero-text p { font-size:.9rem; color:var(--dark); line-height:1.9; max-width:400px; }
  .ab-hero-btn { display:inline-block; border:1.5px solid var(--dark); padding:13px 30px; font-family:var(--fb); font-weight:700; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--dark); background:transparent; cursor:pointer; transition:background var(--t), color var(--t); align-self:flex-start; border-radius:4px; }
  .ab-hero-btn:hover { background:var(--dark); color:var(--white); }
  /* 2. Citation */
  .ab-quote-wrap { border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:72px var(--pad); text-align:center; }
  .ab-quote-text { font-family:var(--fh); font-size:clamp(1.6rem,3vw,3rem); color:var(--dark); line-height:1.45; max-width:780px; margin:0 auto 20px; }
  .ab-quote-author { font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
  /* 2. Section artiste — option B */
  .ab-artist {
    background:var(--beige); border-top:1px solid var(--line);
    padding:80px var(--pad); position:relative; overflow:hidden;
  }
  .ab-artist-inner {
    display:grid; grid-template-columns:1fr 42%;
    gap:0; align-items:center;
    max-width:var(--maxw); margin:0 auto; position:relative;
  }
  .ab-artist-left { display:flex; flex-direction:column; gap:20px; padding-right:48px; z-index:1; }
  .ab-artist-title {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(2.4rem,5vw,5.2rem); /* même que .ab-name */
    text-transform:uppercase; letter-spacing:-.02em;
    color:var(--dark); line-height:.95;
    margin-right:0;
  }
  .ab-artist-title em {
    font-family:var(--fh); font-style:normal; font-weight:400;
    font-size:clamp(2rem,3vw,3.2rem); /* même que .ab-iam */
    color:var(--orange); text-transform:none;
    display:block; line-height:1.1;
  }
  .ab-artist-left p { font-size:.9rem; color:var(--dark); line-height:1.9; max-width:380px; }
  .ab-artist-photo {
    aspect-ratio:1/1; overflow:hidden;
  }
  .ab-artist-photo img { width:100%; height:100%; object-fit:cover; object-position:center 40%; }
  /* 3. Comment je travaille : split */
  .ab-how { display:grid; grid-template-columns:38% 1fr; max-width:var(--maxw); margin:0 auto; padding:80px var(--pad); gap:80px; align-items:start; border-top:1px solid var(--line); }
  .ab-how-title { font-family:var(--fb); font-weight:900; font-size:clamp(1.8rem,3vw,3rem); color:var(--dark); line-height:1.1; margin-bottom:28px; }
  .ab-how-title em { font-family:var(--fh); font-style:normal; font-size:clamp(2rem,3.4vw,3.4rem); color:var(--orange); display:block; font-weight:400; line-height:1; }
  .ab-acc-item { border-bottom:1px solid var(--line); overflow:hidden; }
  .ab-acc-item:first-child { border-top:1px solid var(--line); }
  .ab-acc-trigger { display:flex; align-items:center; justify-content:space-between; padding:18px 0; cursor:pointer; font-family:var(--fb); font-weight:600; font-size:.92rem; color:var(--dark); transition:color var(--t); width:100%; background:none; border:none; text-align:left; }
  .ab-acc-trigger:hover { color:var(--orange); }
  .ab-acc-plus { font-size:1.3rem; font-weight:300; color:var(--orange); transition:transform .3s ease; flex-shrink:0; }
  .ab-acc-item.open .ab-acc-plus { transform:rotate(45deg); }
  .ab-acc-body { max-height:0; overflow:hidden; transition:max-height .35s ease, padding .25s ease; font-size:.87rem; color:var(--muted); line-height:1.85; }
  .ab-acc-item.open .ab-acc-body { max-height:300px; padding:0 0 18px; }

  /* Contact */
  .contact-split { display:grid; grid-template-columns:0.5fr 1fr; min-height:calc(100vh - 64px); }
  .contact-photo { overflow:hidden; max-height:480px; align-self:center; }
  .contact-photo img { width:100%; height:100%; object-fit:cover; object-position:top center; }
  .contact-left { background:var(--dark); padding:80px clamp(32px,5vw,64px); display:flex; flex-direction:column; justify-content:center; }
  .contact-left .sec-big-title { color:var(--white); margin-bottom:8px; }
  .contact-channels { display:flex; flex-direction:column; margin-top:32px; }
  .ch { display:flex; align-items:center; justify-content:space-between; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.07); color:rgba(255,255,255,.35); cursor:pointer; transition:color var(--t); }
  .ch:first-child { border-top:1px solid rgba(255,255,255,.07); }
  .ch:hover { color:var(--orange); }
  .ch-left { display:flex; align-items:center; gap:12px; }
  .ch-ico { width:18px; height:18px; }
  .ch-ico img { width:100%; height:100%; object-fit:contain; filter:brightness(10); opacity:.3; }
  .ch:hover .ch-ico img { opacity:1; }
  .ch-lbl { font-size:.58rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--orange); line-height:1; display:block; }
  .ch-val { font-size:.9rem; }
  .ch-arr { transition:transform var(--t); }
  .ch:hover .ch-arr { transform:translateX(4px); }
  .contact-right { background:var(--beige); padding:80px clamp(100px,15vw,180px); display:flex; flex-direction:column; justify-content:center; }
  .contact-right h2 { font-family:var(--fb); font-weight:900; font-size:clamp(1.3rem,2.5vw,2rem); text-transform:uppercase; letter-spacing:.04em; color:var(--dark); margin-bottom:28px; }
  .f-group { margin-bottom:16px; }
  .f-label { display:block; font-size:.58rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
  .f-ctrl { width:100%; background:var(--white); border:1px solid var(--line); padding:13px 16px; font-family:var(--fb); font-size:.9rem; color:var(--ink); outline:none; transition:border-color var(--t); border-radius:0; }
  .f-ctrl::placeholder { color:rgba(30,30,30,.2); }
  .f-ctrl:focus { border-color:var(--orange); }
  textarea.f-ctrl { resize:vertical; min-height:120px; }
  .f-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

  @media (min-width:769px) {
    .contact-photo { max-height:none; align-self:stretch; height:100%; }
  }

  /* Titre hero sur une ligne uniquement sur grand écran */
  @media (min-width:1020px) {
    .hero-tagline { white-space:nowrap; }
  }

  /* ═══ RESPONSIVE ══════════════════════════════════════════════════ */
  @media (max-width:1020px) {
    .nav-links { display:none; }
    .hamburger { display:flex; }
    .btn-orange.nav-btn { display:none; }
    .nav-socials { display:none; }
    .home-about-inner { grid-template-columns:auto 1fr; }
    .about-photo { display:none; }
    .srv-full-grid { grid-template-columns:1fr; }
    .client-grid { grid-template-columns:repeat(2,1fr); }
    .contact-split { grid-template-columns:1fr; }
    .ab-hero { grid-template-columns:1fr; min-height:auto; padding:0; }
    .ab-hero-photo { height:55vw; max-height:400px; }
    .ab-hero-text { padding:40px var(--pad); }
    .ab-artist-inner { grid-template-columns:1fr; gap:40px; }
    .ab-artist-title { margin-right:0; }
    .ab-artist-left { padding-right:0; }
    .ab-artist-photo { aspect-ratio:1/1; }
    .ab-how { grid-template-columns:1fr; gap:36px; }
    .port-strip { padding:0 0 0 var(--pad); scrollbar-width:thin; scrollbar-color:var(--orange) var(--beige); }
    .port-strip::-webkit-scrollbar { display:block; height:4px; }
    .port-strip::-webkit-scrollbar-track { background:var(--beige); border-radius:2px; }
    .port-strip::-webkit-scrollbar-thumb { background:var(--orange); border-radius:2px; }
    .port-strip-wrap { padding:0; overflow:visible; margin-top:0; }
    .port-strip { gap:6px; }
    .ps { flex:0 0 clamp(160px, 42vw, 280px); }
    .ps.ps-active img { filter:grayscale(0%); transform:scale(1.05); }
    .ps.ps-active .ps-over { opacity:1; }
  }
  @media (max-width:768px) {
    .srv-grid-3 { grid-template-columns:1fr; }
    .port-prj { grid-template-columns:1fr; min-height:auto; }
    .port-prj:nth-child(even) .port-prj-img { order:1; }
    .port-prj:nth-child(even) .port-prj-info { order:2; }
    .port-prj-img { height:280px; position:relative; }
    .port-prj-info { padding:36px 28px; }
    .f-row { grid-template-columns:1fr; }
    /* ── À propos mobile ── */
    .home-about { padding:50px 0; }
    .home-about-inner { grid-template-columns:1fr; gap:24px; }
    .rotated-label { writing-mode:horizontal-tb; transform:none; font-size:clamp(2rem,9vw,3rem); }
    .about-body p { max-width:100%; }
    /* ── Portfolio mobile ── */
    .port-header { flex-direction:column; align-items:center; gap:12px; text-align:center; }
    .port-header-left { text-align:center; order:2; }
    .port-header-right { text-align:center; order:1; }
    .port-header-right .sec-label { justify-content:center; }
    .port-header .sec-label { white-space:nowrap; font-size:.68rem; letter-spacing:.08em; }
    .port-arrow { display:none; }
    .page-hero-img-title h1 { font-size:clamp(2.2rem, 10vw, 3.5rem); }
    .port-quad { grid-template-columns:1fr; grid-template-rows:auto; }
    .pq-mob-hide { display:none; }
    .pq-mob-o1 { order:1; }
    .pq-mob-o2 { order:2; }
    .pq-title { order:-1; }
    .pq-img { height:260px; }
    .pq-info { height:auto; }
    .ab-hero-photo img { content:url("../photos_site/04. IMAGES/Julie1_for_phone.JPG"); }
    .contact-photo { height:55vw; max-height:400px; }
    .contact-photo img { content:url("../photos_site/04. IMAGES/Julie1_for_phone.JPG"); filter:grayscale(100%); object-position:center center; }
    .pq { border-radius:0 !important; }
    .pq-title { border-radius:24px 0 0 0 !important; }
    .pq-mob-last { border-radius:0 0 24px 0 !important; }
    .pq-alt.pq-title { border-radius:0 24px 0 0 !important; }
    .pq-alt.pq-mob-last { border-radius:0 0 0 24px !important; }
    /* ── Hero mobile ── */
    .hero-img { content:url("../photos_site/04. IMAGES/Invaart_hook_to_use_for_phone.png"); }
    .hero-content { margin-left:30%; padding-bottom:62%; }
    .hero-text-block { max-width:80%; }
    .hero-logo-img { filter:brightness(0) invert(1); }
    .hero-tagline, .hero-sub { color:var(--white); }
    .mob-br { display:inline; }
  }
  @media (max-width:480px) {
    .ps { flex:0 0 clamp(140px, 70vw, 240px); }
  }


  /* ═══════════════════════════════════════════════════════════════════
     LANDING PAGE — #page-landing
  ═══════════════════════════════════════════════════════════════════ */

  /* ── LP NAV ── */
  .lp-nav {
    display:flex; align-items:center; justify-content:space-between;
    padding:0 var(--pad); height:64px;
    background:rgba(239,233,225,.97);
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--line);
    position:sticky; top:0; z-index:100;
  }
  .lp-nav-logo img { height:28px; width:auto; object-fit:contain; }
  .lp-nav-back {
    font-family:var(--fb); font-weight:700; font-size:.65rem; letter-spacing:.09em;
    text-transform:uppercase; color:var(--dark); opacity:.6;
    cursor:pointer; display:flex; align-items:center; gap:8px;
    background:none; border:none; transition:opacity var(--t);
  }
  .lp-nav-back:hover { opacity:1; }

  /* ── LP HERO ── */
  .lp-hero {
    position:relative; overflow:hidden;
    min-height:100svh; display:flex; align-items:center;
    background:var(--dark);
  }
  .lp-hero-bg {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; object-position:center top;
    opacity:.45;
  }
  .lp-hero-inner {
    position:relative; z-index:1;
    max-width:var(--maxw); margin:0 0 0 35%;
    padding:80px var(--pad);
    display:flex; flex-direction:column; align-items:flex-start; gap:24px;
  }
  .lp-hook {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.4rem, 3vw, 3.5rem);
    color:var(--white); line-height:1.1;
    text-transform:uppercase; letter-spacing:-.01em;
    max-width:800px;
    animation:hUp .65s ease both;
  }
  .lp-hook span { color:var(--orange); }
  .lp-sub {
    font-family:var(--fh);
    font-size:clamp(1.3rem, 2.5vw, 2.4rem);
    color:rgba(255,255,255,.85); line-height:1.35;
    max-width:620px;
    animation:hUp .65s .12s ease both;
  }
  .lp-hero .btn-cta {
    animation:hUp .65s .22s ease both;
    font-size:.78rem; padding:14px 32px;
  }

  /* ── LP SECTION BASE ── */
  .lp-sec {
    padding:80px 0;
  }
  .lp-sec-inner {
    max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  }
  .lp-sec-title {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.6rem, 3vw, 3rem);
    color:var(--dark); text-transform:uppercase;
    letter-spacing:-.01em; line-height:1.1;
    margin-bottom:12px;
  }
  .lp-sec-label {
    display:flex; align-items:center; gap:12px;
    font-size:.72rem; font-weight:700; letter-spacing:.18em;
    text-transform:uppercase; color:var(--orange);
    margin-bottom:14px;
  }
  .lp-sec-label::before {
    content:''; display:block; width:32px; height:2px;
    background:var(--orange); flex-shrink:0;
  }

  /* ── LP PAIN POINTS ── */
  .lp-pain { background:var(--beige); }
  .lp-pain-grid {
    display:grid; grid-template-columns:repeat(4,1fr);
    gap:clamp(12px,2vw,24px); margin-top:48px;
  }
  .lp-pain-card {
    background:var(--white);
    border-radius:16px;
    padding:clamp(24px,3vw,36px) clamp(18px,2.5vw,28px);
    display:flex; flex-direction:column; gap:14px;
    box-shadow:0 2px 16px rgba(30,30,30,.05);
    transition:transform var(--t), box-shadow var(--t);
  }
  .lp-pain-card:hover { transform:translateY(-4px); box-shadow:0 8px 32px rgba(30,30,30,.1); }
  .lp-pain-emoji { font-size:2rem; line-height:1; }
  .lp-pain-card p { font-size:.92rem; color:var(--dark); line-height:1.7; font-weight:500; }

  /* ── LP AVANT APRÈS ── */
  .lp-avap { background:var(--white); }
  .lp-avap-cols {
    display:grid; grid-template-columns:1fr 1fr;
    gap:clamp(16px,2.5vw,32px); margin-top:48px;
  }
  .lp-avap-col {
    border-radius:16px;
    padding:clamp(28px,4vw,44px) clamp(24px,3vw,36px);
    display:flex; flex-direction:row; align-items:flex-start; gap:20px;
  }
  .lp-avap-col-body { flex:1; min-width:0; }
  .lp-avap-col-img { flex:0 0 170px; width:170px; border-radius:10px; object-fit:cover; }
  .lp-avap-col.avant { background:#f0f0f0; }
  .lp-avap-col.apres { background:#fff3ec; border:2px solid rgba(247,111,39,.25); }
  .lp-avap-col-title {
    font-family:var(--fb); font-weight:900;
    font-size:1rem; letter-spacing:.1em; text-transform:uppercase;
    margin-bottom:22px;
  }
  .lp-avap-col.avant .lp-avap-col-title { color:var(--muted); }
  .lp-avap-col.apres .lp-avap-col-title { color:var(--orange); }
  .lp-avap-list { display:flex; flex-direction:column; gap:11px; }
  .lp-avap-item {
    display:flex; align-items:flex-start; gap:10px;
    font-size:.9rem; line-height:1.6; color:var(--dark);
  }
  .lp-avap-item .av-ico { font-size:1rem; flex-shrink:0; line-height:1.5; }
  .lp-avap-col.avant .av-ico { color:#b0aba3; }
  .lp-avap-col.apres .av-ico { color:var(--orange); font-weight:700; }
  .lp-feed-placeholders {
    display:grid; grid-template-columns:1fr 1fr;
    gap:clamp(16px,2.5vw,32px); margin-top:32px;
  }
  .lp-feed-ph {
    aspect-ratio:9/16; max-height:340px;
    border-radius:12px; border:2px dashed var(--line);
    background:var(--beige);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:10px;
  }
  .lp-feed-ph-label {
    font-size:.68rem; font-weight:700; letter-spacing:.12em;
    text-transform:uppercase; color:var(--muted);
  }
  .lp-feed-ph-icon { font-size:1.6rem; opacity:.3; }

  /* ── LP OFFRE ── */
  .lp-offre { background:var(--beige); }
  .lp-offre-card-wrap {
    display:flex; justify-content:center; margin-top:48px;
  }
  .lp-offre-card {
    background:var(--white);
    border-radius:20px;
    padding:clamp(36px,5vw,56px) clamp(32px,4vw,52px);
    max-width:560px; width:100%;
    box-shadow:0 4px 40px rgba(30,30,30,.1);
    text-align:center;
    position:relative; overflow:hidden;
  }
  .lp-offre-card::before {
    content:''; position:absolute; top:0; left:0; right:0;
    height:4px; background:var(--orange);
  }
  .lp-offre-badge {
    display:inline-block;
    background:var(--orange); color:var(--white);
    font-family:var(--fb); font-weight:700;
    font-size:.65rem; letter-spacing:.1em; text-transform:uppercase;
    padding:6px 16px; border-radius:20px;
    margin-bottom:20px;
  }
  .lp-offre-price {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(2rem, 4vw, 3.5rem);
    color:var(--dark); line-height:1; margin-bottom:6px;
  }
  .lp-offre-price-note {
    font-size:.78rem; color:var(--muted); margin-bottom:28px;
  }
  .lp-offre-list {
    text-align:left; display:flex; flex-direction:column; gap:12px;
    margin-bottom:28px;
  }
  .lp-offre-list li {
    display:flex; align-items:flex-start; gap:10px;
    font-size:.9rem; color:var(--dark); line-height:1.5;
  }
  .lp-offre-list li .lp-check { color:var(--orange); font-weight:900; flex-shrink:0; }
  .lp-offre-mention {
    font-size:.72rem; color:var(--muted); margin-top:16px; line-height:1.6;
  }

  /* ── LP COMMENT ÇA MARCHE ── */
  .lp-how { background:var(--white); }
  .lp-steps {
    display:grid; grid-template-columns:repeat(4,1fr);
    gap:clamp(12px,2vw,24px); margin-top:48px;
    position:relative;
  }
  .lp-steps::before {
    content:''; position:absolute;
    top:32px; left:calc(12.5% + 16px); right:calc(12.5% + 16px);
    height:2px; background:var(--line); z-index:0;
  }
  .lp-step {
    display:flex; flex-direction:column; align-items:center;
    text-align:center; gap:14px; position:relative; z-index:1;
  }
  .lp-step-num {
    width:64px; height:64px; border-radius:50%;
    background:var(--orange); color:var(--white);
    font-family:var(--fb); font-weight:900; font-size:1.4rem;
    display:flex; align-items:center; justify-content:center;
    flex-shrink:0;
  }
  .lp-step-title {
    font-family:var(--fb); font-weight:700;
    font-size:.9rem; color:var(--dark); line-height:1.3;
  }
  .lp-step-desc {
    font-size:.82rem; color:var(--muted); line-height:1.65;
  }

  /* ── LP CLIENTS ── */
  .lp-clients { background:var(--beige); }
  .lp-badges-wrap {
    position:relative; margin-top:40px;
    display:flex; align-items:center; gap:12px;
  }
  .lp-badges-track { overflow:hidden; flex:1; }
  .lp-badges {
    display:flex; flex-wrap:nowrap; gap:8px;
    transition:transform .4s ease;
  }
  .lp-badge {
    flex:0 0 calc(25% - 6px);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    padding:12px 8px; gap:8px; position:relative;
  }
  .lp-badge img {
    height:120px; width:auto; max-width:200px;
    object-fit:contain;
    transition:transform var(--t);
  }
  .lp-badge:hover img { transform:translateY(-4px); }
  .lp-badge-name {
    font-size:.72rem; font-weight:600; letter-spacing:.06em;
    color:var(--dark); text-transform:uppercase;
    opacity:0; transform:translateY(4px);
    transition:opacity var(--t), transform var(--t);
    white-space:nowrap;
  }
  .lp-badge:hover .lp-badge-name { opacity:1; transform:translateY(0); }
  .lp-badges-arrow {
    background:none; border:1.5px solid var(--line); border-radius:50%;
    width:40px; height:40px; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; font-size:1.1rem; color:var(--dark);
    transition:background var(--t), border-color var(--t), color var(--t);
  }
  .lp-badges-arrow:hover { background:var(--orange); border-color:var(--orange); color:var(--white); }
  .lp-testimonial {
    max-width:960px; margin:48px auto 0;
    background:var(--white); border-radius:16px;
    padding:clamp(28px,4vw,44px) clamp(24px,4vw,44px);
    position:relative;
    box-shadow:0 2px 20px rgba(30,30,30,.06);
  }
  .lp-testimonial::before {
    content:'\201C';
    position:absolute; top:-12px; left:28px;
    font-family:Georgia,serif; font-size:5rem;
    color:var(--orange); line-height:1; opacity:.25;
  }
  .lp-testimonial-text {
    font-family:var(--fb); font-style:italic;
    font-size:.9rem; color:var(--muted); line-height:1.85;
    margin-bottom:18px;
  }
  .lp-testimonial-name {
    font-size:.68rem; font-weight:700; letter-spacing:.14em;
    text-transform:uppercase; color:var(--dark);
  }

  /* ── LP QUI SUIS-JE ── */
  .lp-about { background:var(--white); }
  .lp-about-inner {
    display:grid; grid-template-columns:38% 1fr;
    gap:clamp(36px,5vw,72px); align-items:center;
    max-width:var(--maxw); margin:0 auto; padding:80px var(--pad);
  }
  .lp-about-photo {
    border-radius:12px; overflow:hidden;
    aspect-ratio:3/4;
  }
  .lp-about-photo img {
    width:100%; height:100%;
    object-fit:cover; object-position:center top;
    filter:grayscale(100%);
    transition:filter .5s ease;
  }
  .lp-about-photo:hover img { filter:grayscale(0%); }
  .lp-about-text { display:flex; flex-direction:column; gap:16px; }
  .lp-about-name {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.5rem, 3vw, 2.8rem);
    text-transform:uppercase; letter-spacing:-.01em;
    color:var(--dark); line-height:1;
  }
  .lp-about-role {
    font-family:var(--fh); font-size:clamp(1.2rem, 2vw, 1.8rem);
    color:var(--orange); line-height:1;
  }
  .lp-about-city {
    font-size:.72rem; font-weight:700; letter-spacing:.14em;
    text-transform:uppercase; color:var(--muted);
  }
  .lp-about-text p {
    font-size:.9rem; color:var(--dark); line-height:1.85; max-width:480px;
  }

  /* ── LP CTA FINAL ── */
  .lp-cta-final {
    background:var(--dark); padding:80px var(--pad); text-align:center;
  }
  .lp-cta-final-phrase {
    font-family:var(--fh);
    font-size:clamp(1.6rem, 3.5vw, 3.2rem);
    color:var(--white); line-height:1.35; margin-bottom:28px;
  }
  .lp-cta-final .btn-cta { font-size:.78rem; padding:14px 32px; }

  /* ── LP FORMULAIRE ── */
  .lp-form-sec {
    background:var(--beige); padding:80px 0;
  }
  .lp-form-inner {
    max-width:720px; margin:0 auto; padding:0 var(--pad);
  }
  .lp-form-inner h2 {
    font-family:var(--fb); font-weight:900;
    font-size:clamp(1.6rem,3vw,2.6rem);
    color:var(--dark); text-transform:uppercase;
    letter-spacing:-.01em; margin-bottom:8px;
  }
  .lp-form-inner .lp-form-sub {
    font-size:.9rem; color:var(--muted); margin-bottom:36px; line-height:1.7;
  }
  .lp-form-inner .f-group { margin-bottom:16px; }
  .lp-contact-channels {
    display:flex; flex-wrap:wrap; gap:clamp(16px,3vw,32px);
    margin-top:36px; justify-content:center; align-items:center;
  }
  .lp-contact-item {
    display:flex; align-items:center; gap:10px;
    font-size:.85rem; color:var(--dark);
  }
  .lp-contact-item a { color:var(--dark); transition:color var(--t); }
  .lp-contact-item a:hover { color:var(--orange); }
  .lp-contact-item i { color:var(--orange); font-size:1.1rem; }
  .lp-contact-socials {
    display:flex; gap:12px; align-items:center;
  }
  .lp-soc-link {
    display:flex; align-items:center; justify-content:center;
    color:var(--dark); font-size:.9rem; opacity:.3;
    transition:opacity var(--t);
  }
  .lp-soc-link:hover { opacity:1; }
  .lp-copyright {
    text-align:center; padding:24px var(--pad) 32px;
    font-size:.68rem; color:var(--muted); letter-spacing:.07em;
    background:var(--beige);
  }

  /* ── LP RESPONSIVE ── */
  @media (max-width:900px) {
    .lp-pain-grid { grid-template-columns:repeat(2,1fr); }
    .lp-steps { grid-template-columns:repeat(2,1fr); }
    .lp-steps::before { display:none; }
    .lp-about-inner { grid-template-columns:1fr; }
    .lp-about-photo { aspect-ratio:4/3; max-height:360px; }
  }
  @media (max-width:768px) {
    /* Hero */
    .lp-hero-inner { margin:0 auto; padding:60px 24px; text-align:center; align-items:center; }
    .lp-hero { min-height:60svh; }
    .lp-hero-bg { content:url("../photos_site/04. IMAGES/photo_toulouse.jpg"); object-position:center top; }
    .lp-hook { text-align:center; }
    .lp-sub { text-align:center; }

    /* Sections */
    .lp-sec { padding:52px 0; }
    .lp-sec-inner { padding:0 24px; }

    /* Avant/Après */
    .lp-avap-cols { grid-template-columns:1fr; }
    .lp-avap-col { flex-direction:column; }
    .lp-avap-col-img { width:100%; flex:none; height:auto; object-fit:contain; }

    /* Étapes */
    .lp-steps { grid-template-columns:1fr; gap:24px; }
    .lp-step { flex-direction:row; text-align:left; align-items:flex-start; }
    .lp-step-num { flex-shrink:0; width:44px; height:44px; font-size:1rem; }
    .lp-step-body { display:flex; flex-direction:column; gap:4px; }

    /* Offre */
    .lp-offre-card-wrap { padding:0 24px; }
    .lp-offre-card { padding:32px 24px; }

    /* À propos */
    .lp-about-inner { grid-template-columns:1fr; padding:52px 24px; }
    .lp-about-photo { aspect-ratio:4/3; max-height:300px; }
    .lp-about-text .btn-cta { align-self:flex-start; }

    /* CTA final */
    .lp-cta-final {
      padding:60px 24px;
      background-image:url("../photos_site/04. IMAGES/Invaart_hook.png");
      background-size:cover; background-position:center center; background-repeat:no-repeat;
      background-color:var(--dark);
      min-height:80vw;
      position:relative;
    }
    .lp-cta-final::before {
      content:''; position:absolute; inset:0;
      background:rgba(30,30,30,.55);
    }
    .lp-cta-final-phrase, .lp-cta-final .btn-cta { position:relative; z-index:1; }
    .lp-cta-final-phrase { color:var(--white); }
    .lp-cta-final-phrase { font-size:clamp(1.4rem,5vw,2rem); }

    /* Formulaire */
    .lp-form-sec { padding:40px 0; }
    .lp-form-inner { padding:0 24px; }
    .f-row { flex-direction:column; gap:0; }

    /* Nav */
    .lp-nav { padding:12px 24px; }
    .lp-nav .btn-cta { font-size:.58rem; padding:7px 8px; max-width:150px; line-height:1.2; }
  }
  @media (max-width:480px) {
    /* Hero */
    .lp-hook { font-size:clamp(1.3rem,7vw,2rem); }
    .lp-sub { font-size:clamp(1rem,4vw,1.3rem); }

    /* Douleurs */
    .lp-pain-grid { grid-template-columns:1fr; }

    /* Avant/Après */
    .lp-avap-col-img { height:auto; }
  }
