/* ============================================================
   Cabinet Leturcq Avocats - style.css
   Préfixe : ltq-
   ============================================================ */

/* ============================================================
   0. CUSTOM PROPERTIES
   ============================================================ */
:root {
  /* Palette */
  --ltq-bleu-nuit:     #1a2540;
  --ltq-bleu-profond:  #0f1929;
  --ltq-bordeaux:      #7a1f2e;
  --ltq-bordeaux-hover:#8f2535;
  --ltq-or:            #b8974a;
  --ltq-or-clair:      #d4b06a;
  --ltq-gris-ardoise:  #3c3c3c;
  --ltq-gris-moyen:    #6e6e6e;
  --ltq-gris-clair:    #f2f0ec;
  --ltq-creme:         #faf8f4;
  --ltq-blanc:         #ffffff;
  --ltq-trait:         #ddd8d0;

  /* Typographie */
  --ltq-font-titre:    'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --ltq-font-corps:    'DM Sans', system-ui, -apple-system, sans-serif;

  /* Tailles de base */
  --ltq-radius:        3px;
  --ltq-radius-md:     6px;
  --ltq-ombre:         0 2px 12px rgba(26,37,64,.10);
  --ltq-ombre-elevee:  0 6px 32px rgba(26,37,64,.15);

  /* Transitions */
  --ltq-transition:    .22s ease;

  /* Espacements */
  --ltq-section:       80px;
  --ltq-section-md:    56px;
  --ltq-section-sm:    36px;
}

/* ============================================================
   1. RESET
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  overflow-x: hidden;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
  font-family: var(--ltq-font-corps);
  font-size: 16px;
  line-height: 1.7;
  color: var(--ltq-gris-ardoise);
  background-color: var(--ltq-creme);
}

/* Button reset complet */
button {
  color: inherit;
  font-weight: inherit;
  font-size: inherit;
  font-family: inherit;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  line-height: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

table {
  display: block;
  overflow-x: auto;
  width: 100%;
  border-collapse: collapse;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--ltq-font-titre);
  font-weight: 600;
  line-height: 1.25;
  color: var(--ltq-bleu-nuit);
}

p {
  margin-bottom: 1em;
}

p:last-child {
  margin-bottom: 0;
}

/* ============================================================
   2. UTILITAIRES
   ============================================================ */
.ltq-conteneur {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.ltq-conteneur--etroit {
  max-width: 820px;
}

.ltq-section {
  padding: var(--ltq-section-sm) 0;
}

.ltq-titre-section {
  font-family: var(--ltq-font-titre);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin-bottom: .5rem;
}

.ltq-sous-titre-section {
  font-size: 1rem;
  color: var(--ltq-gris-moyen);
  max-width: 580px;
  line-height: 1.65;
}

.ltq-entete-section {
  margin-bottom: 48px;
}

.ltq-trait-or {
  width: 48px;
  height: 2px;
  background: var(--ltq-or);
  margin: 16px 0 20px;
}

/* ============================================================
   3. BOUTONS
   ============================================================ */
.ltq-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--ltq-radius);
  font-family: var(--ltq-font-corps);
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: background-color var(--ltq-transition), color var(--ltq-transition), border-color var(--ltq-transition), box-shadow var(--ltq-transition);
  min-height: 48px;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
}

.ltq-btn--primaire {
  background-color: var(--ltq-bordeaux);
  color: var(--ltq-blanc);
  border: 2px solid var(--ltq-bordeaux);
}

.ltq-btn--primaire:hover,
.ltq-btn--primaire:focus-visible {
  background-color: var(--ltq-bordeaux-hover);
  border-color: var(--ltq-bordeaux-hover);
  box-shadow: 0 4px 16px rgba(122,31,46,.30);
}

.ltq-btn--secondaire {
  background-color: transparent;
  color: var(--ltq-blanc);
  border: 2px solid rgba(255,255,255,.55);
}

.ltq-btn--secondaire:hover,
.ltq-btn--secondaire:focus-visible {
  border-color: var(--ltq-blanc);
  background-color: rgba(255,255,255,.08);
}

.ltq-btn--contour {
  background-color: transparent;
  color: var(--ltq-bordeaux);
  border: 2px solid var(--ltq-bordeaux);
}

.ltq-btn--contour:hover,
.ltq-btn--contour:focus-visible {
  background-color: var(--ltq-bordeaux);
  color: var(--ltq-blanc);
}

.ltq-btn--or {
  background-color: var(--ltq-or);
  color: var(--ltq-blanc);
  border: 2px solid var(--ltq-or);
}

.ltq-btn--or:hover,
.ltq-btn--or:focus-visible {
  background-color: var(--ltq-or-clair);
  border-color: var(--ltq-or-clair);
}

/* ============================================================
   4. HEADER
   ============================================================ */
.ltq-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: transparent;
  transition: background-color var(--ltq-transition), box-shadow var(--ltq-transition), padding var(--ltq-transition);
}

.ltq-header__barre-sup {
  background-color: var(--ltq-bleu-profond);
  padding: 8px 0;
  font-size: .8rem;
  color: rgba(255,255,255,.7);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  transition: height var(--ltq-transition), opacity var(--ltq-transition), padding var(--ltq-transition);
}

.ltq-header__barre-sup .ltq-conteneur {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: 100%;
}

.ltq-header__barre-gauche,
.ltq-header__barre-droite {
  display: flex;
  align-items: center;
  gap: 20px;
}

.ltq-header__barre-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  color: rgba(255,255,255,.72);
}

.ltq-header__barre-item a {
  color: rgba(255,255,255,.72);
  transition: color var(--ltq-transition);
}

.ltq-header__barre-item a:hover {
  color: var(--ltq-or-clair);
}

.ltq-header__barre-icone {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  opacity: .7;
}

.ltq-header__corps {
  padding: 20px 0;
  transition: padding var(--ltq-transition);
}

.ltq-header__interieur {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: 100%;
}

/* État scrolled */
.ltq-header.ltq-header--scrolled {
  background-color: var(--ltq-bleu-nuit);
  box-shadow: var(--ltq-ombre-elevee);
}

.ltq-header.ltq-header--scrolled .ltq-header__barre-sup {
  height: 0;
  opacity: 0;
  padding: 0;
  overflow: hidden;
  pointer-events: none;
}

.ltq-header.ltq-header--scrolled .ltq-header__corps {
  padding: 12px 0;
}

/* Logo */
.ltq-logo {
  display: flex;
  flex-direction: column;
  line-height: 1;
  text-decoration: none;
  flex-shrink: 0;
}

.ltq-logo__nom {
  font-family: var(--ltq-font-titre);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ltq-blanc);
  letter-spacing: .02em;
}

.ltq-logo__sous {
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-top: 2px;
  display: block;
  white-space: nowrap;
  opacity: .85;
  font-family: var(--ltq-font-corps);
  font-weight: 500;
}

/* Navigation principale */
.ltq-nav {
  display: flex;
  align-items: center;
  gap: 4px;
}

.ltq-nav__item {
  position: relative;
}

.ltq-nav__lien {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 10px 14px;
  font-size: .82rem;
  font-weight: 500;
  font-family: var(--ltq-font-corps);
  font-size: .82rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  color: rgba(255,255,255,.85);
  font-weight: 500;
  border-radius: var(--ltq-radius);
  transition: color var(--ltq-transition), background-color var(--ltq-transition);
  min-height: 44px;
  white-space: nowrap;
}

.ltq-nav__lien:hover,
.ltq-nav__item--actif > .ltq-nav__lien {
  color: var(--ltq-blanc);
  background-color: rgba(255,255,255,.08);
}

.ltq-nav__chevron {
  width: 10px;
  height: 10px;
  transition: transform var(--ltq-transition);
  opacity: .7;
  flex-shrink: 0;
}

.ltq-nav__item:hover .ltq-nav__chevron,
.ltq-nav__item--ouvert .ltq-nav__chevron {
  transform: rotate(180deg);
  opacity: 1;
}

.ltq-header__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.ltq-header__tel {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--ltq-font-corps);
  font-size: .875rem;
  font-weight: 600;
  color: var(--ltq-or-clair);
  letter-spacing: .03em;
  padding: 8px 0;
  min-height: 44px;
}

.ltq-header__tel svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ============================================================
   5. MEGA-MENU
   ============================================================ */
.ltq-mega {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background-color: var(--ltq-blanc);
  border-radius: var(--ltq-radius-md);
  box-shadow: 0 12px 48px rgba(26,37,64,.18);
  border: 1px solid var(--ltq-trait);
  min-width: 680px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
  pointer-events: none;
  z-index: 200;
}

.ltq-mega::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 12px;
  height: 6px;
  background-color: var(--ltq-blanc);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}

.ltq-nav__item:hover .ltq-mega,
.ltq-nav__item--ouvert .ltq-mega {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.ltq-mega__grille {
  display: grid;
  grid-template-columns: 200px 1fr;
  min-height: 0;
}

.ltq-mega__colonne-titre {
  background-color: var(--ltq-bleu-nuit);
  padding: 28px 24px;
  border-radius: var(--ltq-radius-md) 0 0 var(--ltq-radius-md);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ltq-mega__hub-titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ltq-blanc);
  margin-bottom: 6px;
  line-height: 1.3;
}

.ltq-mega__hub-desc {
  font-size: .78rem;
  color: rgba(255,255,255,.6);
  line-height: 1.55;
}

.ltq-mega__hub-lien {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 600;
  color: var(--ltq-or-clair);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: auto;
  transition: gap var(--ltq-transition);
}

.ltq-mega__hub-lien:hover {
  gap: 10px;
}

.ltq-mega__liste {
  padding: 20px 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  align-content: start;
}

.ltq-mega__element {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--ltq-radius);
  transition: background-color var(--ltq-transition);
  text-decoration: none;
  min-height: 44px;
}

.ltq-mega__element:hover {
  background-color: var(--ltq-gris-clair);
}

.ltq-mega__element-icone {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--ltq-or);
  flex-shrink: 0;
  margin-top: 8px;
}

.ltq-mega__element-texte {
  font-size: .85rem;
  font-weight: 500;
  color: var(--ltq-gris-ardoise);
  line-height: 1.4;
  transition: color var(--ltq-transition);
}

.ltq-mega__element:hover .ltq-mega__element-texte {
  color: var(--ltq-bordeaux);
}

/* Mega menu simple (Zones) */
.ltq-mega--zones {
  min-width: 320px;
}

.ltq-mega--zones .ltq-mega__liste {
  grid-template-columns: 1fr;
}

/* ============================================================
   6. BURGER MOBILE
   ============================================================ */
.ltq-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
  flex-shrink: 0;
}

.ltq-burger__trait {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--ltq-blanc);
  border-radius: 2px;
  transition: transform var(--ltq-transition), opacity var(--ltq-transition);
}

.ltq-burger--actif .ltq-burger__trait:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.ltq-burger--actif .ltq-burger__trait:nth-child(2) {
  opacity: 0;
}

.ltq-burger--actif .ltq-burger__trait:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   7. MENU MOBILE
   ============================================================ */
.ltq-menu-mobile {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--ltq-bleu-profond);
  z-index: 999;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform .28s ease;
}

.ltq-menu-mobile.ltq-menu-mobile--ouvert {
  transform: translateX(0);
}

.ltq-menu-mobile__entete {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.ltq-menu-mobile__fermer {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ltq-blanc);
  font-size: 1.5rem;
  font-weight: 300;
}

.ltq-menu-mobile__nav {
  padding: 16px 0;
}

.ltq-menu-mobile__lien {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  font-size: .95rem;
  font-weight: 500;
  color: rgba(255,255,255,.85);
  letter-spacing: .04em;
  min-height: 52px;
  transition: background-color var(--ltq-transition), color var(--ltq-transition);
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.ltq-menu-mobile__lien:hover,
.ltq-menu-mobile__lien--ouvert {
  color: var(--ltq-or-clair);
  background-color: rgba(255,255,255,.04);
}

.ltq-menu-mobile__lien svg {
  width: 14px;
  height: 14px;
  transition: transform var(--ltq-transition);
}

.ltq-menu-mobile__lien--ouvert svg {
  transform: rotate(180deg);
}

.ltq-menu-mobile__sous-nav {
  display: none;
  background-color: rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.ltq-menu-mobile__sous-nav.ltq-menu-mobile__sous-nav--visible {
  display: block;
}

.ltq-menu-mobile__sous-lien {
  display: block;
  padding: 12px 24px 12px 40px;
  font-size: .875rem;
  color: rgba(255,255,255,.65);
  transition: color var(--ltq-transition);
  min-height: 44px;
}

.ltq-menu-mobile__sous-lien:hover {
  color: var(--ltq-or-clair);
}

.ltq-menu-mobile__actions {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-top: 1px solid rgba(255,255,255,.1);
}

.ltq-menu-mobile__actions .ltq-btn {
  width: 100%;
  justify-content: center;
}

/* ============================================================
   8. HERO
   ============================================================ */
.ltq-hero {
  position: relative;
  min-height: auto;
  display: flex;
  align-items: center;
  background-color: var(--ltq-bleu-nuit);
  overflow: hidden;
  padding-top: 120px;
}

.ltq-hero__fond {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(15,25,41,.97) 0%, rgba(26,37,64,.88) 50%, rgba(122,31,46,.25) 100%);
  z-index: 1;
}

.ltq-hero__motif {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 79px,
      rgba(184,151,74,.06) 79px,
      rgba(184,151,74,.06) 80px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 79px,
      rgba(184,151,74,.04) 79px,
      rgba(184,151,74,.04) 80px
    );
  z-index: 0;
}

.ltq-hero__contenu {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 48px 0 56px;
}

.ltq-hero__fil {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 28px;
}

.ltq-hero__fil-sep {
  opacity: .5;
}

/* Hero grid */
.ltq-hero__grille {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.ltq-hero__col {
  max-width: 560px;
}

.ltq-hero__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: rgba(184,151,74,.12);
  border: 1px solid rgba(184,151,74,.25);
  color: var(--ltq-or-clair);
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 2px;
  margin-bottom: 20px;
}

.ltq-hero__h1 {
  font-family: var(--ltq-font-titre);
  font-size: clamp(2.2rem, 4.5vw, 3.2rem);
  font-weight: 700;
  color: var(--ltq-blanc);
  line-height: 1.15;
  margin-bottom: 18px;
  letter-spacing: -.01em;
}

.ltq-hero__h1 em {
  font-style: normal;
  color: var(--ltq-or-clair);
}

.ltq-hero__accroche {
  font-size: 1rem;
  color: rgba(255,255,255,.65);
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 480px;
}

.ltq-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 28px;
}

.ltq-hero__stats {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.ltq-hero__stat {
  font-size: .8rem;
  color: rgba(255,255,255,.5);
}

.ltq-hero__stat strong {
  color: var(--ltq-or-clair);
  font-family: var(--ltq-font-titre);
  font-size: 1.1rem;
  font-weight: 700;
  margin-right: 3px;
}

.ltq-hero__stat-sep {
  width: 1px;
  height: 16px;
  background: rgba(255,255,255,.12);
}

/* Hero visuel : photo + portraits */
.ltq-hero__visuel {
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.ltq-hero__photo-stack {
  position: relative;
  width: 100%;
  max-width: 500px;
}

.ltq-hero__photo-main {
  width: 100%;
  height: auto;
  border-radius: var(--ltq-radius-md);
  box-shadow: 0 16px 48px rgba(0,0,0,.35);
  object-fit: cover;
  display: block;
}

.ltq-hero__portraits {
  display: flex;
  gap: 10px;
  position: absolute;
  bottom: -24px;
  left: 20px;
}

.ltq-hero__portrait {
  display: block;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--ltq-bleu-nuit);
  box-shadow: 0 4px 12px rgba(0,0,0,.3);
  transition: transform var(--ltq-transition);
}

.ltq-hero__portrait:hover {
  transform: scale(1.1);
  z-index: 2;
}

.ltq-hero__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@keyframes ltqScrollAnim {
  0%, 100% { opacity: .4; transform: scaleY(1); }
  50%       { opacity: 1;  transform: scaleY(1.2); }
}

/* ============================================================
   9. CHIFFRES CLES
   ============================================================ */
.ltq-chiffres {
  background-color: var(--ltq-bleu-profond);
  padding: 52px 0;
}

.ltq-chiffres__grille {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  min-width: 0;
}

.ltq-chiffre-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 32px 24px;
  position: relative;
  min-width: 0;
}

.ltq-chiffre-item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 25%;
  height: 50%;
  width: 1px;
  background: rgba(255,255,255,.12);
}

.ltq-chiffre-item__valeur {
  font-family: var(--ltq-font-titre);
  font-size: clamp(2.2rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--ltq-or-clair);
  line-height: 1;
  margin-bottom: 8px;
}

.ltq-chiffre-item__label {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  line-height: 1.45;
  letter-spacing: .03em;
}

/* ============================================================
   10. DOMAINES D'INTERVENTION
   ============================================================ */
.ltq-domaines {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-creme);
}

.ltq-domaines__grille {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  min-width: 0;
}

.ltq-domaine-carte {
  background-color: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow var(--ltq-transition), border-color var(--ltq-transition), transform var(--ltq-transition);
  text-decoration: none;
  min-width: 0;
  position: relative;
  overflow: hidden;
}

.ltq-domaine-carte::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--ltq-or);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--ltq-transition);
}

.ltq-domaine-carte:hover {
  box-shadow: var(--ltq-ombre-elevee);
  border-color: rgba(184,151,74,.3);
  transform: translateY(-3px);
}

.ltq-domaine-carte:hover::before {
  transform: scaleX(1);
}

.ltq-domaine-carte__icone {
  width: 48px;
  height: 48px;
  border-radius: var(--ltq-radius);
  background-color: rgba(26,37,64,.06);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background-color var(--ltq-transition);
}

.ltq-domaine-carte:hover .ltq-domaine-carte__icone {
  background-color: rgba(122,31,46,.08);
}

.ltq-domaine-carte__icone svg {
  width: 22px;
  height: 22px;
  color: var(--ltq-bleu-nuit);
  transition: color var(--ltq-transition);
}

.ltq-domaine-carte:hover .ltq-domaine-carte__icone svg {
  color: var(--ltq-bordeaux);
}

.ltq-domaine-carte__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
}

.ltq-domaine-carte__desc {
  font-size: .875rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.6;
  flex: 1;
}

.ltq-domaine-carte__sous-liste {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.ltq-domaine-carte__sous-item {
  font-size: .78rem;
  color: var(--ltq-gris-moyen);
  display: flex;
  align-items: center;
  gap: 7px;
}

.ltq-domaine-carte__sous-item::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--ltq-or);
  flex-shrink: 0;
}

.ltq-domaine-carte__lien {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 600;
  color: var(--ltq-bordeaux);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 6px;
  transition: gap var(--ltq-transition);
}

.ltq-domaine-carte:hover .ltq-domaine-carte__lien {
  gap: 10px;
}

/* ============================================================
   11. PROCESSUS
   ============================================================ */
.ltq-processus {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-gris-clair);
}

.ltq-processus__etapes {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  min-width: 0;
}

.ltq-processus__etapes::before {
  content: '';
  position: absolute;
  top: 32px;
  left: calc(10% + 16px);
  right: calc(10% + 16px);
  height: 1px;
  background: linear-gradient(to right, var(--ltq-or), rgba(184,151,74,.3));
  z-index: 0;
}

.ltq-etape {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 16px;
  position: relative;
  z-index: 1;
  min-width: 0;
}

.ltq-etape__numero {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 2px solid var(--ltq-or);
  background-color: var(--ltq-blanc);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ltq-font-titre);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 20px;
  flex-shrink: 0;
  transition: background-color var(--ltq-transition), color var(--ltq-transition);
}

.ltq-etape:hover .ltq-etape__numero {
  background-color: var(--ltq-bleu-nuit);
  color: var(--ltq-or-clair);
}

.ltq-etape__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 10px;
}

.ltq-etape__desc {
  font-size: .82rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.6;
}

/* ============================================================
   12. EQUIPE
   ============================================================ */
.ltq-equipe {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-blanc);
}

.ltq-equipe__grille {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  min-width: 0;
}

.ltq-avocat-carte {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  overflow: hidden;
  transition: box-shadow var(--ltq-transition), transform var(--ltq-transition);
  min-width: 0;
}

.ltq-avocat-carte:hover {
  box-shadow: var(--ltq-ombre-elevee);
  transform: translateY(-4px);
}

.ltq-avocat-carte__photo {
  width: 100%;
  aspect-ratio: 3/4;
  background-color: var(--ltq-bleu-nuit);
  position: relative;
  overflow: hidden;
}

.ltq-avocat-carte__photo--placeholder {
  background: linear-gradient(160deg, var(--ltq-bleu-nuit) 0%, #2a3d68 100%);
}

.ltq-avocat-carte__photo-initiales {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ltq-font-titre);
  font-size: 2.5rem;
  font-weight: 700;
  color: rgba(255,255,255,.18);
  letter-spacing: .08em;
}

.ltq-avocat-carte__corps {
  padding: 20px;
  background-color: var(--ltq-blanc);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.ltq-avocat-carte__specialite {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 6px;
}

.ltq-avocat-carte__nom {
  font-family: var(--ltq-font-titre);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 8px;
}

.ltq-avocat-carte__role {
  font-size: .8rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.5;
  margin-bottom: 16px;
  flex: 1;
}

.ltq-avocat-carte__lien {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ltq-bordeaux);
  display: flex;
  align-items: center;
  gap: 5px;
  transition: gap var(--ltq-transition);
}

.ltq-avocat-carte:hover .ltq-avocat-carte__lien {
  gap: 9px;
}

/* ============================================================
   13. ENGAGEMENTS
   ============================================================ */
.ltq-engagements {
  padding: var(--ltq-section) 0;
  background: linear-gradient(160deg, var(--ltq-bleu-nuit) 0%, var(--ltq-bleu-profond) 100%);
}

.ltq-engagements__grille {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  min-width: 0;
}

.ltq-engagement-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.ltq-engagement-item__icone {
  width: 52px;
  height: 52px;
  border-radius: 4px;
  background-color: rgba(184,151,74,.12);
  border: 1px solid rgba(184,151,74,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ltq-engagement-item__icone svg {
  width: 22px;
  height: 22px;
  color: var(--ltq-or-clair);
}

.ltq-engagement-item__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--ltq-blanc);
}

.ltq-engagement-item__desc {
  font-size: .875rem;
  color: rgba(255,255,255,.6);
  line-height: 1.65;
}

/* ============================================================
   14. TEMOIGNAGES / AVIS
   ============================================================ */
.ltq-avis {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-creme);
}

.ltq-avis__grille {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  min-width: 0;
}

.ltq-avis-carte {
  background-color: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.ltq-avis-carte__etoiles {
  display: flex;
  gap: 3px;
}

.ltq-avis-carte__etoile {
  width: 16px;
  height: 16px;
  color: var(--ltq-or);
}

.ltq-avis-carte__guillemet {
  font-family: var(--ltq-font-titre);
  font-size: 3rem;
  line-height: 1;
  color: var(--ltq-or);
  opacity: .35;
  margin-bottom: -8px;
}

.ltq-avis-carte__texte {
  font-size: .9rem;
  color: var(--ltq-gris-ardoise);
  line-height: 1.7;
  font-style: italic;
  flex: 1;
}

.ltq-avis-carte__auteur {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--ltq-trait);
}

.ltq-avis-carte__initiales {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--ltq-bleu-nuit);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  font-weight: 700;
  color: var(--ltq-or-clair);
  flex-shrink: 0;
  font-family: var(--ltq-font-titre);
}

.ltq-avis-carte__nom {
  font-weight: 600;
  font-size: .875rem;
  color: var(--ltq-bleu-nuit);
}

.ltq-avis-carte__contexte {
  font-size: .75rem;
  color: var(--ltq-gris-moyen);
}

/* ============================================================
   15. BLOG
   ============================================================ */
.ltq-blog {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-gris-clair);
}

.ltq-blog__grille {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  min-width: 0;
}

.ltq-article-carte {
  background-color: var(--ltq-blanc);
  border-radius: var(--ltq-radius-md);
  overflow: hidden;
  border: 1px solid var(--ltq-trait);
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--ltq-transition), transform var(--ltq-transition);
  text-decoration: none;
  min-width: 0;
}

.ltq-article-carte:hover {
  box-shadow: var(--ltq-ombre-elevee);
  transform: translateY(-3px);
}

.ltq-article-carte__image {
  width: 100%;
  aspect-ratio: 16/9;
  background-color: var(--ltq-bleu-nuit);
  position: relative;
  overflow: hidden;
}

.ltq-article-carte__image-placeholder {
  background: linear-gradient(145deg, var(--ltq-bleu-nuit) 0%, #253353 100%);
}

.ltq-article-carte__corps {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.ltq-article-carte__tag {
  display: inline-block;
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ltq-bordeaux);
  background-color: rgba(122,31,46,.07);
  padding: 3px 9px;
  border-radius: 2px;
  margin-bottom: 10px;
  align-self: flex-start;
}

.ltq-article-carte__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  line-height: 1.35;
  margin-bottom: 10px;
  flex: 1;
}

.ltq-article-carte__extrait {
  font-size: .825rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.6;
  margin-bottom: 16px;
}

.ltq-article-carte__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: .75rem;
  color: var(--ltq-gris-moyen);
  padding-top: 14px;
  border-top: 1px solid var(--ltq-trait);
}

.ltq-article-carte__lire {
  font-weight: 600;
  color: var(--ltq-bordeaux);
  font-size: .75rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* ============================================================
   16. ZONES
   ============================================================ */
.ltq-zones {
  padding: var(--ltq-section) 0;
  background-color: var(--ltq-blanc);
}

.ltq-zones__grille {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
  min-width: 0;
}

.ltq-zones__intro {
  font-size: .95rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.7;
  margin-bottom: 24px;
}

.ltq-zones__liste {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.ltq-zones__ville {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .875rem;
  color: var(--ltq-gris-ardoise);
  transition: color var(--ltq-transition);
  padding: 6px 0;
  min-height: 44px;
  text-decoration: none;
}

.ltq-zones__ville::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ltq-or);
  flex-shrink: 0;
}

.ltq-zones__ville:hover {
  color: var(--ltq-bordeaux);
}

.ltq-zones__carte {
  width: 100%;
  border-radius: var(--ltq-radius-md);
  overflow: hidden;
  min-height: 420px;
  height: 100%;
  box-shadow: var(--ltq-ombre);
  border: 1px solid var(--ltq-trait);
}

/* ============================================================
   17. CTA FINAL
   ============================================================ */
.ltq-cta-final {
  padding: var(--ltq-section) 0;
  background: linear-gradient(135deg, var(--ltq-bordeaux) 0%, #5a1520 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.ltq-cta-final::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 39px,
      rgba(255,255,255,.03) 39px,
      rgba(255,255,255,.03) 40px
    );
}

.ltq-cta-final__contenu {
  position: relative;
  z-index: 1;
}

.ltq-cta-final__surtitre {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin-bottom: 16px;
}

.ltq-cta-final__titre {
  font-family: var(--ltq-font-titre);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  color: var(--ltq-blanc);
  line-height: 1.2;
  margin-bottom: 16px;
}

.ltq-cta-final__sous {
  font-size: 1rem;
  color: rgba(255,255,255,.7);
  max-width: 480px;
  margin: 0 auto 36px;
  line-height: 1.65;
}

.ltq-cta-final__boutons {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

.ltq-cta-final__garantie {
  margin-top: 28px;
  font-size: .8rem;
  color: rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* ============================================================
   18. FOOTER
   ============================================================ */
.ltq-footer {
  background-color: var(--ltq-bleu-profond);
  padding: 64px 0 0;
}

.ltq-footer__grille {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  min-width: 0;
}

.ltq-footer__logo-nom {
  font-family: var(--ltq-font-titre);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ltq-blanc);
  margin-bottom: 4px;
}

.ltq-footer__logo-sous {
  font-size: .68rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 20px;
}

.ltq-footer__desc {
  font-size: .85rem;
  color: rgba(255,255,255,.5);
  line-height: 1.7;
  margin-bottom: 20px;
  max-width: 300px;
}

.ltq-footer__contact-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  margin-bottom: 10px;
  line-height: 1.5;
}

.ltq-footer__contact-item a {
  color: rgba(255,255,255,.55);
  transition: color var(--ltq-transition);
}

.ltq-footer__contact-item a:hover {
  color: var(--ltq-or-clair);
}

.ltq-footer__contact-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-top: 2px;
  opacity: .6;
}

.ltq-footer__titre-col {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 18px;
}

.ltq-footer__liste {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ltq-footer__lien {
  font-size: .82rem;
  color: rgba(255,255,255,.5);
  transition: color var(--ltq-transition);
  min-height: 28px;
  display: flex;
  align-items: center;
}

.ltq-footer__lien:hover {
  color: rgba(255,255,255,.85);
}

.ltq-footer__bas {
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.ltq-footer__copyright {
  font-size: .75rem;
  color: rgba(255,255,255,.3);
}

.ltq-footer__legaux {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.ltq-footer__legaux a {
  font-size: .75rem;
  color: rgba(255,255,255,.35);
  transition: color var(--ltq-transition);
}

.ltq-footer__legaux a:hover {
  color: rgba(255,255,255,.65);
}

.ltq-footer__barreau {
  font-size: .72rem;
  color: rgba(255,255,255,.28);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ============================================================
   18b. FOOTER PAGES INTERIEURES (ltq-pied)
   ============================================================ */
.ltq-pied {
  background-color: var(--ltq-bleu-profond);
  padding: 64px 0 0;
}

.ltq-pied__grille {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  min-width: 0;
}

.ltq-pied__col--identite .ltq-footer__logo-nom {
  font-family: var(--ltq-font-titre);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ltq-blanc);
  margin-bottom: 4px;
}

.ltq-pied__adresse {
  font-size: .82rem;
  color: rgba(255,255,255,.5);
  line-height: 1.7;
  margin-bottom: 12px;
  font-style: normal;
}

.ltq-pied__tel {
  display: inline-block;
  font-size: .9rem;
  font-weight: 600;
  color: var(--ltq-or-clair);
  transition: color var(--ltq-transition);
}

.ltq-pied__tel:hover {
  color: var(--ltq-blanc);
}

.ltq-pied__col-titre {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 18px;
}

.ltq-pied__liens {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ltq-pied__liens a {
  font-size: .82rem;
  color: rgba(255,255,255,.5);
  transition: color var(--ltq-transition);
  min-height: 28px;
  display: flex;
  align-items: center;
}

.ltq-pied__liens a:hover {
  color: rgba(255,255,255,.85);
}

.ltq-pied__bas {
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  font-size: .75rem;
  color: rgba(255,255,255,.3);
}

/* ============================================================
   19. STICKY CTA MOBILE
   ============================================================ */
.ltq-sticky-mobile {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background-color: var(--ltq-blanc);
  border-top: 1px solid var(--ltq-trait);
  box-shadow: 0 -4px 20px rgba(0,0,0,.1);
  padding: 10px 16px;
  gap: 10px;
}

.ltq-sticky-mobile .ltq-btn {
  flex: 1;
  justify-content: center;
  padding: 13px 16px;
  font-size: .8rem;
}

/* ============================================================
   20. DATA-REVEAL ANIMATIONS
   ============================================================ */
[data-ltq-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .55s ease, transform .55s ease;
}

[data-ltq-reveal].ltq-revealed {
  opacity: 1;
  transform: translateY(0);
}

[data-ltq-reveal="fade"] {
  transform: none;
}

[data-ltq-reveal="gauche"] {
  transform: translateX(-20px);
}

[data-ltq-reveal="droite"] {
  transform: translateX(20px);
}

[data-ltq-reveal="gauche"].ltq-revealed,
[data-ltq-reveal="droite"].ltq-revealed {
  transform: translateX(0);
}

/* Délais en cascade */
[data-ltq-delai="1"] { transition-delay: .08s; }
[data-ltq-delai="2"] { transition-delay: .16s; }
[data-ltq-delai="3"] { transition-delay: .24s; }
[data-ltq-delai="4"] { transition-delay: .32s; }
[data-ltq-delai="5"] { transition-delay: .40s; }
[data-ltq-delai="6"] { transition-delay: .48s; }
[data-ltq-delai="7"] { transition-delay: .56s; }

/* ============================================================
   21. ACCESSIBILITE
   ============================================================ */
:focus-visible {
  outline: 2px solid var(--ltq-or);
  outline-offset: 3px;
  border-radius: 2px;
}

.ltq-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}

/* ============================================================
   22. REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }

  [data-ltq-reveal] {
    opacity: 1;
    transform: none;
  }
}

/* ============================================================
   23. RESPONSIVE — TABLETTE 768px
   ============================================================ */
@media (max-width: 1024px) {
  .ltq-domaines__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-equipe__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-chiffres__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-chiffre-item:nth-child(2)::after {
    display: none;
  }

  .ltq-processus__etapes {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .ltq-processus__etapes::before {
    display: none;
  }

  .ltq-etape {
    flex-direction: row;
    text-align: left;
    align-items: flex-start;
    gap: 20px;
    padding: 0;
  }

  .ltq-etape__numero {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .ltq-engagements__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-avis__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-blog__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-footer__grille {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  .ltq-pied__grille {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  .ltq-zones__grille {
    grid-template-columns: 1fr;
  }

  .ltq-zones__carte {
    min-height: 280px;
  }

  .ltq-nav {
    display: none;
  }

  .ltq-burger {
    display: flex;
  }

  .ltq-menu-mobile {
    display: block;
  }

  .ltq-header__barre-sup {
    display: none;
  }

  .ltq-header__tel {
    display: none;
  }

  .ltq-header__actions .ltq-btn {
    display: none;
  }

  .ltq-mega {
    display: none;
  }

  .ltq-sticky-mobile {
    display: flex;
  }
}

/* ============================================================
   24. RESPONSIVE — MOBILE 480px
   ============================================================ */
@media (max-width: 600px) {
  :root {
    --ltq-section: 56px;
  }

  .ltq-domaines__grille {
    grid-template-columns: 1fr;
  }

  .ltq-equipe__grille {
    grid-template-columns: 1fr;
  }

  .ltq-chiffres__grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-chiffre-item::after {
    display: none;
  }

  .ltq-engagements__grille {
    grid-template-columns: 1fr;
  }

  .ltq-avis__grille {
    grid-template-columns: 1fr;
  }

  .ltq-blog__grille {
    grid-template-columns: 1fr;
  }

  .ltq-footer__grille {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ltq-footer__bas {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .ltq-pied__grille {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ltq-pied__bas {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .ltq-hero__grille {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .ltq-hero__visuel {
    display: none;
  }

  .ltq-hero__ctas {
    flex-direction: column;
    align-items: stretch;
  }

  .ltq-hero__ctas .ltq-btn {
    width: 100%;
    justify-content: center;
  }

  .ltq-hero__stats {
    flex-wrap: wrap;
    gap: 12px;
  }

  .ltq-cta-final__boutons {
    flex-direction: column;
    align-items: center;
  }

  .ltq-cta-final__boutons .ltq-btn {
    width: 100%;
    justify-content: center;
  }

  .ltq-zones__liste {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   25. PRINT
   ============================================================ */
@media print {
  .ltq-header,
  .ltq-sticky-mobile,
  .ltq-cta-final,
  .ltq-hero__scroll {
    display: none !important;
  }

  body {
    color: #000;
    background: #fff;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: .75em;
    color: #555;
  }
}

/* ============================================================
   26. PAGES INTERIEURES — Composants communs
   ============================================================ */

/* Fil d'Ariane page intérieure */
.ltq-fil-ariane {
  background-color: var(--ltq-bleu-profond);
  padding: 14px 0;
}

.ltq-fil-ariane__nav {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: .82rem;
  color: rgba(255,255,255,.55);
}

.ltq-fil-ariane__nav a {
  color: rgba(255,255,255,.65);
  transition: color var(--ltq-transition);
}

.ltq-fil-ariane__nav a:hover {
  color: var(--ltq-or-clair);
}

.ltq-fil-ariane__sep {
  color: rgba(255,255,255,.3);
  font-size: .75rem;
}

.ltq-fil-ariane__courant {
  color: var(--ltq-or);
}

/* Hero pages intérieures */
.ltq-hero-int {
  background: linear-gradient(160deg, var(--ltq-bleu-profond) 0%, var(--ltq-bleu-nuit) 60%, #1e2d50 100%);
  padding: 64px 0 48px;
  position: relative;
  overflow: hidden;
}

.ltq-hero-int::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(184,151,74,.06) 0%, transparent 70%);
  pointer-events: none;
}

.ltq-hero-int__inner {
  position: relative;
  z-index: 1;
}

.ltq-hero-int__surtitre {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--ltq-or);
  margin-bottom: 10px;
}

.ltq-hero-int__h1 {
  font-family: var(--ltq-font-titre);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 700;
  color: var(--ltq-blanc);
  margin-bottom: 14px;
  line-height: 1.2;
}

.ltq-hero-int__h1 em {
  color: var(--ltq-or-clair);
  font-style: italic;
}

.ltq-hero-int__intro {
  font-size: 1rem;
  color: rgba(255,255,255,.72);
  max-width: 640px;
  line-height: 1.7;
  margin-bottom: 24px;
}

.ltq-hero-int__ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* Layout 2 colonnes : contenu + sidebar */
.ltq-mise-en-page {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
  padding: 64px 0;
}

.ltq-contenu-principal {
  min-width: 0;
}

.ltq-sidebar {
  position: sticky;
  top: 120px;
}

/* Blocs sidebar */
.ltq-sidebar-bloc {
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 24px;
  margin-bottom: 20px;
}

.ltq-sidebar-bloc__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--ltq-or);
}

.ltq-sidebar-bloc__texte {
  font-size: .88rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.6;
  margin-bottom: 12px;
}

.ltq-sidebar-bloc__avocat {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid var(--ltq-trait);
  margin-top: 12px;
}

.ltq-sidebar-bloc__initiales {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ltq-bleu-nuit) 0%, #2a3d68 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ltq-font-titre);
  font-weight: 700;
  font-size: .9rem;
  color: rgba(255,255,255,.65);
  flex-shrink: 0;
}

.ltq-sidebar-bloc__avocat-nom {
  font-weight: 600;
  font-size: .88rem;
  color: var(--ltq-bleu-nuit);
  line-height: 1.3;
}

.ltq-sidebar-bloc__avocat-spec {
  font-size: .78rem;
  color: var(--ltq-gris-moyen);
}

.ltq-sidebar-bloc__tel {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .95rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  text-decoration: none;
  transition: color var(--ltq-transition);
}

.ltq-sidebar-bloc__tel:hover {
  color: var(--ltq-bordeaux);
}

.ltq-sidebar-bloc__tel svg {
  color: var(--ltq-or);
  flex-shrink: 0;
}

/* Contenu riche article / service */
.ltq-prose h2 {
  font-family: var(--ltq-font-titre);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin: 2em 0 .6em;
  padding-bottom: .35em;
  border-bottom: 1px solid var(--ltq-trait);
}

.ltq-prose h2:first-child {
  margin-top: 0;
}

.ltq-prose h3 {
  font-family: var(--ltq-font-titre);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  margin: 1.5em 0 .4em;
}

.ltq-prose p {
  margin-bottom: 1em;
  line-height: 1.8;
}

.ltq-prose ul,
.ltq-prose ol {
  list-style: none;
  margin: .8em 0 1.2em;
  padding: 0;
}

.ltq-prose ul li,
.ltq-prose ol li {
  padding: 5px 0 5px 22px;
  position: relative;
  line-height: 1.65;
}

.ltq-prose ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 13px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ltq-or);
}

.ltq-prose ol {
  counter-reset: ltq-ol;
}

.ltq-prose ol li::before {
  counter-increment: ltq-ol;
  content: counter(ltq-ol) ".";
  position: absolute;
  left: 0;
  top: 5px;
  font-weight: 600;
  font-size: .85rem;
  color: var(--ltq-bordeaux);
}

.ltq-prose a {
  color: var(--ltq-bordeaux);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--ltq-transition);
}

.ltq-prose a:hover {
  color: var(--ltq-bordeaux-hover);
}

.ltq-prose strong {
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
}

.ltq-prose blockquote {
  border-left: 3px solid var(--ltq-or);
  margin: 1.5em 0;
  padding: 14px 20px;
  background: rgba(184,151,74,.05);
  border-radius: 0 var(--ltq-radius-md) var(--ltq-radius-md) 0;
  font-style: italic;
  color: var(--ltq-gris-ardoise);
}

/* Encadrés */
.ltq-encadre {
  background: rgba(26,37,64,.04);
  border: 1px solid rgba(26,37,64,.12);
  border-radius: var(--ltq-radius-md);
  padding: 18px 22px;
  margin: 1.4em 0;
}

.ltq-encadre--alerte {
  background: rgba(122,31,46,.05);
  border-color: rgba(122,31,46,.2);
}

.ltq-encadre__titre {
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 6px;
}

.ltq-encadre--alerte .ltq-encadre__titre {
  color: var(--ltq-bordeaux);
}

/* FAQ */
.ltq-faq {
  margin: 1.8em 0;
}

.ltq-faq__item {
  border-bottom: 1px solid var(--ltq-trait);
}

.ltq-faq__question {
  width: 100%;
  text-align: left;
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  font-family: var(--ltq-font-titre);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  cursor: pointer;
  transition: color var(--ltq-transition);
  background: none;
  border: none;
}

.ltq-faq__question:hover {
  color: var(--ltq-bordeaux);
}

.ltq-faq__chevron {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  color: var(--ltq-or);
  transition: transform var(--ltq-transition);
}

.ltq-faq__item--ouvert .ltq-faq__chevron {
  transform: rotate(180deg);
}

.ltq-faq__reponse {
  display: none;
  padding: 0 0 16px;
  font-size: .92rem;
  color: var(--ltq-gris-ardoise);
  line-height: 1.75;
}

.ltq-faq__item--ouvert .ltq-faq__reponse {
  display: block;
}

/* Grille services sous-pages */
.ltq-grille-services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 1.8em 0;
}

.ltq-service-carte {
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 22px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 7px;
  transition: box-shadow var(--ltq-transition), transform var(--ltq-transition), border-color var(--ltq-transition);
}

.ltq-service-carte:hover {
  box-shadow: var(--ltq-ombre-elevee);
  transform: translateY(-3px);
  border-color: var(--ltq-bordeaux);
}

.ltq-service-carte__titre {
  font-family: var(--ltq-font-titre);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
}

.ltq-service-carte__desc {
  font-size: .86rem;
  color: var(--ltq-gris-moyen);
  line-height: 1.55;
  flex: 1;
}

.ltq-service-carte__lien {
  font-size: .78rem;
  font-weight: 600;
  color: var(--ltq-bordeaux);
  text-transform: uppercase;
  letter-spacing: .06em;
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Grille articles blog */
.ltq-grille-articles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin: 1.8em 0;
}

/* Profil avocat */
.ltq-profil-grille {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 48px;
  align-items: start;
  padding: 64px 0;
}

.ltq-profil-col-photo {
  position: sticky;
  top: 120px;
}

.ltq-profil-photo {
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: var(--ltq-radius-md);
  background: linear-gradient(160deg, var(--ltq-bleu-nuit) 0%, #2a3d68 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ltq-font-titre);
  font-size: 3.5rem;
  font-weight: 700;
  color: rgba(255,255,255,.18);
  letter-spacing: .06em;
  margin-bottom: 16px;
  overflow: hidden;
}

.ltq-profil-badge {
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 14px 16px;
  font-size: .83rem;
}

.ltq-profil-badge__item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 5px 0;
  color: var(--ltq-gris-ardoise);
  border-bottom: 1px solid var(--ltq-gris-clair);
}

.ltq-profil-badge__item:last-child {
  border-bottom: none;
}

.ltq-profil-badge__item svg {
  color: var(--ltq-or);
  flex-shrink: 0;
  margin-top: 2px;
}

.ltq-spec-tag {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(184,151,74,.08);
  border: 1px solid rgba(184,151,74,.28);
  border-radius: 20px;
  font-size: .76rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 0 4px 6px 0;
}

/* Domaines sous profil */
.ltq-dom-profil {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin: .8em 0;
}

.ltq-dom-profil__item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 12px;
  background: var(--ltq-gris-clair);
  border-radius: var(--ltq-radius);
  text-decoration: none;
  font-size: .86rem;
  color: var(--ltq-gris-ardoise);
  transition: background-color var(--ltq-transition), color var(--ltq-transition);
}

.ltq-dom-profil__item:hover {
  background: rgba(122,31,46,.07);
  color: var(--ltq-bordeaux);
}

.ltq-dom-profil__item::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ltq-or);
  flex-shrink: 0;
}

/* Tarifs */
.ltq-tarif-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.4em 0;
  font-size: .9rem;
}

.ltq-tarif-table th {
  background: var(--ltq-bleu-nuit);
  color: var(--ltq-blanc);
  padding: 11px 14px;
  text-align: left;
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: .04em;
}

.ltq-tarif-table td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--ltq-trait);
  color: var(--ltq-gris-ardoise);
}

.ltq-tarif-table tr:last-child td {
  border-bottom: none;
}

.ltq-tarif-table tr:nth-child(even) td {
  background: rgba(242,240,236,.5);
}

/* Formulaire contact */
.ltq-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ltq-form-groupe {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.ltq-form-grille {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ltq-form label {
  font-size: .83rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
  letter-spacing: .03em;
}

.ltq-form input,
.ltq-form select,
.ltq-form textarea {
  padding: 11px 13px;
  border: 2px solid #cbd5e1;
  border-radius: var(--ltq-radius);
  background: #f8fafc;
  font-family: var(--ltq-font-corps);
  font-size: .92rem;
  color: var(--ltq-gris-ardoise);
  transition: border-color var(--ltq-transition), box-shadow var(--ltq-transition), background var(--ltq-transition);
  width: 100%;
}

.ltq-form input:focus,
.ltq-form select:focus,
.ltq-form textarea:focus {
  outline: none;
  border-color: var(--ltq-bordeaux);
  box-shadow: 0 0 0 3px rgba(122,31,46,.10);
  background: white;
}

.ltq-form textarea {
  resize: vertical;
  min-height: 110px;
}

.ltq-form-statut {
  padding: 11px 14px;
  border-radius: var(--ltq-radius);
  font-size: .88rem;
}

.ltq-form-statut--succes {
  background: rgba(34,197,94,.07);
  border: 1px solid rgba(34,197,94,.22);
  color: #15803d;
}

.ltq-form-statut--erreur {
  background: rgba(122,31,46,.05);
  border: 1px solid rgba(122,31,46,.18);
  color: var(--ltq-bordeaux);
}

/* Carte placeholder */
.ltq-map {
  width: 100%;
  border-radius: var(--ltq-radius-md);
  overflow: hidden;
  margin: 1.5em 0;
  border: 1px solid var(--ltq-trait);
}

.ltq-map iframe {
  width: 100%;
  height: 380px;
  border: none;
  display: block;
}

/* Grille zones */
.ltq-grille-zones {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 1.8em 0;
}

.ltq-zone-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  text-decoration: none;
  font-size: .88rem;
  color: var(--ltq-gris-ardoise);
  transition: background-color var(--ltq-transition), border-color var(--ltq-transition), color var(--ltq-transition);
}

.ltq-zone-item:hover {
  background: rgba(122,31,46,.05);
  border-color: var(--ltq-bordeaux);
  color: var(--ltq-bordeaux);
}

.ltq-zone-item::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ltq-or);
  flex-shrink: 0;
}

/* Avis */
.ltq-grille-avis-full {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 2em 0;
}

.ltq-avis-carte {
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 22px;
}

.ltq-avis-etoiles {
  color: var(--ltq-or);
  font-size: 1rem;
  letter-spacing: 2px;
  margin-bottom: 10px;
}

.ltq-avis-texte {
  font-size: .88rem;
  color: var(--ltq-gris-ardoise);
  line-height: 1.7;
  font-style: italic;
  margin-bottom: 12px;
}

.ltq-avis-auteur {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ltq-bleu-nuit);
}

.ltq-avis-domaine {
  font-size: .76rem;
  color: var(--ltq-gris-moyen);
}

/* Tag */
.ltq-tag {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(26,37,64,.06);
  border-radius: 20px;
  font-size: .73rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ltq-bleu-nuit);
}

/* Lexique */
.ltq-lexique-grille {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 1.8em 0;
}

.ltq-lexique-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius);
  text-decoration: none;
  font-size: .86rem;
  color: var(--ltq-gris-ardoise);
  transition: background-color var(--ltq-transition), color var(--ltq-transition), border-color var(--ltq-transition);
}

.ltq-lexique-item:hover {
  background: rgba(122,31,46,.05);
  border-color: var(--ltq-bordeaux);
  color: var(--ltq-bordeaux);
}

.ltq-lexique-item__lettre {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--ltq-bleu-nuit);
  color: var(--ltq-blanc);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ltq-font-titre);
  font-size: .8rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* Table des matières */
.ltq-tdm {
  background: var(--ltq-blanc);
  border: 1px solid var(--ltq-trait);
  border-radius: var(--ltq-radius-md);
  padding: 18px 22px;
  margin-bottom: 1.8em;
}

.ltq-tdm__titre {
  font-weight: 600;
  font-size: .86rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ltq-bleu-nuit);
  margin-bottom: 10px;
}

.ltq-tdm__liste {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ltq-tdm__liste li {
  padding: 3px 0;
  font-size: .88rem;
}

.ltq-tdm__liste a {
  color: var(--ltq-gris-ardoise);
  text-decoration: none;
  transition: color var(--ltq-transition);
}

.ltq-tdm__liste a:hover {
  color: var(--ltq-bordeaux);
}

/* Paginateur blog */
.ltq-blog-header {
  background: var(--ltq-gris-clair);
  padding: 28px 0;
  border-bottom: 1px solid var(--ltq-trait);
  margin-bottom: 0;
}

/* ============================================================
   27. RESPONSIVE — pages intérieures
   ============================================================ */
@media (max-width: 1024px) {
  .ltq-mise-en-page {
    grid-template-columns: 1fr;
  }

  .ltq-sidebar {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .ltq-profil-grille {
    grid-template-columns: 1fr;
  }

  .ltq-profil-col-photo {
    position: static;
    max-width: 260px;
  }

  .ltq-grille-services {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-grille-articles {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-grille-avis-full {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .ltq-form-grille {
    grid-template-columns: 1fr;
  }

  .ltq-grille-zones {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-grille-avis-full {
    grid-template-columns: 1fr;
  }

  .ltq-grille-services {
    grid-template-columns: 1fr;
  }

  .ltq-grille-articles {
    grid-template-columns: 1fr;
  }

  .ltq-lexique-grille {
    grid-template-columns: repeat(2, 1fr);
  }

  .ltq-dom-profil {
    grid-template-columns: 1fr;
  }

  .ltq-sidebar {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .ltq-grille-zones {
    grid-template-columns: 1fr;
  }

  .ltq-lexique-grille {
    grid-template-columns: 1fr;
  }

  .ltq-hero-int {
    padding: 48px 0 36px;
  }

  .ltq-hero-int__ctas {
    flex-direction: column;
    align-items: flex-start;
  }

  .ltq-hero-int__ctas .ltq-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ============================================================
   IMAGES REELLES — avocats, cabinet, articles
   ============================================================ */

.ltq-equipe-photo {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

.ltq-profil-photo-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

.ltq-article-hero-img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  margin-bottom: 2rem;
  display: block;
}

.ltq-sidebar__auteur-photo {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  object-position: top center;
  flex-shrink: 0;
}

.ltq-cabinet-photo {
  width: 100%;
  height: auto;
  border-radius: 6px;
  display: block;
  margin: 1.5rem 0;
}

.ltq-cabinet-photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 1.5rem 0;
}

@media (max-width: 600px) {
  .ltq-cabinet-photos {
    grid-template-columns: 1fr;
  }
}
