/* =========================================================
   RJ Paysage — V1
   Palette : vert bouteille / champagne / crème + touches argent
   ========================================================= */

:root{
  /* Greens */
  --green-900:#0F2A1E;
  --green-800:#143024;
  --green-700:#1F3D2C;
  --green-600:#2A5239;
  --green-500:#3E6B4D;

  /* Gold / champagne */
  --gold-500:#C8A968;
  --gold-600:#B69552;
  --gold-700:#8E7038;

  /* Silver / metallic touches */
  --silver-100:#E8E5DC;
  --silver-300:#C9C6BD;
  --silver-500:#9CA098;

  /* Cream neutrals */
  --cream-50:#FAF6EC;
  --cream-100:#F4EFE3;
  --cream-200:#E9E2CF;

  /* Ink */
  --ink-900:#15211B;
  --ink-700:#324437;
  --ink-500:#5C6E5F;
  --ink-300:#9AA89D;

  /* Lines */
  --line-dark: rgba(244,239,227,0.12);
  --line-light: rgba(31,61,44,0.12);
  --line-gold: rgba(200,169,104,0.45);
  --line-silver: rgba(156,160,152,0.35);

  --shadow-soft: 0 22px 50px -28px rgba(15,42,30,0.45);
  --shadow-card: 0 16px 36px -20px rgba(15,42,30,0.22);
  --shadow-pop:  0 24px 50px -18px rgba(15,42,30,0.35);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ----------------- Reset & base ----------------- */
*,*::before,*::after{box-sizing:border-box;}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  scroll-padding-top: 88px;
  scroll-padding-bottom: 100px;
}
body{
  margin:0;
  font-family:"Outfit", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  color:var(--ink-700);
  background:var(--cream-50);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font:inherit; cursor:pointer; border:0; background:none;}
ul{margin:0; padding:0; list-style:none;}

.container{
  width:100%;
  max-width:1240px;
  margin:0 auto;
  padding:0 28px;
}

.muted{color:var(--ink-300);}
.light-muted{color:rgba(244,239,227,0.65);}
.light{color:var(--cream-100);}
.small{font-size:0.86rem;}
.center{text-align:center;}

/* ----------------- Eyebrow ----------------- */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:11px;
  font-weight:500;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold-700);
  margin-bottom:18px;
}
.eyebrow-light{color:var(--gold-500);}
.eyebrow .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--gold-500);
  box-shadow:0 0 0 4px rgba(200,169,104,0.18);
}

/* ----------------- Buttons ----------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 22px;
  border-radius:var(--radius-pill);
  font-weight:500;
  font-size:0.95rem;
  letter-spacing:0.01em;
  transition: transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  white-space:nowrap;
  cursor:pointer;
}
.btn-sm{padding:10px 16px; font-size:0.85rem;}
.btn-lg{padding:16px 26px; font-size:1rem;}
.btn-block{width:100%;}

.btn-gold{
  background: linear-gradient(180deg, var(--gold-500) 0%, var(--gold-600) 100%);
  color:var(--green-900);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    inset 0 -1px 0 rgba(0,0,0,0.08),
    0 14px 30px -16px rgba(200,169,104,0.6);
}
.btn-gold:hover{transform: translateY(-1px); filter: brightness(1.04);}
.btn-gold:active{transform: translateY(0); }

.btn-ghost{
  color:var(--cream-100);
  border:1px solid rgba(244,239,227,0.35);
}
.btn-ghost:hover{border-color:var(--gold-500); color:var(--gold-500);}

.btn-dark{
  background:var(--green-800);
  color:var(--cream-100);
}
.btn-dark:hover{background:var(--green-900); transform: translateY(-1px);}

.btn-link{
  background:none;
  color:var(--green-700);
  padding: 14px 8px;
  font-weight:500;
}
.btn-link:hover{color:var(--gold-700);}

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:14px 0;
  transition: background .35s var(--ease), backdrop-filter .35s var(--ease), padding .35s var(--ease), border-color .35s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(15,42,30,0.88);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color: var(--line-dark);
  padding:10px 0;
}
.header-row{
  display:flex;
  align-items:center;
  gap:24px;
}
.brand{display:flex; align-items:center; gap:14px; color:var(--cream-100);}
.brand-mark{
  width:48px; height:48px;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.4));
}
.brand-text{display:flex; flex-direction:column; line-height:1.1;}
.brand-name{font-family:"Lora", Georgia, serif; font-size:1.1rem; letter-spacing:0.005em;}
.brand-tag{font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold-500); margin-top:3px;}

.nav{
  display:flex; gap:4px;
  margin-left:auto;
}
.nav a{
  padding:10px 14px;
  font-size:0.92rem;
  color:rgba(244,239,227,0.78);
  border-radius:var(--radius-pill);
  transition: color .2s var(--ease), background .2s var(--ease);
}
.nav a:hover{color:var(--gold-500);}

.header-cta{margin-left:8px;}

.menu-toggle{
  display:none;
  width:42px; height:42px;
  flex-direction:column;
  justify-content:center; align-items:center;
  gap:5px;
  border-radius:12px;
  margin-left:auto;
}
.menu-toggle span{
  display:block; width:22px; height:2px;
  background:var(--cream-100);
  border-radius:2px;
  transition: transform .3s var(--ease), opacity .3s var(--ease);
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform: translateY(7px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform: translateY(-7px) rotate(-45deg);}

.mobile-nav{
  display:none;
  flex-direction:column;
  gap:6px;
  padding:18px 28px 24px;
  background: rgba(15,42,30,0.96);
  border-bottom:1px solid var(--line-dark);
}
.mobile-nav a{
  padding:14px 4px;
  color:var(--cream-100);
  font-size:1rem;
  border-bottom:1px solid var(--line-dark);
}
.mobile-nav .btn{margin-top:14px;}

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  position:relative;
  min-height:100dvh;
  display:flex;
  align-items:flex-end;
  padding: 140px 0 90px;
  color:var(--cream-100);
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{position:absolute; inset:0; z-index:-1;}
.hero-img{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 70% 20%, rgba(200,169,104,0.12), transparent 55%),
    linear-gradient(180deg, #1a3527 0%, #0e2419 100%),
    url("https://picsum.photos/seed/rjpaysagehero4/1800/1200") center/cover no-repeat;
  background-blend-mode: normal, multiply, overlay;
  filter: saturate(0.85) contrast(1.05);
}
.hero-veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,42,30,0.55) 0%, rgba(15,42,30,0.85) 70%, var(--cream-50) 100%),
    linear-gradient(90deg, rgba(15,42,30,0.7) 0%, rgba(15,42,30,0.2) 60%);
}
.hero-grain{
  position:absolute; inset:0;
  opacity:0.06;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Logo en filigrane discret */
.hero-watermark-logo{
  position:absolute;
  right:-60px; top:18%;
  width: 380px; height: 380px;
  opacity: 0.07;
  filter: grayscale(0.3) brightness(1.3);
  pointer-events:none;
  z-index:-1;
}

.hero-inner{
  max-width:880px;
  position:relative;
}
.hero-title{
  font-family:"Lora", Georgia, serif;
  font-weight:400;
  font-size: clamp(2.4rem, 5.6vw, 4.6rem);
  line-height:1.05;
  margin: 14px 0 22px;
  letter-spacing:-0.015em;
  color:var(--cream-100);
}
.display-serif{font-style:italic;}
.display-plain{
  font-family:"Lora", Georgia, serif;
  font-weight:400;
  color: var(--cream-100);
}
.display-gold{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  background: linear-gradient(180deg, #f0dbac 0%, #cda85e 100%);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
.hero-sub{
  max-width:560px;
  font-size:1.06rem;
  line-height:1.65;
  color:rgba(244,239,227,0.85);
  margin-bottom:32px;
}
.hero-sub strong{color:var(--cream-100); font-weight:600;}

.hero-cta{
  display:flex; flex-wrap:wrap; gap:12px;
  margin-bottom:36px;
}
.hero-trust{
  display:flex; flex-wrap:wrap; align-items:center; gap:16px;
  font-size:0.92rem;
  color:rgba(244,239,227,0.78);
}
.trust-rating{display:flex; align-items:center; gap:10px;}
.trust-rating strong{color: var(--cream-100); font-weight:600;}
.stars{display:inline-flex; gap:2px; color: var(--gold-500);}
.trust-sep{
  width:1px; height:18px;
  background: linear-gradient(180deg, transparent, var(--silver-500), transparent);
  opacity:0.6;
}
.trust-item{color:rgba(244,239,227,0.7);}

/* ===================================================================
   RÉASSURANCE
   =================================================================== */
.reassure{
  background: linear-gradient(180deg, var(--gold-500) 0%, var(--gold-600) 100%);
  color: var(--green-900);
  border-top: 1px solid rgba(0,0,0,0.08);
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.reassure-row{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 28px;
  padding: 26px 28px;
}
@media (min-width: 700px){
  .reassure-row{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1050px){
  .reassure-row{ grid-template-columns: repeat(6, 1fr); }
}
.reassure-item{
  display:flex; align-items:center; gap:10px;
  font-size:0.92rem; font-weight:500;
}
.reassure-item svg{
  flex-shrink:0;
  padding:5px;
  width:28px; height:28px;
  border-radius:50%;
  background: var(--green-800);
  color: var(--gold-500);
}

/* ===================================================================
   SECTIONS
   =================================================================== */
.section{padding: 100px 0;}
.section-light{background: var(--cream-50);}
.section-cream{background: var(--cream-100);}
.section-dark{
  background: var(--green-800);
  color: var(--cream-100);
  position:relative;
  isolation:isolate;
}
.section-dark::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 80% 0%, rgba(200,169,104,0.08), transparent 50%),
    radial-gradient(ellipse at 0% 100%, rgba(200,169,104,0.05), transparent 50%);
  pointer-events:none;
  z-index:-1;
}

.section-head{
  max-width:760px;
  margin-bottom:50px;
}
.section-head.center{margin-left:auto; margin-right:auto; text-align:center;}
.section-head h2,
.split-text h2{
  font-family:"Lora", Georgia, serif;
  font-weight:400;
  font-size: clamp(1.9rem, 3.6vw, 2.9rem);
  line-height:1.15;
  letter-spacing:-0.015em;
  margin: 0 0 14px;
  color: var(--green-900);
}
.section-dark h2,
.section-head--light h2{color: var(--cream-100);}
.section-lead{
  max-width:64ch;
  color: var(--ink-500);
  font-size:1.02rem;
}

/* ===================================================================
   SERVICES
   =================================================================== */
.services-subtitle{
  display:flex; align-items:center; gap:14px;
  margin: 0 0 28px;
  font-family:"Outfit", sans-serif;
  font-weight:500;
  font-size:0.75rem;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color: var(--green-700);
}
.services-subtitle::after{
  content:"";
  flex:1;
  height:1px;
  background: linear-gradient(90deg, var(--line-silver), transparent);
}
.subtitle-label{
  padding: 4px 10px;
  background: var(--cream-100);
  border: 1px solid var(--line-silver);
  border-radius: var(--radius-pill);
}
.services-subtitle--secondary{margin-top:54px;}
.services-subtitle--secondary .subtitle-label{color: var(--ink-500);}

/* Priority grid */
.services-priority{
  display:grid;
  grid-template-columns: 1fr;
  gap:16px;
}
@media (min-width: 640px){
  .services-priority{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 980px){
  .services-priority{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1180px){
  .services-priority{ grid-template-columns: repeat(5, 1fr); }
}

.service-card{
  position:relative;
  padding: 28px 24px 26px;
  background:#fff;
  border:1px solid var(--line-light);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  transition: transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  overflow:hidden;
}
.service-card::before{
  content:"";
  position:absolute; left:0; top:0; bottom:0;
  width:2px;
  background: linear-gradient(180deg, var(--gold-500), var(--gold-700));
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .4s var(--ease);
}
.service-card:hover{
  transform: translateY(-3px);
  border-color: var(--line-gold);
  box-shadow: var(--shadow-pop);
}
.service-card:hover::before{transform: scaleY(1);}

.badge-icon{
  display:inline-flex;
  align-items:center; justify-content:center;
  width:48px; height:48px;
  border-radius:50%;
  background: var(--green-700);
  color: var(--gold-500);
  border:1px solid var(--gold-500);
  margin-bottom:18px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 10px 22px -14px rgba(31,61,44,0.6);
}
/* Variante : badge utilisant une image (PNG) comme icône.
   - L'image possède son propre cercle/bord, on retire le fond + la bordure du badge
   - overflow:hidden + border-radius:50% sur le badge → clip circulaire propre
   - transform:scale(1.08) sur l'img pour pousser hors clip les éventuels résidus de fond
   - on conserve l'ombre extérieure pour garder la même profondeur que les autres badges */
.badge-icon--image{
  background: transparent;
  border: 0;
  padding: 0;
  overflow: hidden;
  box-shadow: 0 10px 22px -14px rgba(31,61,44,0.6);
}
.badge-icon--image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
  transform: scale(1.08);
}
.service-card h4{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size:1.18rem;
  margin: 0 0 8px;
  color: var(--green-900);
  letter-spacing:-0.005em;
  line-height:1.3;
}
.service-card p{
  margin:0;
  font-size:0.93rem;
  color: var(--ink-500);
  line-height:1.55;
}

/* Other services */
.services-other{
  display:flex; flex-wrap:wrap; gap:10px 14px;
}
.services-other li{
  display:inline-flex; align-items:center; gap:10px;
  padding: 12px 18px;
  background: var(--cream-100);
  border: 1px solid var(--line-silver);
  border-radius: var(--radius-pill);
  font-size:0.92rem;
  color: var(--green-800);
  transition: border-color .25s var(--ease), background .25s var(--ease);
}
.services-other li:hover{
  border-color: var(--gold-500);
  background: #fff;
}
.dot-mini{
  width:6px; height:6px; border-radius:50%;
  background: var(--gold-500);
  display:inline-block;
}

.services-note{
  margin: 36px 0 0;
  padding-top: 24px;
  border-top: 1px dashed var(--line-silver);
  color: var(--ink-500);
  font-size:0.95rem;
}
.services-note a{
  color: var(--green-700);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--gold-500);
  font-weight:500;
}
.services-note a:hover{color: var(--gold-700);}

/* ===================================================================
   POURQUOI / PILLARS
   =================================================================== */
.pillars-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 800px){
  .pillars-grid{ grid-template-columns: repeat(3, 1fr); }
}
.pillar{
  position:relative;
  padding: 36px 32px;
  background: rgba(244,239,227,0.04);
  border: 1px solid var(--line-dark);
  border-radius: var(--radius-md);
  transition: border-color .3s var(--ease), background .3s var(--ease);
}
.pillar:hover{border-color: var(--line-gold); background: rgba(244,239,227,0.06);}
.pillar-num{
  display:inline-block;
  font-family:"Lora", Georgia, serif;
  font-style:italic;
  font-weight:500;
  font-size:1.5rem;
  color: var(--gold-500);
  margin-bottom:18px;
  letter-spacing:0.02em;
}
.pillar h3{
  margin:0 0 10px;
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size:1.3rem;
  color: var(--cream-100);
  letter-spacing:-0.005em;
}
.pillar p{
  margin:0;
  color: rgba(244,239,227,0.7);
  font-size:0.95rem;
  line-height:1.6;
}

/* ===================================================================
   AVIS GOOGLE
   =================================================================== */
.rating-block{
  display:flex; flex-direction:column; align-items:center; gap:14px;
  margin-top: 20px;
}
.rating-score{
  display:flex; align-items:center; gap:14px;
}
.rating-num{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size: 2.6rem;
  line-height:1;
  color: var(--green-800);
  letter-spacing:-0.02em;
}
.rating-stars{display:inline-flex; gap:3px; color: var(--gold-500);}
.rating-text{margin:0; color: var(--ink-500); max-width:50ch;}
.rating-text strong{color: var(--green-800);}
.google-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding: 8px 14px;
  background:#fff;
  border:1px solid var(--line-silver);
  border-radius: var(--radius-pill);
  font-size:0.85rem;
  color: var(--green-800);
  font-weight:500;
}

/* Liste de vrais avis Google */
.reviews-list{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 44px;
}
@media (min-width: 800px){
  .reviews-list{ grid-template-columns: repeat(3, 1fr); }
}

.review{
  position:relative;
  padding: 26px 24px 22px;
  background:#fff;
  border:1px solid var(--line-silver);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  display:flex; flex-direction:column;
  transition: transform .25s var(--ease), border-color .25s var(--ease);
}
.review:hover{ transform: translateY(-3px); border-color: var(--gold-500); }

.review-head{
  display:grid;
  grid-template-columns: 40px 1fr auto;
  align-items:center;
  gap: 12px;
  margin-bottom: 16px;
}
.review-avatar{
  display:inline-flex; align-items:center; justify-content:center;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--green-700);
  color: var(--gold-500);
  font-family:"Lora", Georgia, serif;
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: 0;
  border: 1px solid var(--gold-500);
}
.review-id{display:flex; flex-direction:column; gap:2px; min-width:0;}
.review-name{
  margin:0;
  font-family:"Lora", Georgia, serif;
  font-weight: 500;
  font-size: 0.98rem;
  color: var(--green-900);
  line-height: 1.2;
}
.review-date{
  margin:0;
  font-size: 0.78rem;
  color: var(--ink-300);
  letter-spacing: 0.02em;
}
.review-stars{
  display:inline-flex; gap: 2px;
  color: var(--gold-500);
  align-self: center;
}

.review-text{
  margin: 0 0 16px;
  font-family:"Lora", Georgia, serif;
  font-weight: 400;
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--green-900);
  flex-grow: 1;
}
.review-context{
  margin: 0;
  padding-top: 14px;
  border-top: 1px solid var(--line-light);
  font-size: 0.78rem;
  color: var(--ink-500);
  letter-spacing: 0.02em;
}

/* Ancien bloc placeholder (gardé inactif au cas où, peut être supprimé plus tard) */
.reviews-placeholder{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 44px;
}
@media (min-width: 800px){
  .reviews-placeholder{grid-template-columns: repeat(3, 1fr);}
}
.review-empty{
  position:relative;
  padding: 32px 24px;
  background: #fff;
  border: 1px dashed var(--line-silver);
  border-radius: var(--radius-md);
  text-align:center;
  transition: border-color .3s var(--ease);
}
.review-empty:hover{border-color: var(--gold-500);}
.review-empty-stars{
  display:inline-flex; gap:3px;
  color: var(--gold-500);
  margin-bottom: 14px;
  opacity: 0.7;
}
.review-empty-label{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size:1.05rem;
  color: var(--green-800);
  margin: 0 0 6px;
}
.review-empty-hint{
  margin:0;
  font-size:0.85rem;
  color: var(--ink-300);
}

.reviews-cta{
  display:flex; align-items:center; justify-content:center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 36px;
  padding-top: 30px;
  border-top: 1px solid var(--line-silver);
}

/* ===================================================================
   COMMENT ÇA SE PASSE
   =================================================================== */
.process-steps{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
  counter-reset: step;
  position:relative;
  list-style:none;
  padding:0;
  margin:0;
}
@media (min-width: 820px){
  .process-steps{ grid-template-columns: repeat(3, 1fr); gap: 28px; }
}
.process-step{
  position:relative;
  padding: 30px 26px 26px;
  background:#fff;
  border:1px solid var(--line-silver);
  border-radius: var(--radius-md);
  transition: border-color .25s var(--ease), transform .25s var(--ease);
}
.process-step:hover{border-color: var(--gold-500); transform: translateY(-2px);}
.process-num{
  position:absolute;
  top:-18px; left: 24px;
  display:inline-flex; align-items:center; justify-content:center;
  width: 38px; height: 38px;
  border-radius:50%;
  background: linear-gradient(180deg, var(--gold-500) 0%, var(--gold-600) 100%);
  color: var(--green-900);
  font-family:"Lora", Georgia, serif;
  font-weight:600;
  font-size:1.1rem;
  box-shadow: 0 8px 18px -10px rgba(200,169,104,0.6);
  border: 2px solid var(--cream-100);
}
.process-step h3{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size:1.2rem;
  margin: 4px 0 8px;
  color: var(--green-900);
  letter-spacing:-0.005em;
}
.process-step p{
  margin:0;
  font-size:0.94rem;
  color: var(--ink-500);
  line-height:1.55;
}

/* ===================================================================
   SPLIT (zone + devis)
   =================================================================== */
.split{
  display:grid;
  grid-template-columns: 1fr;
  gap: 60px;
}
@media (min-width: 980px){
  .split{
    grid-template-columns: 1fr 1fr;
    gap: 80px;
  }
}
.split.align-center{align-items:center;}

.split-text .lead{
  font-size:1.04rem;
  color: var(--ink-500);
  margin: 16px 0 28px;
  max-width: 50ch;
}
.section-dark .split-text .lead{color: rgba(244,239,227,0.7);}

/* Cities */
.cities{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 28px;
  margin: 12px 0 12px;
}
@media (min-width: 600px){
  .cities{grid-template-columns: repeat(3, 1fr);}
}
.cities li{
  position:relative;
  padding: 10px 0 10px 20px;
  font-size:0.95rem;
  color: var(--green-900);
  border-bottom:1px dashed var(--line-silver);
}
.cities li::before{
  content:"";
  position:absolute; left:0; top:50%;
  width:7px; height:7px; transform: translateY(-50%);
  background: var(--gold-500);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
}

.center-block{
  margin-left:auto;
  margin-right:auto;
}

/* Zone : grille plein écran sans carte SVG */
.cities-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  max-width: 980px;
  margin: 0 auto;
}
@media (min-width: 640px){ .cities-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px){ .cities-grid{ grid-template-columns: repeat(4, 1fr); } }
.cities-grid li{
  position:relative;
  padding: 16px 18px 16px 36px;
  background:#fff;
  border:1px solid var(--line-silver);
  border-radius: var(--radius-md);
  font-size:0.95rem;
  color: var(--green-900);
  font-weight:500;
  transition: border-color .2s var(--ease), transform .2s var(--ease);
}
.cities-grid li:hover{ border-color: var(--gold-500); transform: translateY(-1px); }
.cities-grid li::before{
  content:"";
  position:absolute; left:14px; top:50%;
  width:8px; height:8px; transform: translateY(-50%);
  background: var(--gold-500);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
}
.cities-note{
  text-align:center;
  margin: 22px 0 0;
  color: var(--ink-500);
  font-size:0.92rem;
  font-style: italic;
}

/* ===================================================================
   DEVIS FORM
   =================================================================== */
.trust-list{
  display:flex; flex-direction:column; gap:10px;
  margin: 22px 0 28px;
  font-size:0.95rem;
  color: rgba(244,239,227,0.8);
}
.trust-list li{display:flex; gap:12px; align-items:flex-start;}
.check{
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; flex-shrink:0;
  border-radius:50%;
  background: rgba(200,169,104,0.15);
  color: var(--gold-500);
  font-size:0.8rem;
}

.contact-direct{
  display:flex; flex-direction:column; gap:12px;
  padding-top:22px;
  border-top:1px solid var(--line-dark);
}
.contact-link{
  display:inline-flex; align-items:center; gap:10px;
  color: var(--cream-100);
  font-size:1.05rem;
  font-family:"Lora", Georgia, serif;
  transition: color .2s var(--ease);
}
.contact-link:hover{color: var(--gold-500);}
.contact-link svg{color: var(--gold-500); flex-shrink:0;}

.devis-form{
  background: var(--cream-50);
  color: var(--ink-700);
  padding: 32px;
  border-radius: var(--radius-lg);
  border:1px solid var(--line-gold);
  display:flex; flex-direction:column; gap:18px;
  box-shadow: var(--shadow-soft);
}
.field{display:flex; flex-direction:column; gap:6px;}
.field label{
  font-size:0.78rem;
  font-weight:500;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color: var(--green-800);
}
.field input,
.field select,
.field textarea{
  width:100%;
  padding: 12px 14px;
  font: inherit;
  color: var(--green-900);
  background:#fff;
  border:1px solid var(--line-light);
  border-radius: var(--radius-sm);
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color: var(--gold-500);
  box-shadow: 0 0 0 4px rgba(200,169,104,0.15);
}
.field input[aria-invalid="true"],
.field select[aria-invalid="true"],
.field textarea[aria-invalid="true"]{
  border-color: #b04646;
  box-shadow: 0 0 0 4px rgba(176,70,70,0.12);
}
.field textarea{resize:vertical; min-height:110px;}
.field-row{display:grid; grid-template-columns:1fr; gap:18px;}
@media (min-width: 600px){
  .field-row{grid-template-columns: 1fr 1fr;}
}

.form-foot{
  display:flex; align-items:center; gap:8px;
  margin: 6px 0 0;
  color: var(--ink-500);
}
.form-success{
  margin-top:6px;
  padding: 16px 18px;
  background: var(--green-700);
  color: var(--cream-100);
  border-radius: var(--radius-sm);
  font-size:0.95rem;
  border-left: 3px solid var(--gold-500);
}
.form-success strong{color: var(--gold-500); font-family:"Lora", Georgia, serif;}
.form-error{
  margin-top:6px;
  padding: 14px 16px;
  background: #fdecec;
  color: #7a2c2c;
  border-radius: var(--radius-sm);
  font-size:0.92rem;
  border-left: 3px solid #b04646;
}
.form-error a{color: #5c1d1d; font-weight:600; text-decoration: underline;}

/* ===================================================================
   COORDONNÉES
   =================================================================== */
.coords-card{
  display:grid;
  grid-template-columns: 1fr;
  gap: 0;
  background:#fff;
  border:1px solid var(--line-silver);
  border-radius: var(--radius-lg);
  overflow:hidden;
  box-shadow: var(--shadow-card);
}
@media (min-width: 640px){
  .coords-card{grid-template-columns: repeat(2, 1fr);}
}
@media (min-width: 980px){
  .coords-card{grid-template-columns: repeat(4, 1fr);}
}
.coords-item{
  padding: 30px 26px;
  display:flex; flex-direction:column; gap:8px;
  border-right:1px solid var(--line-light);
  border-bottom:1px solid var(--line-light);
  text-align:left;
}
@media (min-width: 980px){
  .coords-item{border-bottom:0;}
}
.coords-item:last-child{border-right:0;}
.coords-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px;
  border-radius:50%;
  background: var(--green-700);
  color: var(--gold-500);
  border:1px solid var(--gold-500);
  margin-bottom:8px;
}
.coords-label{
  font-size:0.74rem;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: var(--ink-300);
}
.coords-value{
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  font-size:1.08rem;
  color: var(--green-900);
  line-height:1.4;
  word-break: break-word;
}
a.coords-value{transition: color .2s var(--ease);}
a.coords-value:hover{color: var(--gold-700);}
.coords-sub{
  display:inline-block;
  margin-top: 2px;
  font-family:"Outfit", sans-serif;
  font-weight:400;
  font-size:0.92rem;
  color: var(--ink-500);
}

.coords-extras{
  display:flex; flex-wrap:wrap; align-items:center; gap:16px;
  margin-top: 26px;
  padding: 20px 26px;
  background: var(--cream-100);
  border-radius: var(--radius-md);
  border:1px solid var(--line-silver);
  justify-content:center;
}
.extras-link{
  display:inline-flex; align-items:center; gap:10px;
  font-size:0.95rem;
  color: var(--green-800);
  transition: color .2s var(--ease);
}
.extras-link:hover{color: var(--gold-700);}
.extras-sep{
  width:1px; height:20px;
  background: var(--line-silver);
}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{
  background: var(--green-900);
  color: rgba(244,239,227,0.7);
  padding: 70px 0 28px;
  border-top: 1px solid var(--line-dark);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 40px;
  padding-bottom:48px;
  border-bottom:1px solid var(--line-dark);
}
@media (min-width: 760px){
  .footer-grid{grid-template-columns: 1.4fr 1fr 1fr 1fr;}
}
.foot-brand img{margin-bottom:14px;}
.foot-title{
  margin: 6px 0 4px;
  font-family:"Lora", Georgia, serif;
  font-weight:500;
  color: var(--cream-100);
  font-size:1.2rem;
}
.foot-baseline{
  margin: 0 0 8px;
  color: var(--gold-500);
  font-size:0.85rem;
  letter-spacing:0.05em;
}
.site-footer h4{
  font-family:"Outfit", sans-serif;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.18em;
  font-size:0.76rem;
  color: var(--gold-500);
  margin: 0 0 18px;
}
.site-footer ul{display:flex; flex-direction:column; gap:10px;}
.site-footer ul a{transition: color .2s var(--ease);}
.site-footer ul a:hover{color: var(--gold-500);}

.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:8px;
  padding-top: 24px;
}
.foot-bottom p{margin:0;}

/* ===================================================================
   CTA FIXES
   =================================================================== */
/* Desktop floating */
.cta-floating{
  position:fixed;
  right: 24px; bottom: 24px;
  z-index: 40;
  display: none;
  align-items:center; gap:10px;
  padding: 14px 22px;
  border-radius: var(--radius-pill);
  background: linear-gradient(180deg, var(--gold-500) 0%, var(--gold-600) 100%);
  color: var(--green-900);
  font-weight:500;
  font-size:0.95rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    0 18px 36px -14px rgba(15,42,30,0.55);
  transition: transform .3s var(--ease), opacity .3s var(--ease);
  opacity:0;
  transform: translateY(20px);
}
.cta-floating.visible{
  opacity:1;
  transform: translateY(0);
}
.cta-floating:hover{transform: translateY(-3px); filter: brightness(1.05);}
@media (min-width: 980px){
  .cta-floating{display:inline-flex;}
}

/* Mobile bottom bar */
.cta-mobile-bar{
  position:fixed; left:0; right:0; bottom:0;
  z-index: 40;
  display:none;
  grid-template-columns: 1fr 1fr;
  gap:0;
  background: rgba(15,42,30,0.96);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid var(--line-dark);
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -8px 24px rgba(0,0,0,0.25);
}
.cta-mobile-action{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding: 14px 12px;
  margin: 0 4px;
  border-radius: var(--radius-pill);
  font-size:0.95rem; font-weight:500;
  transition: transform .2s var(--ease), filter .2s var(--ease);
}
.cta-mobile-call{
  background: rgba(244,239,227,0.08);
  color: var(--cream-100);
  border: 1px solid var(--line-dark);
}
.cta-mobile-call:hover{background: rgba(244,239,227,0.14);}
.cta-mobile-devis{
  background: linear-gradient(180deg, var(--gold-500) 0%, var(--gold-600) 100%);
  color: var(--green-900);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.35);
}
.cta-mobile-action:active{transform: scale(0.98);}

@media (max-width: 979px){
  .cta-mobile-bar{display:grid;}
  /* éviter que le footer/form/contenu soit caché sous la barre fixe */
  body{padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));}
  html{ scroll-padding-bottom: calc(110px + env(safe-area-inset-bottom, 0px)); }
}

/* ===================================================================
   MOBILE & RESPONSIVE
   =================================================================== */
@media (max-width: 880px){
  .nav, .header-cta{display:none;}
  .menu-toggle{display:flex;}
  .mobile-nav[data-open="true"]{display:flex;}

  /* Header compact mobile */
  .site-header{padding: 10px 0;}
  .site-header.scrolled{padding: 6px 0;}
  .brand-mark{width: 40px; height: 40px;}
  .brand-name{font-size: 1rem;}
  .brand-tag{font-size: 9px; margin-top: 2px;}
  .menu-toggle{width: 38px; height: 38px;}
  html{ scroll-padding-top: 72px; }

  .hero{padding-top:110px; padding-bottom:50px; align-items:center;}
  .hero-watermark-logo{
    width: 200px; height: 200px;
    right: -50px; top: auto; bottom: 6%;
    opacity: 0.05;
  }
  .hero-title{font-size: clamp(2.1rem, 8vw, 3rem);}
  .hero-sub{font-size: 0.98rem;}
  .hero-cta{margin-bottom: 28px;}

  /* Sections compactes mobile */
  .section{padding: 56px 0;}
  .section-head{margin-bottom: 30px;}
  .section-head h2,
  .split-text h2{font-size: clamp(1.7rem, 5.5vw, 2.1rem);}
  .container{padding:0 18px;}

  /* Réassurance compact */
  .reassure-row{padding: 18px 20px;}
  .reassure-item{font-size: 0.88rem;}

  /* Services compact */
  .services-subtitle--secondary{margin-top: 38px;}
  .services-priority{gap: 12px;}
  .service-card{padding: 22px 20px;}
  .service-card h4{font-size: 1.1rem;}
  .badge-icon{width: 42px; height: 42px; margin-bottom: 14px;}

  /* Pillars compact */
  .pillar{padding: 26px 22px;}
  .pillar h3{font-size: 1.15rem;}

  /* Comment ça se passe compact */
  .process-steps{gap: 26px; margin-top: 8px;}
  .process-step{padding: 26px 22px 22px;}

  /* Avis compact */
  .reviews-placeholder{gap: 12px; margin-top: 32px;}
  .review-empty{padding: 24px 20px;}
  .rating-num{font-size: 2.2rem;}
  .reviews-cta{flex-direction:column;}

  /* Zone compact */
  .cities-grid{gap: 8px;}
  .cities-grid li{padding: 14px 16px 14px 32px; font-size: 0.92rem;}

  /* Devis compact */
  .devis-form{padding: 24px;}

  /* Coords compact */
  .coords-item{padding: 22px 20px;}
  .coords-icon{width: 38px; height: 38px;}

  /* Footer compact */
  .site-footer{padding: 56px 0 24px;}
  .footer-grid{gap: 32px; padding-bottom: 36px;}
  .foot-bottom{flex-direction: column; align-items: flex-start; gap: 4px;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    transition: none !important;
    animation: none !important;
  }
  html{scroll-behavior: auto;}
}

/* ===================================================================
   PAGE MENTIONS LÉGALES (sobre)
   =================================================================== */
/* Header opaque en permanence (pas de hero sombre derrière sur cette page) */
.site-header.is-solid{
  background:rgba(15,42,30,0.96);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color: var(--line-dark);
}

.legal{
  padding: 140px 0 88px;
  background: var(--cream-50);
}
.legal .container{max-width: 820px;}
.legal-title{
  font-family:"Lora", Georgia, serif;
  font-weight:600;
  font-size: clamp(1.9rem, 4vw, 2.6rem);
  color: var(--green-900);
  margin: 0 0 36px;
}
.legal-block{margin: 0 0 34px;}
.legal-block:last-child{margin-bottom: 0;}
.legal-block h2{
  font-family:"Lora", Georgia, serif;
  font-weight:600;
  font-size: 1.25rem;
  color: var(--green-700);
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line-light);
}
.legal-block p{margin: 0 0 12px; color: var(--ink-700);}
.legal-block p:last-child{margin-bottom: 0;}
.legal-block a{
  color: var(--gold-700);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .2s var(--ease);
}
.legal-block a:hover{color: var(--green-700);}
.legal-list{display:flex; flex-direction:column; gap: 7px; margin: 0;}
.legal-list strong{color: var(--ink-900); font-weight:600;}

@media (max-width: 760px){
  .legal{padding: 110px 0 64px;}
}

/* Liens légaux dans le pied de page */
.foot-legal a{
  color: rgba(244,239,227,0.7);
  transition: color .2s var(--ease);
}
.foot-legal a:hover{color: var(--gold-500);}
.foot-sep{margin: 0 6px; color: rgba(244,239,227,0.4);}

/* Lien politique sous le formulaire */
.form-foot a{
  color: var(--gold-500);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.form-foot a:hover{color: var(--cream-100);}
