
/* ═══════════════════════ PALETTE ═══════════════════════ */
:root {
  --ivoire:    #ffffff;
  --ivoire-2:  #f7f5f0;
  --ivoire-3:  #e2ddd6;
  --or:        #c4923a;
  --or-clair:  #d4a843;
  --or-pale:   #fdf0d4;
  --ardoise:   #1e1e2e;   /* noir bleuté premium — fort contraste */
  --ardoise-2: #2d2d3f;   /* ardoise sombre */
  --cendre:    #555566;
  --cendre-2:  #a89e92;
  --lin:       #c8bfb0;
  --rouge:     #c0392b;
  --ciel:      #1a5276;
  --ciel-pale: #eaf4fb;
  --blanc:     #ffffff;
}

/* ═══ GLOBAL ACCESSIBILITY — HIGH CONTRAST TEXT ═══ */
body { color: #1e1e2e; }
.s-blanc *, .s-ivoire2 * { color: inherit; }
.s-blanc, .s-ivoire2 { color: #1e1e2e; }
.s-blanc h2.titre, .s-ivoire2 h2.titre { color: #1e1e2e; }
.s-blanc h3, .s-ivoire2 h3 { color: #1e1e2e; }
.s-blanc p, .s-ivoire2 p { color: #3a3a4a; }
.s-blanc .intro, .s-ivoire2 .intro { color: #3a3a4a; }
.srv p, .defend-card p { color: #3a3a4a; }
.note.n-or p, .note.n-or { color: #4a3800 !important; }
.note.n-ci p, .note.n-ci { color: #0e3a52 !important; }
.note.n-al p, .note.n-al { color: #6b1a10 !important; }
.loi-box blockquote { color: rgba(255,255,255,.92); }
.loi-box .loi-note { color: rgba(255,255,255,.6); }
/* Dark sections keep white text */
.s-ardoise *, .s-ardoise2 *, .hero * { color: inherit; }

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family: 'Raleway', sans-serif;
  background: var(--ivoire);
  color: var(--ardoise);
  line-height: 1.75;
  font-weight: 300;
  overflow-x: hidden;
  transition: font-family .3s;
}

/* ═══════════════════════ RTL (Arabe & Ourdou) ═══════════════════════ */
html[dir="rtl"] body {
  font-family: 'Noto Naskh Arabic', serif;
}
html[dir="rtl"] .hero-eyebrow::before { display:none; }
html[dir="rtl"] .hero-eyebrow::after {
  content:''; width:36px; height:1px; background:var(--or); flex-shrink:0;
}
html[dir="rtl"] .trait { margin-left:auto; margin-right:0; }
html[dir="rtl"] .section-eyebrow::before { display:none; }
html[dir="rtl"] .section-eyebrow::after {
  content:''; width:22px; height:1px; background:var(--or); display:block; order:-1;
}
html[lang="ur"] body { font-family:'Noto Nastaliq Urdu', serif; line-height:2.2; }
html[lang="de"] body { font-family:'Raleway',sans-serif; }
html[lang="pt"] body { font-family:'Raleway',sans-serif; }
html[lang="ur"] .nav-nom-1, html[lang="ur"] h1, html[lang="ur"] h2.titre,
html[lang="ur"] h3, html[lang="ur"] h4 { font-family:'Noto Nastaliq Urdu', serif; }

/* ═══════════════════════ GRAIN ═══════════════════════ */
body::after {
  content:''; position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}

/* ═══════════════════════ SÉLECTEUR DE LANGUE ═══════════════════════ */
.lang-bar {
  background: #1e1e2e;
  border-bottom: 1px solid rgba(184,146,74,.2);
  padding: .5rem 3.5rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
}
.lang-urgence {
  font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
  color: rgba(255,255,255,.45); font-weight:500;
}
.lang-urgence strong { color:var(--or-clair); }
.lang-switcher {
  display:flex; gap:.3rem; flex-wrap:wrap; align-items:center;
}
.lang-btn {
  background:none; border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.45);
  padding:.3rem .7rem; font-size:.62rem; letter-spacing:.08em;
  text-transform:uppercase; font-weight:500; font-family:'Raleway',sans-serif;
  transition: all .2s; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; gap:2px;
  line-height:1;
}
.lang-btn .flag { font-size:1.1rem; line-height:1; }
.lang-btn .code { font-size:.52rem; letter-spacing:.1em; }
.lang-btn:hover { border-color:rgba(184,146,74,.5); color:var(--or-clair); }
.lang-btn.active {
  background:var(--or); border-color:var(--or);
  color:var(--blanc); font-weight:600;
}

/* ═══════════════════════ NAVIGATION ═══════════════════════ */
nav {
  position:sticky; top:0; z-index:100;
  background:rgba(248,244,237,.97);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--ivoire-3);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 3.5rem; height:78px;
  box-shadow:0 1px 20px rgba(37,32,24,.06);
}
.nav-logo { display:flex; align-items:center; gap:1rem; text-decoration:none; }
.nav-monogramme {
  width:42px; height:42px; border:1.5px solid var(--or);
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:400;
  color:var(--or); transition:all .3s;
}
.nav-logo:hover .nav-monogramme { background:var(--or); color:var(--blanc); }
.nav-nom { display:flex; flex-direction:column; gap:1px; }
.nav-nom-1 {
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:500;
  letter-spacing:.06em; color:var(--ardoise); line-height:1.1; text-transform:uppercase;
}
.nav-nom-2 {
  font-size:.58rem; font-weight:500; letter-spacing:.28em;
  color:var(--or); text-transform:uppercase; line-height:1;
}
.nav-liens { display:flex; align-items:center; gap:.1rem; list-style:none; }
.nav-liens a {
  font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  color:var(--cendre); text-decoration:none; padding:.5rem 1rem;
  transition:color .2s; position:relative;
}
/* ── NAVIGATION DROPDOWN ── */
.nav-group { position:relative; }
.nav-group-title { display:flex; align-items:center; gap:3px; }
.nav-arrow { font-size:.5rem; opacity:.5; transition:transform .2s; }
.nav-group:hover .nav-arrow { transform:rotate(180deg); opacity:1; }
.nav-dropdown {
  display:none; position:absolute; top:calc(100% + 8px); left:50%;
  transform:translateX(-50%); background:var(--blanc);
  border:1px solid var(--ivoire-3); border-radius:8px;
  box-shadow:0 8px 24px rgba(61,53,40,.12); min-width:220px;
  z-index:200; padding:.4rem 0; white-space:nowrap;
}
.nav-group:hover .nav-dropdown { display:block; }
.nav-dropdown a {
  display:block; padding:.5rem 1.1rem; font-size:.75rem;
  color:var(--cendre) !important; font-weight:400;
  transition:background .12s, color .12s;
  border-bottom:.5px solid transparent;
}
.nav-dropdown a::after { display:none !important; }
.nav-dropdown a:hover { background:var(--ivoire); color:var(--ardoise) !important; }
.nav-dropdown a:first-child { border-radius:8px 8px 0 0; }
.nav-dropdown a:last-child { border-radius:0 0 8px 8px; }
@media(max-width:900px){
  .nav-group .nav-dropdown { display:none !important; }
}
.nav-liens a::after {
  content:''; position:absolute; bottom:0; left:1rem; right:1rem;
  height:1px; background:var(--or); transform:scaleX(0); transition:transform .3s;
}
.nav-liens a:hover { color:var(--ardoise); }
.nav-liens a:hover::after { transform:scaleX(1); }
.nav-cta {
  background:var(--ardoise)!important; color:var(--or-pale)!important;
  padding:.58rem 1.6rem!important; font-size:.6rem!important;
  letter-spacing:.18em!important; border:1px solid transparent!important;
  transition:all .3s!important;
  white-space:nowrap!important;
}
.nav-cta:hover { background:var(--or)!important; color:var(--blanc)!important; }
.nav-cta::after { display:none!important; }
/* FIX 1: Mobile CTA text variations */
@media(max-width:900px) {
  .nav-cta .long-text { display:none; }
  .nav-cta .short-text { display:inline; }
}

/* ═══════════════════════ HERO ═══════════════════════ */
.hero {
  min-height:94vh; background: #1e1e2e;
  display:grid; grid-template-columns:55% 45%;
  position:relative; overflow:hidden;
}
.hero-gauche {
  padding:10rem 5rem 8rem 5rem;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; z-index:2;
}
.hero-gauche::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 90% 70% at 0% 55%, rgba(184,146,74,.06) 0%, transparent 70%);
}
.hero-droit {
  position:relative; overflow:hidden;
  background:linear-gradient(160deg, #2d2d3f 0%, #1e1e2e 100%);
  border-left:1px solid rgba(184,146,74,.12);
}
.hero-droit::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%, rgba(184,146,74,.08) 0%, transparent 65%),
    linear-gradient(180deg, rgba(184,146,74,.03) 0%, transparent 100%);
}
.hero-pattern {
  position:absolute; inset:0; opacity:.05;
  background-image:
    repeating-linear-gradient(0deg, var(--or) 0, var(--or) 1px, transparent 1px, transparent 60px),
    repeating-linear-gradient(90deg, var(--or) 0, var(--or) 1px, transparent 1px, transparent 60px);
}
.hero-droit-inner {
  position:relative; z-index:2;
  padding:10rem 4rem 8rem 4rem;
  display:flex; flex-direction:column; justify-content:center; height:100%;
}
.hero-filigrane {
  position:absolute; bottom:-1rem; right:-1rem;
  font-family:'Cormorant Garamond',serif; font-size:22rem; font-weight:300;
  font-style:italic; color:rgba(184,146,74,.04); line-height:1;
  user-select:none; pointer-events:none; letter-spacing:-.04em;
}

.hero-eyebrow {
  display:flex; align-items:center; gap:1rem;
  font-size:.6rem; letter-spacing:.28em; text-transform:uppercase;
  font-weight:500; color:var(--or); margin-bottom:2.8rem; position:relative; z-index:2;
}
.hero-eyebrow::before { content:''; width:36px; height:1px; background:var(--or); flex-shrink:0; }

.hero h1 {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(3rem, 5.5vw, 5.2rem);
  font-weight:300; line-height:1.08; letter-spacing:-.01em;
  color:var(--blanc); margin-bottom:2rem; position:relative; z-index:2;
}
.hero h1 em { font-style:italic; color:var(--or-clair); }
.hero-desc {
  font-size:.95rem; color:rgba(255,255,255,.8); max-width:500px;
  line-height:1.9; margin-bottom:3.5rem; font-weight:300; position:relative; z-index:2;
}
.hero-desc strong { color:rgba(255,255,255,.8); font-weight:500; }
.hero-btns { display:flex; gap:1rem; flex-wrap:wrap; position:relative; z-index:2; }
.btn-or {
  background:var(--or); color:var(--blanc);
  padding:.9rem 2.4rem; font-size:.65rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; text-decoration:none;
  border:1px solid var(--or); transition:all .3s;
  font-family:'Raleway',sans-serif;
}
.btn-or:hover { background:transparent; color:var(--or); transform:translateY(-2px); box-shadow:0 8px 24px rgba(184,146,74,.2); }
.btn-ligne {
  background:transparent; color:rgba(255,255,255,.88);
  padding:.9rem 2.4rem; font-size:.65rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; text-decoration:none;
  border:1px solid rgba(255,255,255,.2); transition:all .3s;
  font-family:'Raleway',sans-serif;
}
.btn-ligne:hover { border-color:rgba(184,146,74,.6); color:var(--or-clair); transform:translateY(-2px); }

/* CARTES DÉLAIS dans hero droit */
.hero-delais { display:flex; flex-direction:column; gap:1rem; }
.delai-card {
  border:1px solid rgba(184,146,74,.18); padding:1.4rem 1.8rem;
  display:flex; align-items:center; gap:1.5rem;
  transition:border-color .3s, background .3s;
  background:rgba(255,255,255,.02);
}
.delai-card:hover { border-color:rgba(184,146,74,.4); background:rgba(184,146,74,.04); }
.delai-val {
  font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:400;
  color:var(--or-clair); line-height:1; flex-shrink:0; min-width:70px;
}
.delai-text h4 {
  font-size:.7rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(255,255,255,.75); margin-bottom:.2rem;
}
.delai-text p { font-size:.75rem; color:rgba(255,255,255,.82); line-height:1.5; }
.delai-ref {
  font-size:.58rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--or); background:rgba(184,146,74,.1); padding:.18rem .6rem;
  margin-top:.4rem; display:inline-block;
}

/* ═══════════════════════ BANDE OR ═══════════════════════ */
.bande-or {
  background:var(--or); padding:2.5rem 3.5rem;
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:linear-gradient(135deg, var(--or) 0%, var(--or-clair) 50%, var(--or) 100%);
}
.bande-chiffre {
  text-align:center; padding:1rem 1.5rem;
  border-right:1px solid rgba(255,255,255,.2);
}
.bande-chiffre:last-child { border-right:none; }
.bande-num {
  font-family:'Cormorant Garamond',serif; font-size:2.8rem; font-weight:400;
  color:var(--blanc); display:block; line-height:1;
}
.bande-label {
  font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.75); font-weight:500; margin-top:.4rem; display:block;
}

/* ═══════════════════════ SECTIONS COMMUNES ═══════════════════════ */
.section { padding:7rem 5rem; }
.s-ivoire  { background:var(--ivoire); }
.s-blanc   { background:var(--blanc); }
.s-ivoire2 { background:var(--ivoire-2); }
.s-ardoise { background: #1e1e2e; }
.s-ardoise2{ background: #2d2d3f; }

.container    { max-width:1180px; margin:0 auto; }
.container-sm { max-width:860px;  margin:0 auto; }

.section-eyebrow {
  display:flex; align-items:center; gap:.8rem;
  font-size:.6rem; letter-spacing:.24em; text-transform:uppercase;
  font-weight:600; color:var(--or); margin-bottom:1rem;
}
.section-eyebrow::before { content:''; width:22px; height:1px; background:var(--or); display:block; }

h2.titre {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem, 3.5vw, 3.2rem); font-weight:400; line-height:1.15;
  color:var(--ardoise); letter-spacing:-.01em;
}
.s-ardoise h2.titre, .s-ardoise2 h2.titre { color:#f5f3f0; }

.trait {
  width:48px; height:1px; background:var(--or);
  margin:1.4rem 0 2.2rem;
}
p.intro {
  font-size:.95rem; color:var(--cendre); line-height:1.9; max-width:700px; font-weight:300;
}
.s-ardoise p.intro, .s-ardoise2 p.intro { color:rgba(255,255,255,.82); }

/* ═══════════════════════ SERVICES ═══════════════════════ */
.services-grille {
  display:grid; grid-template-columns:repeat(3,1fr);
  margin-top:3rem; border:1px solid var(--ivoire-3);
  background:var(--ivoire-3);
  gap:1px;
}
.srv {
  background:var(--blanc); padding:2.8rem 2.2rem;
  position:relative; overflow:hidden; transition:background .25s;
}
.srv:hover { background:var(--ivoire); }
.srv::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  transition:opacity .3s;
}
.srv-1::before { background:linear-gradient(90deg,var(--or),var(--or-clair)); }
.srv-2::before { background:linear-gradient(90deg,var(--cendre-2),var(--lin)); }
.srv-3::before { background:linear-gradient(90deg,var(--ciel),#7baec8); }
.srv-4::before { background:linear-gradient(90deg,var(--or-clair),var(--or)); }
.srv-5::before { background:linear-gradient(90deg,var(--rouge),#b05a4a); }
.srv-6::before { background:linear-gradient(90deg,var(--ciel),var(--or)); }
.srv-num {
  font-family:'Cormorant Garamond',serif; font-size:4.5rem; font-weight:300;
  color:var(--ivoire-3); position:absolute; top:.8rem; right:1.5rem; line-height:1;
  pointer-events:none;
}
.srv h3 {
  font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:500;
  color:var(--ardoise); margin-bottom:.6rem; line-height:1.3;
}
.srv p { font-size:.83rem; color:var(--cendre); line-height:1.8; margin-bottom:1.2rem; }
.srv-tags { display:flex; flex-wrap:wrap; gap:.35rem; }
.tag {
  font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; font-weight:600;
  padding:.2rem .65rem; background:var(--ivoire-2); color:var(--cendre);
  border:1px solid var(--ivoire-3);
}

/* ═══════════════════════ DISPOSITIFS D'AIDE (section #rebond) ═══════════════════════ */
#rebond .services-grille { grid-template-columns:repeat(3,1fr); gap:1rem; border:none; background:transparent; }
#rebond .srv {
  display:flex; flex-direction:column; height:100%;
  padding:2rem; border-radius:8px; border:1.5px solid rgba(255,255,255,.08);
}
#rebond .srv-tags { margin-top:auto; padding-top:1rem; border-top:1px solid rgba(255,255,255,.05); }
#rebond .srv h3 { font-size:1.15rem; margin-bottom:1rem; line-height:1.35; }
#rebond .srv p { font-size:.8rem; line-height:1.7; margin-bottom:.8rem; }
#rebond .tag { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.1); color:rgba(255,255,255,.8); font-size:.65rem; }
#rebond .srv ul li { font-size:.8rem; }
#rebond .srv a { font-size:.8rem; }

/* Mobile : 1 colonne */
@media(max-width:768px) {
  #rebond .services-grille { grid-template-columns:1fr; gap:.8rem; }
  #rebond .srv { padding:1.5rem; }
}

/* Tablette : 2 colonnes */
@media(max-width:1024px) and (min-width:769px) {
  #rebond .services-grille { grid-template-columns:repeat(2,1fr); gap:1rem; }
}

/* ═══════════════════════ ÉTAPES ═══════════════════════ */
.etapes { margin-top:3.5rem; }
.etape-row { display:grid; grid-template-columns:64px 1fr; }
.et-gauche { display:flex; flex-direction:column; align-items:center; }
.et-badge {
  width:48px; height:48px; border:1px solid var(--or);
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400;
  color:var(--or); flex-shrink:0; z-index:1;
}
.et-ligne { flex:1; width:1px; background:linear-gradient(to bottom, var(--ivoire-3), transparent); }
.etape-row:last-child .et-ligne { display:none; }
.et-corps { padding:0 0 3rem 2.2rem; padding-top:.1rem; }
.et-puce {
  display:inline-block; font-size:.58rem; letter-spacing:.16em; text-transform:uppercase;
  font-weight:600; padding:.22rem .8rem; margin-bottom:.9rem;
  border:1px solid;
}
.ep-or  { border-color:rgba(184,146,74,.4); color:var(--or); background:rgba(184,146,74,.06); }
.ep-al  { border-color:rgba(139,58,42,.3);  color:var(--rouge); background:rgba(139,58,42,.04); }
.ep-ci  { border-color:rgba(74,124,158,.3); color:var(--ciel);  background:rgba(74,124,158,.04); }
.eb-oc  { background:var(--ivoire-2); color:var(--or); border-color:var(--ivoire-3); }
.eb-ci  { background:var(--ciel-pale); color:var(--ciel); border-color:rgba(74,124,158,.3); }
.et-corps h3 {
  font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:500;
  color:var(--ardoise); margin-bottom:.5rem;
}
.et-corps p { font-size:.85rem; color:var(--cendre); line-height:1.82; margin-bottom:.8rem; }

.pieces {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:.4rem; margin:.8rem 0;
}
.piece {
  background:var(--ivoire); border:1px solid var(--ivoire-3); border-left:2px solid var(--or);
  padding:.65rem 1rem; display:flex; align-items:flex-start; gap:.6rem;
  font-size:.78rem; color:var(--cendre); line-height:1.5;
}
.piece.ci { border-left-color:var(--ciel); }
.piece.al { border-left-color:var(--rouge); }
.piece-n { font-family:'Cormorant Garamond',serif; font-size:.9rem; color:var(--or); flex-shrink:0; }

.note {
  padding:1rem 1.4rem; margin:.8rem 0;
  font-size:.82rem; line-height:1.78;
  border-left:2px solid;
}
.n-or  { background:rgba(184,146,74,.05); border-color:var(--or);   color:var(--cendre); }
.n-al  { background:rgba(139,58,42,.04);  border-color:var(--rouge); color:var(--cendre); }
.n-ci  { background:rgba(74,124,158,.05); border-color:var(--ciel);  color:var(--cendre); }
.note strong { color:var(--ardoise); font-weight:500; }

/* ═══════════════════════ ENCADRÉS LÉGAUX ═══════════════════════ */
.loi-box {
  background: #1e1e2e; border-left:3px solid var(--or);
  padding:1.8rem 2.2rem; margin:1.5rem 0;
}
.loi-ref {
  font-size:.58rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; color:var(--or); display:block; margin-bottom:.8rem;
}
.loi-box blockquote {
  font-family:'Cormorant Garamond',serif; font-size:.95rem; font-style:italic;
  color:rgba(255,255,255,.82); line-height:1.9;
}
.loi-note {
  font-size:.75rem; color:rgba(255,255,255,.68); margin-top:.8rem;
  border-top:1px solid rgba(255,255,255,.08); padding-top:.7rem;
  font-style:normal; font-family:'Raleway',sans-serif;
}

/* ═══════════════════════ JURISPRUDENCES ═══════════════════════ */
.juris-grille {
  display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:2.5rem;
}
.juris-card {
  background:var(--blanc); border:1px solid var(--ivoire-3);
  padding:2rem 2rem; position:relative; overflow:hidden;
  transition:box-shadow .3s, transform .3s;
}
.juris-card:hover { box-shadow:0 12px 40px rgba(37,32,24,.08); transform:translateY(-3px); }
.juris-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
}
.jc-or::before { background:linear-gradient(90deg,var(--or),var(--or-clair)); }
.jc-ar::before { background:linear-gradient(90deg,var(--ardoise-2),var(--cendre)); }
.jc-ci::before { background:linear-gradient(90deg,var(--ciel),#7baec8); }
.jc-mi::before { background:linear-gradient(90deg,var(--or),var(--ciel)); }
.j-ref {
  font-size:.58rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:600; display:block; margin-bottom:1rem;
}
.jc-or .j-ref { color:var(--or); }
.jc-ar .j-ref { color:var(--cendre); }
.jc-ci .j-ref { color:var(--ciel); }
.jc-mi .j-ref { color:var(--or); }
.juris-card blockquote {
  font-family:'Cormorant Garamond',serif; font-size:.93rem; font-style:italic;
  color:var(--ardoise); line-height:1.85;
  border-left:1px solid var(--ivoire-3); padding-left:1rem; margin-bottom:1rem;
}
.j-analyse { font-size:.78rem; color:var(--cendre-2); line-height:1.7; }
.j-analyse strong { color:var(--cendre); font-weight:500; }

/* ═══════════════════════ DÉFENSE ═══════════════════════ */
.defend-grille { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:3rem; }
.defend-card {
  background:var(--blanc); padding:3rem 2.5rem;
  border:1px solid var(--ivoire-3); position:relative;
  transition:box-shadow .3s;
}
.defend-card:hover { box-shadow:0 16px 48px rgba(37,32,24,.08); }
.defend-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
}
.dd-or::after { background:linear-gradient(90deg,var(--or),var(--or-clair)); }
.dd-ci::after { background:linear-gradient(90deg,var(--ciel),#7baec8); }
.dd-num {
  font-family:'Cormorant Garamond',serif; font-size:6rem; font-weight:300;
  color:var(--ivoire-2); line-height:1; margin-bottom:.5rem;
}
.defend-card h3 {
  font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:500;
  color:var(--ardoise); margin-bottom:1rem;
}
.defend-card > p { font-size:.85rem; color:var(--cendre); line-height:1.85; margin-bottom:1.5rem; }
.defend-list { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.defend-list li {
  display:flex; align-items:flex-start; gap:.8rem;
  font-size:.82rem; color:var(--cendre); line-height:1.6;
}
.dl-puce { width:6px; height:6px; border-radius:50%; flex-shrink:0; margin-top:.45rem; }
.dd-or .dl-puce { background:var(--or); }
.dd-ci .dl-puce { background:var(--ciel); }

/* ═══════════════════════ RECOURS ═══════════════════════ */
.recours-grille { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.recours-card {
  border:1px solid rgba(255,255,255,.08); padding:2.5rem 2rem;
  position:relative; transition:border-color .3s, background .3s;
}
.recours-card:hover { border-color:rgba(184,146,74,.3); background:rgba(184,146,74,.03); }
.recours-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
}
.rc1::before { background:var(--or); }
.rc2::before { background:var(--or-clair); }
.rc3::before { background:var(--ciel); }
.rc-num {
  font-family:'Cormorant Garamond',serif; font-size:4rem; font-weight:300;
  color:rgba(184,146,74,.15); line-height:1; margin-bottom:.8rem;
}
.recours-card h3 {
  font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:500;
  color:var(--ivoire-2); margin-bottom:.5rem;
}
.recours-card .rc-art {
  font-size:.58rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:600; color:var(--or); margin-bottom:1rem; display:block;
}
.recours-card p { font-size:.82rem; color:rgba(255,255,255,.75); line-height:1.78; margin-bottom:.8rem; }

/* ═══════════════════════ TEXTES LÉGAUX ═══════════════════════ */
.textes-grille { display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; margin-top:3rem; }
.tx-bloc { border-bottom:1px solid var(--ivoire-3); }
.tx-btn {
  width:100%; background:none; border:none;
  display:flex; justify-content:space-between; align-items:flex-start; gap:1rem;
  padding:1rem 0; font-family:'Raleway',sans-serif; font-size:.8rem;
  font-weight:500; text-align:left; color:var(--ardoise); transition:color .2s;
}
.tx-btn:hover { color:var(--or); }
.tx-ref { flex:1; line-height:1.45; }
.tx-ico {
  width:20px; height:20px; border:1px solid var(--ivoire-3);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; color:var(--or); transition:transform .3s, background .2s;
  flex-shrink:0; margin-top:.1rem;
}
.tx-btn.open .tx-ico { transform:rotate(45deg); background:var(--or); color:var(--blanc); border-color:var(--or); }
.tx-panel { max-height:0; overflow:hidden; transition:max-height .45s ease; }
.tx-panel.open { max-height:1400px; }
.tx-inner { padding-bottom:1.4rem; }
.tx-source {
  font-size:.6rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:600; color:var(--cendre-2); margin-bottom:.7rem; display:block;
}
.tx-texte {
  font-family:'Cormorant Garamond',serif; font-size:.92rem; font-style:italic;
  color:var(--ardoise-2); line-height:1.9; border-left:2px solid var(--ivoire-3);
  padding:.9rem 1rem .9rem 1.2rem; margin:0;
  background:var(--ivoire); transition:border-color .3s;
}
.tx-bloc:hover .tx-texte { border-left-color:var(--or-pale); }

/* ═══════════════════════ CONTACT ═══════════════════════ */
.contact-grille { display:grid; grid-template-columns:1fr 1fr; gap:5rem; margin-top:3rem; }
.form-groupe { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1.1rem; }
.form-groupe label {
  font-size:.58rem; letter-spacing:.16em; text-transform:uppercase;
  font-weight:600; color:var(--cendre-2);
}
.form-groupe input, .form-groupe textarea, .form-groupe select {
  border:1px solid var(--ivoire-3); background:var(--blanc);
  padding:.85rem 1.1rem; font-family:'Raleway',sans-serif; font-size:.88rem;
  color:var(--ardoise); outline:none; transition:border-color .2s;
  appearance:none;
}
.form-groupe input:focus, .form-groupe textarea:focus, .form-groupe select:focus {
  border-color:var(--or);
}
.form-groupe textarea { min-height:110px; resize:vertical; }
.form-ligne { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.btn-submit {
  width:100%; background:var(--ardoise); color:var(--or-pale); border:none;
  padding:1.1rem; font-family:'Raleway',sans-serif; font-size:.65rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; transition:all .3s;
}
.btn-submit:hover { background:var(--or); color:var(--blanc); }

.contact-infos { display:flex; flex-direction:column; gap:1.2rem; }
.ci-bloc {
  padding:1.8rem 2rem; background:var(--ivoire);
  border:1px solid var(--ivoire-3); border-top:2px solid;
  transition:box-shadow .25s;
}
.ci-bloc:hover { box-shadow:0 6px 20px rgba(37,32,24,.07); }
.ci-or { border-top-color:var(--or); }
.ci-ci { border-top-color:var(--ciel); }
.ci-ar { border-top-color:var(--ardoise); }
.ci-bloc h4 {
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:500;
  color:var(--ardoise); margin-bottom:.4rem;
}
.ci-bloc p { font-size:.82rem; color:var(--cendre); line-height:1.7; }
.urgence-bloc {
  background: #1e1e2e; padding:2rem; border:1px solid rgba(196,146,58,.2);
}
.ub-label {
  font-size:.58rem; letter-spacing:.2em; text-transform:uppercase;
  font-weight:600; color:var(--or); display:block; margin-bottom:.6rem;
}
.urgence-bloc h4 {
  font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--ivoire-2); margin-bottom:.4rem;
}
.urgence-bloc p { font-size:.8rem; color:rgba(255,255,255,.75); margin-bottom:.9rem; }
.urgence-tel {
  font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:400;
  color:var(--or-clair); display:block; letter-spacing:.02em;
}

/* ═══════════════════════ FOOTER ═══════════════════════ */
footer {
  background: #1e1e2e;
  padding:4.5rem 3.5rem 2.5rem;
}
.footer-grille {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem; max-width:1180px; margin:0 auto 3rem;
}
.footer-logo {
  font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:400;
  color:var(--or-clair); letter-spacing:.06em; text-transform:uppercase;
  display:block; margin-bottom:1rem;
}
.footer-brand p { font-size:.78rem; color:rgba(255,255,255,.65); line-height:1.8; }
.footer-col h5 {
  font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; font-weight:600;
  color:rgba(255,255,255,.60); margin-bottom:1.2rem;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
.footer-col a {
  font-size:.78rem; color:rgba(255,255,255,.72); text-decoration:none; transition:color .2s;
}
.footer-col a:hover { color:var(--or-clair); }
.footer-bas {
  border-top:1px solid rgba(255,255,255,.06); padding-top:2rem;
  max-width:1180px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
}
.footer-bas p { font-size:.62rem; color:rgba(255,255,255,.18); }
.footer-badges { display:flex; gap:.4rem; }
.fbadge {
  font-size:.55rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  padding:.25rem .7rem; border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.60);
}

/* ═══════════════════════ SCROLL REVEAL ═══════════════════════ */
.sr { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.sr.on { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

/* ═══════════════════════ RESPONSIVE ═══════════════════════ */
@media(max-width:1100px){
  .hero { grid-template-columns:1fr; }
  .hero-droit { display:none; }
  .bande-or { grid-template-columns:1fr 1fr; }
  .services-grille { grid-template-columns:1fr 1fr; }
  .recours-grille { grid-template-columns:1fr; }
}
@media(max-width:900px){
  nav { padding:0 1.5rem; }
  .nav-liens { display:none; }
  .section { padding:4rem 1.5rem; }
  .lang-bar { padding:.5rem 1.5rem; flex-direction:column; gap:.5rem; text-align:center; }
  .services-grille, .juris-grille, .defend-grille, .contact-grille, .textes-grille { grid-template-columns:1fr; }
  .footer-grille { grid-template-columns:1fr 1fr; }
  .hero-gauche { padding:6rem 2rem 5rem; }
  .form-ligne { grid-template-columns:1fr; }
  .bande-or { grid-template-columns:1fr 1fr; padding:2rem 1.5rem; }
}

/* ═══════════════════════ MASQUAGE LANGUE ═══════════════════════ */
[data-lang] { display:none; }
[data-lang].active-lang { display:block; }
.inline-lang { display:none; }
.inline-lang.active-lang { display:inline; }

</style>
<style>
/* ── OVERLAY ACCUEIL ── */
#accueil-overlay {
  position:fixed; inset:0; z-index:9999;
  background:rgba(10,10,20,.92);
  backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center;
  opacity:1; transition:opacity .5s;
  font-family:'Raleway',sans-serif;
}
#accueil-overlay.closing { opacity:0; pointer-events:none; }

.accueil-modal {
  width:min(680px,94vw);
  background:#ffffff;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.4), 0 0 0 1px rgba(196,146,58,.2);
  display:flex; flex-direction:column;
  max-height:92vh;
}

.acc-header {
  background:linear-gradient(135deg, #1e1e2e 0%, #2d2d3f 100%);
  padding:2rem 2rem 1.5rem;
  position:relative; overflow:hidden;
}
.acc-header::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 30% 50%, rgba(196,146,58,.12) 0%, transparent 70%);
}
.acc-header-inner { position:relative; z-index:1; display:flex; align-items:center; gap:1rem; }
.lexia-avatar {
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg, #c4923a, #d4a843);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; flex-shrink:0;
  box-shadow:0 0 0 3px rgba(196,146,58,.3);
  animation:pulse-ring 2.5s ease-in-out infinite;
}
@keyframes pulse-ring {
  0%,100%{ box-shadow:0 0 0 3px rgba(196,146,58,.3); }
  50%{ box-shadow:0 0 0 7px rgba(196,146,58,.1); }
}
.lexia-info h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem; font-weight:500; color:#f5f3f0; margin:0 0 2px;
}
.lexia-info p { font-size:.72rem; color:rgba(255,255,255,.65); margin:0; letter-spacing:.08em; text-transform:uppercase; }
.lexia-status {
  margin-left:auto; display:flex; align-items:center; gap:5px;
  font-size:.65rem; color:rgba(255,255,255,.6); letter-spacing:.06em;
}
.lexia-dot { width:7px; height:7px; border-radius:50%; background:#4caf50; animation:blink 1.8s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.acc-body { padding:1.5rem 2rem; overflow-y:auto; flex:1; }

.acc-message {
  background:#f7f5f0; border-radius:12px; padding:1rem 1.2rem;
  margin-bottom:1.2rem; border-left:3px solid #c4923a;
}
.acc-message p { font-size:.88rem; color:#1e1e2e; line-height:1.75; margin:0; }

.acc-quick-btns {
  display:grid; grid-template-columns:1fr 1fr; gap:.6rem;
  margin-bottom:1.2rem;
}
.acc-btn {
  padding:.75rem 1rem; background:#f7f5f0; border:1.5px solid #e2ddd6;
  border-radius:8px; cursor:pointer; text-align:left;
  transition:all .15s; font-family:'Raleway',sans-serif;
}
.acc-btn:hover { border-color:#c4923a; background:#fff8ea; }
.acc-btn .btn-ico { font-size:1.1rem; display:block; margin-bottom:3px; }
.acc-btn .btn-lbl { font-size:.78rem; font-weight:500; color:#1e1e2e; display:block; }
.acc-btn .btn-sub { font-size:.68rem; color:#555566; display:block; margin-top:1px; }

.acc-divider { display:flex; align-items:center; gap:.8rem; margin:.8rem 0; }
.acc-divider span { font-size:.7rem; color:#888899; white-space:nowrap; }
.acc-divider::before, .acc-divider::after { content:''; flex:1; height:.5px; background:#e2ddd6; }

.acc-input-row { display:flex; gap:.6rem; }
.acc-input {
  flex:1; padding:.75rem 1rem; font-size:.85rem;
  border:1.5px solid #e2ddd6; border-radius:8px;
  font-family:'Raleway',sans-serif; color:#1e1e2e;
  background:#fff; outline:none; transition:border-color .15s;
}
.acc-input:focus { border-color:#c4923a; }
.acc-send {
  padding:.75rem 1.2rem; background:#1e1e2e; color:#fff;
  border:none; border-radius:8px; cursor:pointer;
  font-family:'Raleway',sans-serif; font-size:.82rem; font-weight:500;
  transition:background .15s; display:flex; align-items:center; gap:5px;
}
.acc-send:hover { background:#c4923a; }
.acc-send:disabled { opacity:.4; cursor:not-allowed; }

.acc-response {
  margin-top:1rem; padding:1rem 1.1rem;
  background:#eaf4fb; border-radius:8px; border-left:3px solid #1a5276;
  font-size:.85rem; color:#0e3a52; line-height:1.7;
  display:none;
}
.acc-nav-links {
  margin-top:.8rem; display:flex; flex-wrap:wrap; gap:.4rem;
}
.acc-nav-link {
  display:inline-block; padding:.3rem .9rem;
  background:#1e1e2e; color:#fff !important;
  border-radius:99px; font-size:.72rem; text-decoration:none;
  font-family:'Raleway',sans-serif; font-weight:500;
  transition:background .15s;
}
.acc-nav-link:hover { background:#c4923a !important; }

.acc-footer {
  padding:1rem 2rem; background:#f7f5f0;
  border-top:.5px solid #e2ddd6;
  display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap;
}
.acc-skip {
  font-size:.72rem; color:#888899; cursor:pointer;
  background:none; border:none; font-family:'Raleway',sans-serif;
  text-decoration:underline; transition:color .15s;
}
.acc-skip:hover { color:#1e1e2e; }
.acc-langs { display:flex; gap:.3rem; flex-wrap:wrap; }
.acc-lang-btn {
  font-size:.68rem; padding:.25rem .6rem;
  background:transparent; border:.5px solid #e2ddd6; border-radius:4px;
  cursor:pointer; color:#555566; font-family:'Raleway',sans-serif;
  transition:all .15s;
}
.acc-lang-btn:hover, .acc-lang-btn.active { background:#1e1e2e; color:#fff; border-color:#1e1e2e; }
.spin-small { display:inline-block; width:11px; height:11px; border:2px solid rgba(255,255,255,.3); border-top-color:#fff; border-radius:50%; animation:spin .6s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ── CARTE DE VISITE + QR ── */
#carte-visite {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:8000;
  display:none; /* shown after welcome dismissed */
}
.carte-toggle {
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg, #1e1e2e, #2d2d3f);
  border:2px solid rgba(196,146,58,.4);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; box-shadow:0 4px 20px rgba(0,0,0,.3);
  transition:all .2s; font-size:1.2rem;
}
.carte-toggle:hover { transform:scale(1.08); border-color:var(--or); }
.carte-panel {
  position:absolute; bottom:64px; right:0;
  width:280px; background:#ffffff;
  border-radius:12px; overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.25), 0 0 0 1px rgba(196,146,58,.15);
  display:none; transform:translateY(8px); transition:all .2s;
}
.carte-panel.open { display:block; transform:translateY(0); }
.carte-top {
  background:linear-gradient(135deg, #1e1e2e 0%, #2d2d3f 100%);
  padding:1.2rem 1.4rem; position:relative; overflow:hidden;
}
.carte-top::after {
  content:''; position:absolute; bottom:-20px; right:-20px;
  width:80px; height:80px; border-radius:50%;
  background:rgba(196,146,58,.06);
}
.carte-monogramme {
  font-family:'Cormorant Garamond',serif;
  font-size:2rem; font-weight:500; color:#c4923a;
  line-height:1; margin-bottom:.3rem;
}
.carte-nom { font-size:.92rem; font-weight:600; color:#f5f3f0; letter-spacing:.04em; }
.carte-titre { font-size:.65rem; color:rgba(255,255,255,.6); letter-spacing:.12em; text-transform:uppercase; margin-top:2px; }
.carte-body { padding:1rem 1.2rem; }
.carte-ligne {
  display:flex; align-items:center; gap:.6rem;
  padding:.35rem 0; border-bottom:.5px solid #f0ede8;
  font-size:.75rem; color:#1e1e2e;
}
.carte-ligne:last-of-type { border-bottom:none; }
.carte-ligne .ico { color:#c4923a; width:14px; text-align:center; flex-shrink:0; }
.qr-zone {
  padding:.8rem 1.2rem 1rem;
  border-top:.5px solid #f0ede8;
  display:flex; align-items:center; gap:.8rem;
}
.qr-box {
  width:70px; height:70px; background:#1e1e2e;
  border-radius:6px; display:flex; align-items:center;
  justify-content:center; flex-shrink:0; padding:5px;
}
.qr-box svg { width:60px; height:60px; }
.qr-text { font-size:.68rem; color:#555566; line-height:1.6; }
.qr-text strong { color:#1e1e2e; display:block; margin-bottom:2px; }

/* ═══════════════════════ RESPONSIVE NAV — HAMBURGER MOBILE ═══════════════════════ */
.nav-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
  padding: 0.5rem;
  z-index: 101;
}
.nav-hamburger span {
  width: 24px;
  height: 2px;
  background: var(--ardoise);
  transition: all 0.3s;
  display: block;
}
.nav-hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translateY(10px);
}
.nav-hamburger.active span:nth-child(2) {
  opacity: 0;
}
.nav-hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translateY(-10px);
}

@media (max-width: 900px) {
  nav {
    padding: 0 1.25rem;
    height: auto;
    position: relative;
  }

  .nav-hamburger {
    display: flex;
  }

  .nav-liens {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    background: white;
    border-top: 1px solid var(--ivoire-3);
    box-shadow: 0 4px 12px rgba(37, 32, 24, 0.1);
    padding: 1rem 0;
    gap: 0;
    z-index: 100;
  }

  .nav-liens.active {
    display: flex;
  }

  .nav-liens a {
    padding: 0.75rem 1.25rem;
    border-bottom: 1px solid var(--ivoire-3);
    font-size: 0.8rem;
  }

  .nav-liens a:last-child {
    border-bottom: none;
  }

  .nav-group .nav-dropdown {
    position: static;
    display: none !important;
    transform: none;
    background: var(--ivoire-2);
    border: none;
    box-shadow: none;
    padding: 0;
    min-width: auto;
  }

  .nav-group {
    position: relative;
  }

  .nav-group:hover .nav-dropdown,
  .nav-group.active .nav-dropdown {
    display: block !important;
  }

  .nav-dropdown a {
    padding: 0.5rem 2rem;
    font-size: 0.7rem;
  }

  .lang-bar {
    flex-direction: column;
    padding: 0.75rem 1.25rem;
    gap: 0.75rem;
  }

  .lang-urgence {
    font-size: 0.55rem;
  }

  .lang-switcher {
    gap: 0.2rem;
  }

  .lang-btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.5rem;
  }

  .hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .hero-gauche {
    padding: 3rem 1.25rem 2rem;
  }

  .hero-droit {
    border-left: none;
    border-top: 1px solid rgba(184, 146, 74, 0.12);
    padding: 2rem 1.25rem;
  }

  .hero-droit-inner {
    padding: 0;
  }

  .hero h1 {
    font-size: clamp(1.8rem, 5vw, 2.5rem);
  }

  .hero-desc {
    font-size: 0.85rem;
  }

  .bande-or {
    grid-template-columns: repeat(2, 1fr);
    padding: 1.5rem 1.25rem;
    gap: 0;
  }

  .bande-chiffre {
    border-right: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    padding: 1rem;
  }

  .bande-chiffre:nth-child(3),
  .bande-chiffre:nth-child(4) {
    border-bottom: none;
  }
}

@media (max-width: 768px) {
  nav {
    padding: 0 1rem;
  }

  .nav-logo {
    gap: 0.5rem;
  }

  .nav-monogramme {
    width: 36px;
    height: 36px;
    font-size: 1rem;
  }

  .nav-nom-1 {
    font-size: 0.95rem;
  }

  .nav-nom-2 {
    font-size: 0.5rem;
  }

  .container {
    padding: 0 1rem;
  }

  .section {
    padding: clamp(2rem, 8vw, 4rem) 0 !important;
  }

  h2.titre {
    font-size: clamp(1.5rem, 4vw, 2.2rem) !important;
  }

  .grille-4 {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 480px) {
  .lang-urgence {
    font-size: 0.5rem;
  }

  .hero-btns {
    flex-direction: column;
  }

  .btn-or,
  .btn-ligne {
    width: 100%;
    text-align: center;
  }

  .delai-card {
    flex-direction: column;
    text-align: center;
  }

  .delai-val {
    min-width: auto;
  }
}

/* ═══ ÉTAT ACTIF (page courante) ═══ */
.nav-active { color: var(--or) !important; }
.nav-active::after { transform: scaleX(1) !important; }
.nav-cta.nav-active { 
  background: var(--or) !important; 
  color: var(--blanc) !important; 
}

/* ═══ FIX MOBILE — masquer le grain pour gain perf ═══ */
@media (max-width: 768px) {
  body::after { display: none; }
}

/* ═══ FIX RESPONSIVE TYPOGRAPHIE ═══ */
@media (max-width: 768px) {
  h1 { font-size: clamp(1.75rem, 6vw, 2.75rem) !important; }
  h2.titre { font-size: clamp(1.5rem, 5vw, 2.25rem) !important; }
  .section { padding: 3rem 1.25rem !important; }
}

/* ═══ FIX HAMBURGER COULEUR (visible) ═══ */
.nav-hamburger span { background: var(--ardoise); }

/* ════════════════════════════════════════════════════════════════════ */
/* LEXIA WIDGET — Bulle flottante en bas à droite                       */
/* ════════════════════════════════════════════════════════════════════ */

#lexia-widget {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9000;
  font-family: 'Raleway', sans-serif;
}
html[dir="rtl"] #lexia-widget {
  right: auto;
  left: 1.5rem;
}

/* ── Bulle ── */
#lexia-bubble {
  position: relative;
  width: 68px; height: 68px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--or) 0%, var(--or-clair) 100%);
  color: var(--ardoise);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 32px rgba(196,146,58,.35), 0 0 0 1px rgba(196,146,58,.5);
  transition: transform .25s, box-shadow .25s;
}
#lexia-bubble:hover {
  transform: scale(1.08);
  box-shadow: 0 16px 40px rgba(196,146,58,.5), 0 0 0 2px rgba(196,146,58,.7);
}
#lexia-bubble.open {
  background: linear-gradient(135deg, var(--or-clair) 0%, var(--or) 100%);
  color: var(--ardoise);
}
.lexia-bubble-badge {
  position: absolute;
  top: -4px; right: -4px;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: #c0392b;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: .9rem;
  box-shadow: 0 4px 12px rgba(192,57,43,.4);
}
.lexia-bubble-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(196,146,58,.4);
  opacity: .4;
  animation: lexia-pulse 3s infinite;
}
#lexia-bubble.open .lexia-bubble-pulse { display: none; }
@keyframes lexia-pulse {
  0%   { transform: scale(1);    opacity: .4; }
  70%  { transform: scale(1.3);  opacity: 0; }
  100% { transform: scale(1.3);  opacity: 0; }
}

/* ── Tooltip "Besoin d'aide ?" ── */
.lexia-help-tooltip {
  position: absolute;
  bottom: 76px; right: 0;
  background: var(--ardoise);
  color: var(--ivoire);
  padding: .6rem .9rem;
  border-radius: 8px;
  font-size: .85rem;
  font-weight: 500;
  white-space: nowrap;
  box-shadow: 0 6px 16px rgba(0,0,0,.2);
  animation: lexia-tooltip-in .3s ease-out;
  z-index: 10;
}
.lexia-help-tooltip::after {
  content: '';
  position: absolute;
  bottom: -6px; right: 12px;
  width: 8px; height: 8px;
  background: var(--ardoise);
  transform: rotate(45deg);
}
.lexia-help-tooltip-hide {
  animation: lexia-tooltip-out .3s ease-in forwards;
}
@keyframes lexia-tooltip-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes lexia-tooltip-out {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(8px); }
}

/* ── Panneau (caché par défaut, ouvert via .lexia-panel-open) ── */
#lexia-panel {
  position: absolute;
  bottom: 70px; right: 0;
  width: 380px;
  max-width: calc(100vw - 3rem);
  max-height: calc(100vh - 6rem);
  background: var(--blanc);
  border-radius: 14px;
  box-shadow: 0 24px 60px rgba(0,0,0,.25), 0 0 0 1px rgba(184,146,74,.18);
  display: none;
  flex-direction: column;
  overflow: hidden;
}
#lexia-panel.lexia-panel-open {
  display: flex;
  animation: lexia-slide-up .25s ease-out;
}
html[dir="rtl"] #lexia-panel { right: auto; left: 0; }
@keyframes lexia-slide-up {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Header ── */
.lexia-head {
  display: flex; align-items: center; gap: .8rem;
  padding: 1rem 1.2rem;
  background: linear-gradient(135deg, var(--ardoise) 0%, var(--ardoise-2) 100%);
  color: var(--ivoire);
  position: relative;
}
.lexia-head-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--or) 0%, var(--or-clair) 100%);
  color: var(--ardoise);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  font-weight: 600;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(196,146,58,.3);
}
.lexia-head-info { flex: 1; min-width: 0; }
.lexia-head-title {
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .01em;
  color: var(--ivoire);
}
.lexia-head-subtitle {
  font-size: .68rem;
  color: rgba(255,255,255,.6);
  display: flex; align-items: center; gap: .4rem;
  margin-top: 2px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.lexia-status-dot {
  width: 7px; height: 7px;
  background: #4ade80;
  border-radius: 50%;
  display: inline-block;
  box-shadow: 0 0 0 2px rgba(74,222,128,.3);
}
.lexia-close {
  background: none; border: none;
  color: rgba(255,255,255,.7);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  padding: .25rem .5rem;
  border-radius: 4px;
  transition: background .2s;
}
.lexia-close:hover { background: rgba(255,255,255,.1); color: var(--ivoire); }

/* ── Body ── */
.lexia-body {
  flex: 1;
  padding: 1rem 1.2rem;
  overflow-y: auto;
  background: var(--ivoire-2);
}
.lexia-msg {
  padding: .8rem 1rem;
  border-radius: 12px;
  font-size: .82rem;
  line-height: 1.6;
  margin-bottom: .8rem;
  max-width: 92%;
}
.lexia-msg-bot {
  background: var(--blanc);
  color: var(--ardoise);
  border: 1px solid var(--ivoire-3);
  border-top-left-radius: 4px;
}
.lexia-msg-user {
  background: var(--ardoise);
  color: var(--ivoire);
  margin-left: auto;
  border-top-right-radius: 4px;
}
html[dir="rtl"] .lexia-msg-user { margin-left: 0; margin-right: auto; border-top-left-radius: 4px; border-top-right-radius: 12px; }

.lexia-cases-label {
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cendre);
  margin: 1rem 0 .5rem;
}
.lexia-cases {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  margin-bottom: 1rem;
}
.lexia-case-btn {
  display: flex; align-items: center; gap: .6rem;
  padding: .65rem .85rem;
  background: var(--blanc);
  border: 1px solid var(--ivoire-3);
  border-radius: 8px;
  cursor: pointer;
  font-size: .8rem;
  color: var(--ardoise);
  text-align: left;
  transition: all .2s;
  font-family: inherit;
}
.lexia-case-btn:hover {
  border-color: var(--or);
  background: var(--or-pale);
  transform: translateX(2px);
}
html[dir="rtl"] .lexia-case-btn { text-align: right; }
html[dir="rtl"] .lexia-case-btn:hover { transform: translateX(-2px); }
.lexia-case-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
}
.lexia-link {
  display: inline-block;
  margin-top: .5rem;
  color: var(--or);
  font-weight: 600;
  text-decoration: none;
  font-size: .78rem;
}
.lexia-link:hover { color: var(--ardoise); text-decoration: underline; }

/* ── Footer ── */
.lexia-foot {
  padding: .8rem 1.2rem;
  background: var(--blanc);
  border-top: 1px solid var(--ivoire-3);
}
.lexia-input-row {
  display: flex;
  gap: .5rem;
}
#lexia-input {
  flex: 1;
  padding: .6rem .8rem;
  border: 1px solid var(--ivoire-3);
  border-radius: 8px;
  font-size: .82rem;
  font-family: inherit;
  outline: none;
  transition: border-color .2s;
}
#lexia-input:focus { border-color: var(--or); }
#lexia-send {
  width: 38px; height: 38px;
  background: var(--or);
  color: var(--ivoire);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
#lexia-send:hover { background: var(--or-clair); }
.lexia-disclaimer {
  margin-top: .6rem;
  font-size: .65rem;
  color: var(--cendre);
  line-height: 1.4;
  text-align: center;
}

/* ── Mobile ── */
@media (max-width: 480px) {
  #lexia-widget { bottom: 1rem; right: 1rem; }
  html[dir="rtl"] #lexia-widget { right: auto; left: 1rem; }
  #lexia-panel {
    width: calc(100vw - 2rem);
    max-height: calc(100vh - 5rem);
  }
  #lexia-bubble { width: 60px; height: 60px; }
  .lexia-help-tooltip { font-size: .8rem; }
}

/* ════════════════════════════════════════════════════════════════════ */
/* ACCORDÉONS — FIX 5 Parties-prenantes                                  */
/* ════════════════════════════════════════════════════════════════════ */
/* Utilise les H3 existants comme accordéons au CSS pour meilleure lisibilité mobile */
#salaries h3:not(.titre),
#creanciers h3:not(.titre),
#negociation h3:not(.titre),
#cession h3:not(.titre) {
  cursor: pointer;
  user-select: none;
  padding: .9rem 1rem;
  background: linear-gradient(135deg, var(--ivoire-2) 0%, var(--ivoire-3) 100%);
  border-left: 3px solid var(--or);
  margin-bottom: .5rem;
  transition: all .25s;
  position: relative;
}
#salaries h3:not(.titre)::before,
#creanciers h3:not(.titre)::before,
#negociation h3:not(.titre)::before,
#cession h3:not(.titre)::before {
  content: '▾';
  position: absolute;
  right: 1rem;
  transition: transform .25s;
  color: var(--or);
  font-weight: bold;
}
#salaries h3:not(.titre):hover,
#creanciers h3:not(.titre):hover,
#negociation h3:not(.titre):hover,
#cession h3:not(.titre):hover {
  background: linear-gradient(135deg, var(--ivoire) 0%, var(--ivoire-2) 100%);
  box-shadow: 0 2px 6px rgba(30,30,46,.08);
}

details.acc-section {
  margin-bottom: 1.2rem;
}
details.acc-section summary {
  cursor: pointer;
  padding: 1rem 1.2rem;
  background: linear-gradient(135deg, var(--ivoire-2) 0%, var(--ivoire-3) 100%);
  border-left: 3px solid var(--or);
  font-weight: 500;
  color: var(--ardoise);
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
  transition: all .25s;
  list-style: none;
}
details.acc-section summary:hover {
  background: linear-gradient(135deg, var(--ivoire) 0%, var(--ivoire-2) 100%);
  box-shadow: 0 2px 8px rgba(30,30,46,.08);
}
details.acc-section summary::after {
  content: '▾';
  transition: transform .25s;
  font-size: .9rem;
  color: var(--or);
  margin-left: 1rem;
}
details.acc-section[open] summary::after {
  transform: rotate(180deg);
}
details.acc-section > *:not(summary) {
  padding: 1rem 1.2rem;
  background: var(--ivoire);
  border-left: 3px solid rgba(196,146,58,.2);
  animation: acc-slide-down .25s ease-out;
}
@keyframes acc-slide-down {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}
@media print {
  details.acc-section > *:not(summary) { display: block !important; }
  details.acc-section[open] summary::after { transform: none; }
}
@media (max-width: 768px) {
  #salaries h3:not(.titre),
  #creanciers h3:not(.titre),
  #negociation h3:not(.titre),
  #cession h3:not(.titre) { padding: .7rem .8rem; font-size: 1rem; }
}

/* ════════════════════════════════════════════════════════════════════ */
/* PAGE CABINET — Stats, Bio, Tarif                                     */
/* ════════════════════════════════════════════════════════════════════ */

/* Stats grid */
.cabinet-stats { 
  display: grid; 
  grid-template-columns: repeat(4, 1fr); 
  gap: 1.5rem; 
}
.stat-card {
  padding: 1.8rem 1.2rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(196,146,58,.15);
  border-radius: 6px;
  text-align: center;
  transition: all .3s;
}
.stat-card:hover {
  border-color: rgba(196,146,58,.4);
  background: rgba(255,255,255,.06);
  transform: translateY(-2px);
}
.stat-card.stat-highlight {
  background: rgba(196,146,58,.08);
  border-color: rgba(196,146,58,.35);
}
.stat-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 3.2rem;
  font-weight: 500;
  color: var(--or-clair);
  line-height: 1;
  margin-bottom: .6rem;
}
.stat-lbl {
  font-size: .78rem;
  color: rgba(255,255,255,.7);
  letter-spacing: .04em;
  line-height: 1.4;
}

/* Bio block */
.bio-block {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2.5rem;
  margin: 3rem 0;
  align-items: start;
}
.bio-mono-square {
  width: 180px; height: 180px;
  background: linear-gradient(135deg, var(--or) 0%, var(--or-clair) 100%);
  color: var(--ardoise);
  font-family: 'Cormorant Garamond', serif;
  font-size: 5.5rem;
  font-weight: 500;
  display: flex; align-items: center; justify-content: center;
  border-radius: 4px;
  box-shadow: 0 12px 32px rgba(196,146,58,.25);
}
.bio-eyebrow {
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--or);
  margin-bottom: .8rem;
}
.bio-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem;
  font-weight: 500;
  color: var(--ardoise);
  line-height: 1.15;
  margin-bottom: 1.5rem;
}
.bio-credentials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .7rem;
}
.bio-cred-item {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .7rem 1rem;
  background: var(--ivoire-2);
  border: 1px solid var(--ivoire-3);
  border-radius: 4px;
  font-size: .85rem;
  color: var(--ardoise);
}
.bio-cred-item.bio-cred-highlight {
  background: var(--or-pale);
  border-color: rgba(196,146,58,.4);
  font-weight: 500;
}
.bio-cred-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
}

/* defend-card highlight */
.defend-card.defend-highlight {
  border-top: 3px solid var(--or) !important;
  background: var(--or-pale);
}

/* Tarif grid */
.tarif-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 3rem;
}
.tarif-card {
  padding: 2rem 2rem;
  border-radius: 6px;
  position: relative;
}
.tarif-card.tarif-main {
  background: var(--blanc);
  border: 2px solid var(--or);
  box-shadow: 0 12px 32px rgba(196,146,58,.12);
}
.tarif-card.tarif-gift {
  background: linear-gradient(135deg, var(--ardoise) 0%, var(--ardoise-2) 100%);
  color: var(--ivoire);
  position: relative;
  overflow: hidden;
}
.tarif-card.tarif-gift::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 60% at 30% 50%, rgba(196,146,58,.12) 0%, transparent 70%);
  pointer-events: none;
}
.tarif-gift-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.tarif-eyebrow {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--or);
  background: rgba(196,146,58,.1);
  padding: .35rem .8rem;
  border-radius: 3px;
  display: inline-block;
  margin-bottom: 1rem;
}
.tarif-prix {
  display: flex;
  align-items: flex-start;
  gap: .3rem;
  margin: 1rem 0 .3rem;
}
.tarif-symbol {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.5rem;
  font-weight: 400;
  color: var(--ardoise);
  margin-top: .5rem;
}
.tarif-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 5rem;
  font-weight: 500;
  color: var(--ardoise);
  line-height: 1;
}
.tarif-ht {
  font-size: 1rem;
  font-weight: 500;
  color: var(--cendre);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: .3rem;
}
.tarif-ttc {
  font-size: .85rem;
  color: var(--cendre);
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--ivoire-3);
}
.tarif-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.tarif-list li {
  display: flex;
  gap: .7rem;
  align-items: flex-start;
  padding: .55rem 0;
  font-size: .87rem;
  color: var(--ardoise);
  line-height: 1.5;
}
.tarif-check {
  color: var(--or);
  font-weight: 600;
  flex-shrink: 0;
}

/* CTA button */
.btn-cta {
  display: inline-block;
  background: var(--rouge);
  color: var(--ivoire);
  padding: 1.1rem 2.5rem;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: .04em;
  text-decoration: none;
  border-radius: 4px;
  transition: all .25s;
  box-shadow: 0 8px 24px rgba(192,57,43,.25);
}
.btn-cta:hover {
  background: #a72f24;
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(192,57,43,.35);
}

/* Mobile cabinet */
@media (max-width: 900px) {
  .cabinet-stats { grid-template-columns: 1fr 1fr !important; }
  .bio-block { grid-template-columns: 1fr !important; gap: 1.5rem !important; text-align: center; }
  .bio-mono-square { margin: 0 auto; }
  .bio-credentials { grid-template-columns: 1fr; text-align: left; }
  .tarif-grid { grid-template-columns: 1fr !important; }
  .tarif-num { font-size: 3.5rem; }
}
@media (max-width: 480px) {
  .cabinet-stats { grid-template-columns: 1fr !important; }
  .bio-mono-square { width: 120px; height: 120px; font-size: 3.5rem; }
  .stat-num { font-size: 2.4rem; }
}

/* ════════════════════════════════════════════════════════════════════ */
/* V5 — RESPONSIVE OVERRIDES POUR LES INLINE GRIDS                      */
/* Beaucoup de grilles sont en style="grid-template-columns:..." inline */
/* On force le passage en colonnes adaptatives sur mobile/tablette       */
/* ════════════════════════════════════════════════════════════════════ */

/* Tablette : tout ce qui était 3+ cols passe en 2 cols */
@media (max-width: 1024px) {
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  [style*="grid-template-columns:1fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }
  [style*="grid-template-columns:1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* Mobile : tout passe en 1 colonne */
@media (max-width: 768px) {
  [style*="grid-template-columns:1fr 1fr 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: 1fr !important;
  }
}

/* Sections spécifiques : bonne UX mobile pour services-grille */
@media (max-width: 768px) {
  #penal .services-grille,
  #competence-territoriale .services-grille,
  #dirigeants .services-grille,
  #recouvrement .services-grille,
  #cession-actifs .services-grille,
  #negociation .services-grille,
  #salaries .services-grille,
  #creanciers .services-grille,
  #cabinet-hero .cabinet-stats,
  #bio .defend-grille {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  
  #penal .srv,
  #competence-territoriale .srv,
  #dirigeants .srv,
  #recouvrement .srv,
  #cession-actifs .srv,
  #negociation .srv,
  #salaries .srv,
  #creanciers .srv {
    padding: 1.4rem 1.2rem !important;
  }
  
  /* Réduit la taille des h3 dans les cards mobile */
  .srv h3 { font-size: 1.05rem !important; line-height: 1.3 !important; }
  .srv p { font-size: .82rem !important; line-height: 1.65 !important; }
}

/* Tablette : services-grille en 2 cols max */
@media (min-width: 769px) and (max-width: 1024px) {
  .services-grille:not(.cabinet-stats):not(.defend-grille) {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ── Tableaux responsifs : scrollbar horizontale propre ── */
table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
  white-space: nowrap;
}
@media (min-width: 769px) {
  table { display: table; white-space: normal; }
}
/* Tables explicitement responsive */
.responsive-table { width: 100%; }
@media (max-width: 768px) {
  .responsive-table thead { display: none; }
  .responsive-table tbody, 
  .responsive-table tr { display: block; }
  .responsive-table tr {
    margin-bottom: 1rem;
    padding: 1rem;
    border: 1px solid var(--ivoire-3);
    border-radius: 6px;
    background: var(--blanc);
  }
  .responsive-table td {
    display: block;
    padding: .35rem 0;
    border: none;
  }
  .responsive-table td::before {
    content: attr(data-label) " : ";
    font-weight: 600;
    color: var(--ardoise);
    display: block;
    margin-bottom: .15rem;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
  }
}

/* ════════════════════════════════════════════════════════════════════ */
/* V5 — ACCORDÉON parties-prenantes.html (auto via JS)                  */
/* ════════════════════════════════════════════════════════════════════ */
.acc-block {
  margin-bottom: 1rem;
  border-top: 1px solid var(--ivoire-3);
  padding-top: 1rem;
}
.acc-h3 {
  cursor: pointer;
  position: relative;
  padding-right: 2.5rem !important;
  user-select: none;
  transition: color .2s;
}
.acc-h3:hover { color: var(--or) !important; }
.acc-h3::after {
  content: '▾';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%) rotate(0deg);
  font-size: 1rem;
  color: var(--or);
  transition: transform .25s ease;
}
.acc-block.acc-closed .acc-h3::after {
  transform: translateY(-50%) rotate(-90deg);
}
.acc-block.acc-closed > *:not(.acc-h3) {
  display: none;
}
.acc-block:not(.acc-closed) > *:not(.acc-h3) {
  animation: acc-fade-in .3s ease-out;
}
@keyframes acc-fade-in {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Indicateur "expand all" en haut de la page */
.acc-toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 1.5rem;
  font-size: .8rem;
}
.acc-toolbar button {
  background: var(--ivoire-2);
  border: 1px solid var(--ivoire-3);
  color: var(--ardoise);
  padding: .4rem .9rem;
  border-radius: 4px;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
  transition: all .2s;
}
.acc-toolbar button:hover {
  background: var(--or-pale);
  border-color: var(--or);
}
