/* ============================================================
   CSKA BTP — Design system v2 (refonte complète)
   ============================================================ */

:root {
  /* Polices */
  --cska-font: 'Plus Jakarta Sans', 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --cska-display: 'Plus Jakarta Sans', 'Inter', system-ui, sans-serif;

  /* Palette principale */
  --cska-purple: #b020c9;
  --cska-purple-deep: #7a2d8e;
  --cska-purple-soft: #d8b4e8;
  --cska-purple-50: #faf5fc;
  --cska-purple-100: #f1e4f6;
  --cska-purple-glow: rgba(176, 32, 201, 0.18);

  /* Accents secondaires (chaleur, contraste) */
  --cska-amber: #f5a623;
  --cska-amber-soft: #ffd591;

  /* Encres et neutres */
  --cska-ink: #14101c;
  --cska-ink-soft: #2c2238;
  --cska-muted: #5a4d6b;
  --cska-mist: #f6f3fa;
  --cska-bone: #fdfaf6;
  --cska-line: rgba(20, 16, 28, 0.08);
  --cska-line-soft: rgba(20, 16, 28, 0.05);

  /* Espacements */
  --cska-section: clamp(72px, 9vw, 128px);

  /* Easings */
  --cska-ease: cubic-bezier(0.22, 0.94, 0.32, 1);
  --cska-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --cska-ease-soft: cubic-bezier(0.4, 0.0, 0.2, 1);

  /* Rayons */
  --cska-radius: 18px;
  --cska-radius-lg: 28px;

  /* Ombres */
  --cska-shadow-sm: 0 1px 2px rgba(20, 16, 28, 0.04), 0 4px 12px rgba(20, 16, 28, 0.06);
  --cska-shadow-md: 0 8px 24px rgba(20, 16, 28, 0.10), 0 24px 56px rgba(20, 16, 28, 0.08);
  --cska-shadow-lg: 0 16px 40px rgba(122, 45, 142, 0.20), 0 32px 72px rgba(122, 45, 142, 0.14);
}

/* ============================================================
   1. KEYFRAMES
   ============================================================ */

@keyframes cska-fade-in   { from { opacity: 0 } to { opacity: 1 } }
@keyframes cska-rise      { from { transform: translateY(28px) } to { transform: translateY(0) } }
@keyframes cska-rise-soft { from { transform: translateY(14px) } to { transform: translateY(0) } }
@keyframes cska-zoom-in   { from { transform: scale(0.94) } to { transform: scale(1) } }
@keyframes cska-float     { 0%,100% { transform: translateY(0) } 50% { transform: translateY(-6px) } }
@keyframes cska-pulse     { 0%,100% { opacity: 0.5 } 50% { opacity: 1 } }
@keyframes cska-scroll-cue {
  0%   { transform: translate(-50%, 0); opacity: 0.35 }
  50%  { transform: translate(-50%, 8px); opacity: 1 }
  100% { transform: translate(-50%, 0); opacity: 0.35 }
}
@keyframes cska-shimmer { from { background-position: -300% 0 } to { background-position: 300% 0 } }
@keyframes cska-blink   { 0%,100% { opacity: 1 } 50% { opacity: 0.3 } }

/* ============================================================
   2. BASE — police, body, scroll
   ============================================================ */

html { scroll-behavior: smooth; }

html, body {
  background-color: #000;
}

body,
h1, h2, h3, h4, h5, h6,
p, a, li, span, button, label, input, textarea, select,
.et_pb_module, .et_pb_text, .et_pb_button, .et_pb_menu,
#main-header, #footer-bottom, #footer-info, #footer-widgets,
.et-menu, .et-menu-nav, .nav, .sub-menu,
.entry-content, .entry-title {
  font-family: var(--cska-font) !important;
  font-feature-settings: "ss01", "cv11", "cv02";
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.005em;
}

h1, h2, h3, h4, h5, h6,
.et_pb_module h1, .et_pb_module h2, .et_pb_module h3, .et_pb_module h4 {
  font-family: var(--cska-display) !important;
  font-weight: 800;
  letter-spacing: -0.028em;
  line-height: 1.04;
}

h1, .et_pb_module h1 {
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.96;
}

p {
  line-height: 1.7;
  letter-spacing: -0.005em;
}

[data-icon], .et-pb-icon, .et_pb_button:before, .et_pb_button:after,
.et_pb_font_icon, .et-social-icon a,
.dashicons, .dashicons-before:before {
  font-family: 'ETmodules' !important;
}

.et_pb_module.et_animated.et-waypoint,
.et_pb_module.et-waypoint:not(.et_pb_counters),
.et_pb_image.et_animated,
.et_pb_image.et-waypoint,
.et_pb_image,
.et_pb_image_wrap,
.et_pb_image_wrap img,
.et_pb_section_1 .et_pb_column,
.et_pb_section_1 .et_pb_module {
  opacity: 1 !important;
  visibility: visible !important;
}

::selection { background: var(--cska-amber); color: var(--cska-ink); }

::-webkit-scrollbar       { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(176, 32, 201, 0.45);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(176, 32, 201, 0.75);
  background-clip: padding-box;
}

/* Focus ring cohérent (pill par défaut pour matcher les boutons) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
.et_pb_button:focus-visible {
  outline: 2px solid var(--cska-amber);
  outline-offset: 3px;
  border-radius: 999px;
}
input:focus-visible,
textarea:focus-visible {
  border-radius: 12px;
}

/* Skip-to-content (a11y) */
.cska-skip {
  position: absolute;
  left: 16px;
  top: -100px;
  background: var(--cska-ink);
  color: #fff;
  padding: 12px 18px;
  border-radius: 12px;
  font-weight: 600;
  font-size: 14px;
  z-index: 9999;
  transition: top 0.3s var(--cska-ease);
  text-decoration: none;
}
.cska-skip:focus { top: 16px; outline: 2px solid var(--cska-amber); }

#page-container {
  background-color: #fff;
  animation: cska-fade-in 0.5s var(--cska-ease) both;
}

/* ============================================================
   3. HEADER
   ============================================================ */

#main-header,
.et_pb_section.et_pb_section_0_tb_header {
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.et_pb_section_0_tb_header {
  transition: padding 0.4s var(--cska-ease) !important;
}

.et_pb_section_0_tb_header.is-scrolled {
  background-color: rgba(255, 255, 255, 0.96) !important;
  box-shadow: 0 1px 0 rgba(20, 16, 28, 0.06);
}

#top-menu li a,
.et_pb_menu ul li a,
nav.et-menu-nav ul.nav > li > a {
  font-weight: 600 !important;
  letter-spacing: 0.005em !important;
  font-size: 15px !important;
  position: relative;
  transition: color 0.3s var(--cska-ease) !important;
}

/* ============================================================
   Menu — couleurs différenciées par type d'item
   ============================================================ */

/* Couleur de base des items menu (gris foncé sobre) */
nav.et-menu-nav > ul.nav > li > a,
#top-menu > li > a {
  color: var(--cska-ink-soft) !important;
  font-weight: 600 !important;
  transition: color 0.25s var(--cska-ease) !important;
}

/* Item ancestors (parents des sous-menus marqués current) :
   ne pas les highlighter en violet juste parce qu'ils pointent vers index.html */
nav.et-menu-nav > ul.nav > li.menu-item-home.current-menu-item:not(:first-child) > a,
nav.et-menu-nav > ul.nav > li.menu-item-home.current-menu-ancestor:not(:first-child) > a {
  color: var(--cska-ink-soft) !important;
  font-weight: 600 !important;
}

/* Chaque item garde sa couleur identitaire même quand il est actif.
   L'état actif est signalé par un bold + un pill background subtil. */

/* Accueil — toujours violet (couleur principale du site) */
nav.et-menu-nav > ul.nav > li:first-child > a,
#top-menu > li:first-child > a {
  color: var(--cska-purple) !important;
}

/* Travaux publics ▾ — gris foncé sobre */
nav.et-menu-nav > ul.nav > li.menu-item-565 > a,
nav.et-menu-nav > ul.nav > li:nth-child(2) > a,
#top-menu > li:nth-child(2) > a {
  color: var(--cska-ink-soft) !important;
}

/* Façade — toujours ambre (accent nouveau) */
nav.et-menu-nav > ul.nav > li.cska-menu-facade > a,
#top-menu li.cska-menu-facade > a {
  color: var(--cska-amber) !important;
  font-weight: 700 !important;
  position: relative;
}

nav.et-menu-nav > ul.nav > li.cska-menu-facade > a::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--cska-amber);
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: 2px;
}

/* Démolition ▾ — vert pétrole pour distinction */
nav.et-menu-nav > ul.nav > li.menu-item-566 > a,
#top-menu > li.menu-item-566 > a {
  color: #1f7a6f !important;
}

/* Nous contacter — violet profond (CTA) */
nav.et-menu-nav > ul.nav > li:nth-last-child(2) > a,
#top-menu > li:nth-last-child(2) > a {
  color: var(--cska-purple-deep) !important;
}

/* Mentions légales — même taille que les autres items */

/* État actif (page courante) — bold + pill background subtil
   sans changer la couleur de l'item. */
nav.et-menu-nav > ul.nav > li.current-menu-item > a,
nav.et-menu-nav > ul.nav > li.current_page_item > a {
  font-weight: 800 !important;
  background: rgba(0, 0, 0, 0.04);
  padding: 6px 12px !important;
  border-radius: 999px;
  margin: 0 -6px !important;
}

/* Sur home, l'ancestor wrongly-marked devient pas actif */
body.cska-page-home nav.et-menu-nav > ul.nav > li.menu-item-home.current-menu-item:not(:first-child) > a,
body.cska-page-home nav.et-menu-nav > ul.nav > li.menu-item-home.current-menu-ancestor:not(:first-child) > a {
  background: transparent;
  font-weight: 600 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Hover : assombrit légèrement la couleur identitaire (pas de violet uniforme) */
nav.et-menu-nav > ul.nav > li > a:hover,
#top-menu > li > a:hover {
  filter: brightness(0.85) saturate(1.2);
}

/* Pas de strikethrough hérité */
nav.et-menu-nav a,
#top-menu a,
.et_pb_menu a {
  text-decoration: none !important;
}

/* Sous-menu plus aérien */
.sub-menu, .et-menu .nav li ul {
  border-radius: 14px !important;
  padding: 6px 0 !important;
  box-shadow: var(--cska-shadow-md) !important;
  border-top: none !important;
}

.sub-menu li a, .et-menu .nav li ul li a {
  padding: 10px 18px !important;
  border-radius: 8px !important;
  margin: 0 6px !important;
  transition: background 0.25s var(--cska-ease), color 0.25s var(--cska-ease) !important;
}

.sub-menu li a:hover, .et-menu .nav li ul li a:hover {
  background: var(--cska-purple-50) !important;
  color: var(--cska-purple) !important;
}

.et_pb_menu__logo img {
  transition: transform 0.5s var(--cska-ease) !important;
}

.et_pb_menu__logo:hover img {
  transform: scale(1.06) rotate(-2deg);
}

/* CTA "Devis" optionnel dans le menu */
.cska-nav-cta {
  margin-left: 18px !important;
  padding: 9px 20px !important;
  background: var(--cska-purple) !important;
  color: #fff !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  transition: transform 0.25s var(--cska-ease), box-shadow 0.25s var(--cska-ease), background 0.25s var(--cska-ease) !important;
}

.cska-nav-cta:hover {
  background: var(--cska-purple-deep) !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(122, 45, 142, 0.30);
}

.cska-nav-cta::after { display: none !important; }

/* ============================================================
   4. HERO ACCUEIL — full impact
   ============================================================ */

.et_pb_section_0 {
  position: relative;
  min-height: clamp(440px, 64vh, 760px) !important;
  overflow: hidden;
  padding-top: clamp(72px, 10vh, 120px) !important;
  padding-bottom: clamp(56px, 8vh, 96px) !important;
  margin-bottom: 0 !important;
  background-color: var(--cska-purple-deep) !important;
  background-image: none !important;
}

div.et_pb_section.et_pb_section_0 {
  background-image: none !important;
  background-color: var(--cska-purple-deep) !important;
}

/* Pages services : hero plus court */
body:not(.home):not(.page-id-43) .et_pb_section_0 {
  min-height: clamp(360px, 48vh, 520px) !important;
}

/* Mobile : hero compact (sinon du vide) */
@media (max-width: 700px) {
  .et_pb_section_0 {
    min-height: auto !important;
    padding-top: clamp(56px, 12vw, 96px) !important;
    padding-bottom: clamp(40px, 8vw, 72px) !important;
  }
  body:not(.home):not(.page-id-43) .et_pb_section_0 {
    min-height: auto !important;
  }
}

/* Overlay violet avec dégradé radial pour profondeur — accueil seulement */
body.home .et_pb_section_0::before,
body.page-id-43 .et_pb_section_0::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 25% 35%, rgba(176, 32, 201, 0.40) 0%, transparent 60%),
    linear-gradient(105deg,
      rgba(122, 45, 142, 0.94) 0%,
      rgba(122, 45, 142, 0.78) 36%,
      rgba(122, 45, 142, 0.46) 64%,
      rgba(122, 45, 142, 0.10) 90%,
      rgba(122, 45, 142, 0) 100%
    ),
    linear-gradient(180deg, rgba(20, 16, 28, 0.18) 0%, rgba(20, 16, 28, 0) 35%);
  pointer-events: none;
  z-index: 1;
}

/* Pages services : voile sobre, sans gradient parasite */
body:not(.home):not(.page-id-43) .et_pb_section_0::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20, 16, 28, 0.18) 0%, rgba(20, 16, 28, 0) 60%);
  pointer-events: none;
  z-index: 1;
}

.et_pb_section_0 > * {
  position: relative;
  z-index: 2;
}

.et_pb_section_0 .et_pb_bottom_inside_divider,
.et_pb_section_3 .et_pb_top_inside_divider,
.et_pb_section_3 .et_pb_bottom_inside_divider,
.et_pb_section .et_pb_top_inside_divider,
.et_pb_section .et_pb_bottom_inside_divider {
  display: none !important;
}

/* La section contact (violet) doit toucher directement le footer noir.
   Aucun fond blanc ne doit apparaître entre la dernière section et le footer. */
.et_pb_section_3 {
  margin: 0 !important;
  padding-bottom: clamp(64px, 8vw, 112px) !important;
}

#main-content {
  background-color: transparent !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

#main-content > article {
  background-color: transparent !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

#main-content > article > .entry-content {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* Le footer arrive directement après le dernier contenu */
#main-footer {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Wrapper principal transparent — laisse le page-container piloter le fond */
#et-main-area {
  background-color: transparent !important;
}

.et_pb_section_0 + .et_pb_section {
  margin-top: 0 !important;
  padding-top: clamp(72px, 9vw, 128px) !important;
}

/* Eyebrow accueil — uniquement sur la home (les pages services ont breadcrumb) */
body.home .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner,
body.page-id-43 .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner {
  position: relative;
}

body.home .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner::before,
body.page-id-43 .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner::before {
  content: "Travaux publics · Démolition · Façade";
  display: inline-block;
  padding: 6px 14px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 18px;
  backdrop-filter: blur(8px);
}

.et_pb_section_0 .et_pb_text_0,
.et_pb_section_0 .et_pb_text_0 .et_pb_text_inner,
.et_pb_section_0 .et_pb_text_0 h1,
#page-container .et_pb_section_0 h1 {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #ffffff !important;
}

.et_pb_section_0 .et_pb_text_0 h1,
#page-container .et_pb_section_0 h1 {
  font-size: clamp(36px, 4.4vw, 72px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.0 !important;
  margin: 0 0 26px !important;
  color: #ffffff !important;
  text-wrap: balance;
  max-width: 18ch;
}

body.home .et_pb_section_0 h1,
body.page-id-43 .et_pb_section_0 h1 {
  font-size: clamp(40px, 5.4vw, 84px) !important;
  letter-spacing: -0.045em !important;
  line-height: 0.96 !important;
}

.et_pb_section_0 .et_pb_text_1,
.et_pb_section_0 .et_pb_text_1 .et_pb_text_inner,
.et_pb_section_0 .et_pb_text_1 p,
.et_pb_section_0 .et_pb_text_1 span {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #ffffff !important;
}

.et_pb_section_0 .et_pb_text_1 {
  padding: 0 !important;
  margin: 0 0 32px !important;
  max-width: 620px;
}

.et_pb_section_0 .et_pb_text_1 p {
  font-size: clamp(15px, 1.2vw, 18px) !important;
  line-height: 1.65 !important;
  font-weight: 400 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: rgba(255, 255, 255, 0.92) !important;
}

.et_pb_section_0 .et_pb_text_1 span {
  font-size: inherit !important;
  line-height: inherit !important;
}

/* Bouton hatched du hero (services pages) — compact */
.et_pb_button_module_wrapper.et_pb_button_0_wrapper {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-height: auto;
}

/* Indicateur scroll en bas du hero — accueil seulement */
body.home .et_pb_section_0::after,
body.page-id-43 .et_pb_section_0::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 32px;
  width: 1px;
  height: 48px;
  background: linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.6) 100%);
  transform: translateX(-50%);
  animation: cska-scroll-cue 2.4s var(--cska-ease-soft) infinite;
  pointer-events: none;
  z-index: 5;
}

/* Hero accueil étendu : social proof intégré */
.cska-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(20px, 4vw, 48px);
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  max-width: 720px;
}

.cska-hero-meta__item {
  color: rgba(255, 255, 255, 0.92);
  position: relative;
  padding-right: clamp(20px, 4vw, 48px);
}

.cska-hero-meta__item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: rgba(255, 255, 255, 0.18);
}

.cska-hero-meta__item:last-child {
  padding-right: 0;
}

.cska-hero-meta__num {
  display: block;
  font-size: clamp(24px, 2.2vw, 32px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #fff;
  margin-bottom: 2px;
  line-height: 1;
}

.cska-hero-meta__label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(255, 255, 255, 0.7);
}

/* ============================================================
   5. BOUTONS
   ============================================================ */

.et_pb_button {
  font-family: var(--cska-font) !important;
  font-weight: 600 !important;
  letter-spacing: 0.005em !important;
  font-size: 15px !important;
  line-height: 1 !important;
  border-radius: 999px !important;
  padding: 14px 32px !important;
  position: relative;
  overflow: hidden;
  background: #fff !important;
  color: var(--cska-purple-deep) !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  max-width: none !important;
  box-shadow: 0 4px 14px rgba(20, 16, 28, 0.10) !important;
  transition:
    transform 0.3s var(--cska-ease),
    box-shadow 0.3s var(--cska-ease),
    background-color 0.3s var(--cska-ease) !important;
}

.et_pb_button::before, .et_pb_button::after { display: none !important; }

.et_pb_button:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(122, 45, 142, 0.25) !important;
  background: #fff !important;
}

/* Variante CTA primary */
.cska-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--cska-purple) 0%, var(--cska-purple-deep) 100%);
  color: #fff;
  padding: 16px 32px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: transform 0.25s var(--cska-ease), box-shadow 0.25s var(--cska-ease);
  box-shadow: 0 8px 24px rgba(122, 45, 142, 0.25);
}

.cska-cta-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(122, 45, 142, 0.40);
}

.cska-cta-primary::after {
  content: "→";
  transition: transform 0.25s var(--cska-ease);
}

.cska-cta-primary:hover::after { transform: translateX(4px); }

.cska-cta-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.30);
  color: #fff;
  padding: 14px 26px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  backdrop-filter: blur(8px);
  transition: background 0.25s var(--cska-ease), border-color 0.25s var(--cska-ease);
}

.cska-cta-ghost:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.45);
}

/* ============================================================
   6. SECTIONS — espacement aéré
   ============================================================ */

.et_pb_section_1.et_pb_section,
.et_pb_section_2.et_pb_section {
  padding: var(--cska-section) 0 calc(var(--cska-section) * 0.6) !important;
}

.et_pb_section_2.et_pb_section {
  padding-top: calc(var(--cska-section) * 0.55) !important;
}

/* Eyebrow + titre + description pour sections services accueil */
.et_pb_section_1 h3,
.et_pb_section_2 h3 {
  font-size: clamp(32px, 4vw, 52px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  color: var(--cska-ink) !important;
  margin: 0 0 56px !important;
  text-align: center !important;
  line-height: 1.0 !important;
  position: relative;
}

.et_pb_section_1 h3 strong,
.et_pb_section_2 h3 strong {
  font-weight: 800 !important;
}

.et_pb_section_1 h3::before,
.et_pb_section_2 h3::before {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background: var(--cska-purple);
  border-radius: 2px;
  margin: 0 auto 22px;
}

.et_pb_section_1 h3::after,
.et_pb_section_2 h3::after {
  content: "";
  display: block;
  width: 56px;
  height: 3px;
  background: linear-gradient(90deg, var(--cska-purple) 0%, var(--cska-purple-soft) 100%);
  border-radius: 2px;
  margin: 22px auto 0;
}

/* ============================================================
   7. GRILLE SERVICES — 4+3 + démolition 3
   ============================================================ */

.et_pb_row.services-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 220px));
  gap: 28px;
  justify-content: center;
  align-items: start;
  max-width: 1180px !important;
  width: 92% !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.et_pb_row.services-grid::after { content: none !important; }

.et_pb_row.services-grid--row2 {
  grid-template-columns: repeat(3, minmax(0, 220px));
  margin-top: 28px !important;
}

.et_pb_row.services-grid--demolition {
  grid-template-columns: repeat(3, minmax(0, 240px));
  gap: 32px;
  max-width: 920px !important;
}

.services-grid__col {
  width: 100%;
  display: block;
  float: none !important;
  margin: 0 !important;
}

/* Neutraliser tout encadré sur les PNG transparents */
.services-grid__col,
.services-grid__col *,
.services-grid__col *::before,
.services-grid__col *::after {
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 none !important;
  outline: 0 none !important;
  filter: none !important;
}

.services-grid__col img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
}

.services-grid__col a {
  display: block;
  position: relative;
  transition: transform 0.45s var(--cska-ease-out), filter 0.45s var(--cska-ease-out);
  will-change: transform;
}

.services-grid__col a:hover {
  transform: translateY(-4px);
  filter: drop-shadow(0 12px 24px rgba(122, 45, 142, 0.22));
}

@media (max-width: 980px) {
  .et_pb_row.services-grid {
    grid-template-columns: repeat(3, minmax(0, 200px));
  }
  .et_pb_row.services-grid--row2 {
    grid-template-columns: repeat(3, minmax(0, 200px));
  }
}

@media (max-width: 700px) {
  .et_pb_row.services-grid,
  .et_pb_row.services-grid--row2,
  .et_pb_row.services-grid--demolition {
    grid-template-columns: repeat(2, minmax(0, 200px));
    gap: 18px;
  }
}

@media (max-width: 480px) {
  .et_pb_row.services-grid,
  .et_pb_row.services-grid--row2,
  .et_pb_row.services-grid--demolition {
    grid-template-columns: minmax(0, 280px);
  }
}

/* ============================================================
   8. SOUS-SECTION INTRO (section--intro)
   ============================================================ */

.cska-intro {
  max-width: 720px;
  margin: 0 auto 56px;
  text-align: center;
  padding: 0 24px;
}

.cska-intro__eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cska-purple);
  margin-bottom: 14px;
}

.cska-intro__lede {
  font-size: 17px;
  line-height: 1.6;
  color: var(--cska-muted);
  margin: 0;
}

/* ============================================================
   9. PAGES SERVICES — hero violet plus subtil
   ============================================================ */

/* Bouton "Nous contacter" — sobre, sans hatch + reset complet du wrapper et de la colonne */
.et_pb_section_0 .et_pb_button_0_wrapper,
.et_pb_section_0 .et_pb_column,
.et_pb_section_0 .et_pb_row {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
}
.et_pb_section_0 .et_pb_button_0_wrapper {
  padding: 0 !important;
}

/* Diviseur élégant entre titre et description */
.et_pb_module.et_pb_divider {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.45) 0%, rgba(255, 255, 255, 0) 100%) !important;
  height: 1px !important;
  border: none !important;
  opacity: 1 !important;
  margin: 0 0 24px !important;
}

/* ============================================================
   10. PAGES SERVICES — galerie images
   ============================================================ */

.et_pb_section_1 .et_pb_image .et_pb_image_wrap img {
  border-radius: var(--cska-radius) !important;
  box-shadow: var(--cska-shadow-sm) !important;
  transition:
    transform 0.5s var(--cska-ease-out),
    box-shadow 0.5s var(--cska-ease-out) !important;
  will-change: transform;
}

.et_pb_section_1 .et_pb_image:hover .et_pb_image_wrap img {
  transform: scale(1.025) translateY(-3px);
  box-shadow: var(--cska-shadow-md) !important;
}

.et_pb_section_1 .et_pb_module.et_pb_image {
  opacity: 1;
}

/* ============================================================
   11. BREADCRUMBS
   ============================================================ */

.cska-breadcrumb {
  max-width: 1180px;
  width: 92%;
  margin: 0 auto;
  padding: 18px 0 8px;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.78);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.cska-breadcrumb a {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  transition: color 0.25s var(--cska-ease);
}

.cska-breadcrumb a:hover { color: #fff; }

.cska-breadcrumb__sep {
  opacity: 0.5;
  font-size: 10px;
}

.cska-breadcrumb__current {
  color: #fff;
  font-weight: 600;
}

/* ============================================================
   12. RELATED SERVICES (en bas des pages services)
   ============================================================ */

.cska-related {
  background: var(--cska-mist);
  padding: var(--cska-section) 0;
}

.cska-related__inner {
  max-width: 1180px;
  width: 92%;
  margin: 0 auto;
}

.cska-related__title {
  font-size: clamp(24px, 2.6vw, 36px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--cska-ink);
  text-align: center;
  margin: 0 0 36px;
}

.cska-related__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

@media (max-width: 900px) {
  .cska-related__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .cska-related__grid { grid-template-columns: 1fr; }
}

.cska-related__card {
  background: #fff;
  border-radius: var(--cska-radius);
  padding: 22px 24px;
  text-decoration: none;
  color: var(--cska-ink);
  border: 1px solid var(--cska-line);
  transition: transform 0.3s var(--cska-ease), box-shadow 0.3s var(--cska-ease), border-color 0.3s var(--cska-ease);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cska-related__card:hover {
  transform: translateY(-3px);
  border-color: var(--cska-purple-soft);
  box-shadow: var(--cska-shadow-sm);
}

.cska-related__card-tag {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--cska-purple);
}

.cska-related__card-title {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--cska-ink);
}

.cska-related__card-arrow {
  margin-top: auto;
  font-size: 14px;
  color: var(--cska-purple);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.cska-related__card-arrow::after { content: "→"; }

/* ============================================================
   13. CTA BAND (en bas des pages services)
   ============================================================ */

.cska-cta-band {
  margin: var(--cska-section) auto;
  max-width: 1180px;
  width: 92%;
  border-radius: var(--cska-radius-lg);
  background: linear-gradient(135deg, var(--cska-purple) 0%, var(--cska-purple-deep) 100%);
  padding: clamp(40px, 6vw, 64px);
  display: grid;
  grid-template-columns: 1.6fr auto;
  align-items: center;
  gap: 32px;
  color: #fff;
}

@media (max-width: 700px) {
  .cska-cta-band {
    grid-template-columns: 1fr;
    text-align: left;
    padding: 36px 28px;
  }
}

.cska-cta-band__title {
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
  color: #fff;
}

.cska-cta-band__sub {
  font-size: 15px;
  margin: 0;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.6;
}

.cska-cta-band__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  color: var(--cska-purple-deep);
  padding: 14px 26px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  letter-spacing: 0.005em;
  transition: transform 0.25s var(--cska-ease), box-shadow 0.25s var(--cska-ease);
  white-space: nowrap;
}

.cska-cta-band__btn::after { content: "→"; transition: transform 0.25s var(--cska-ease); }
.cska-cta-band__btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0, 0, 0, 0.20); }
.cska-cta-band__btn:hover::after { transform: translateX(4px); }

/* ============================================================
   14. SECTION CONTACT — contraste amélioré
   ============================================================ */

.et_pb_section_3 {
  padding: calc(var(--cska-section) * 0.95) 0 0 !important;
  position: relative;
}

.et_pb_section_3 h2 {
  font-size: clamp(32px, 4.4vw, 60px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.038em !important;
  line-height: 0.96 !important;
  margin-bottom: 32px !important;
}

.et_pb_text_5 h4,
.et_pb_text_6 h4,
.et_pb_text_7 h4,
.et_pb_text_8 h4,
.et_pb_text_9 h4,
.et_pb_text_10 h4 {
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  font-size: clamp(15px, 1.2vw, 17px) !important;
}

/* Inputs formulaire — propres et lisibles */
.et_pb_contact_field input,
.et_pb_contact_field textarea,
.input,
input.input,
textarea.input,
.et_pb_contact_form_label {
  font-family: var(--cska-font) !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  color: #fff !important;
}

.et_pb_contact_field input,
.et_pb_contact_field textarea,
.input,
input.input,
textarea.input {
  border-radius: 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.40) !important;
  background: rgba(255, 255, 255, 0.10) !important;
  padding: 14px 16px !important;
  transition: border-color 0.25s var(--cska-ease), background 0.25s var(--cska-ease) !important;
}

.et_pb_contact_field input::placeholder,
.et_pb_contact_field textarea::placeholder,
input.input::placeholder,
textarea.input::placeholder {
  color: rgba(255, 255, 255, 0.65) !important;
}

.et_pb_contact_field input:focus,
.et_pb_contact_field textarea:focus,
.input:focus {
  outline: none !important;
  border-color: rgba(255, 255, 255, 0.80) !important;
  background: rgba(255, 255, 255, 0.18) !important;
}

/* Bouton Envoi formulaire — visible */
.et_pb_contact_submit.et_pb_button {
  background: #fff !important;
  color: var(--cska-purple-deep) !important;
  font-weight: 700 !important;
  padding: 14px 36px !important;
}

.et_pb_contact_submit.et_pb_button:hover {
  background: var(--cska-amber) !important;
  color: var(--cska-ink) !important;
}

/* Adresse / contact — links cliquables stylés */
.cska-contact-link {
  color: #fff !important;
  text-decoration: none !important;
  transition: opacity 0.25s var(--cska-ease);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600 !important;
}

.cska-contact-link:hover { opacity: 0.75; text-decoration: underline !important; }

/* ============================================================
   15. FOOTER — ENRICHI
   ============================================================ */

#main-footer,
#main-footer .container {
  background-color: transparent !important;
  margin: 0 !important;
}

#footer-bottom {
  background-color: var(--cska-ink) !important;
  margin: 0 !important;
}

#footer-bottom {
  padding: 0 !important;
}

.cska-footer-rich {
  background: var(--cska-ink);
  color: rgba(255, 255, 255, 0.78);
  padding: 56px 0 28px;
}

.cska-footer-rich__inner {
  max-width: 1180px;
  width: 92%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 36px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
}

@media (max-width: 900px) {
  .cska-footer-rich__inner { grid-template-columns: 1fr 1fr; gap: 32px; }
}

@media (max-width: 480px) {
  .cska-footer-rich__inner { grid-template-columns: 1fr; }
}

.cska-footer-col__title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #fff;
  margin: 0 0 16px;
}

.cska-footer-col p,
.cska-footer-col li {
  font-size: 14px;
  line-height: 1.7;
  margin: 0 0 6px;
  color: rgba(255, 255, 255, 0.72);
}

.cska-footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.cska-footer-col a {
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  transition: color 0.25s var(--cska-ease);
}

.cska-footer-col a:hover {
  color: #fff;
}

.cska-footer-brand {
  display: inline-block;
  margin-bottom: 16px;
  text-decoration: none;
  transition: opacity 0.25s var(--cska-ease);
}

.cska-footer-brand:hover { opacity: 0.85; }

.cska-footer-brand img {
  display: block;
  height: 56px;
  width: auto;
  max-width: 200px;
  filter: brightness(1.1);
}

.cska-footer-bottom {
  max-width: 1180px;
  width: 92%;
  margin: 0 auto;
  padding: 24px 0 4px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.55);
}

.cska-footer-bottom a {
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
}

.cska-footer-bottom a:hover { color: #fff; }

/* Le footer Divi natif (footer-bottom) — caché si on a le rich footer */
body.cska-has-rich-footer #footer-bottom { display: none !important; }

/* ============================================================
   16. FAÇADE — sous-services chips
   ============================================================ */

.cska-facade-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 22px 0 32px;
}

.cska-facade-chips__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.005em;
  backdrop-filter: blur(8px);
}

.cska-facade-chips__chip::before {
  content: "•";
  color: var(--cska-amber);
  font-weight: 800;
}

/* ============================================================
   16b. FAÇADE — prestations + galerie
   ============================================================ */

.cska-fac-services {
  padding: clamp(64px, 8vw, 110px) 24px;
  background: var(--cska-mist);
}

.cska-fac-services__inner {
  max-width: 1240px;
  margin: 0 auto;
}

.cska-fac-services__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
}

.cska-fac-card {
  position: relative;
  background: #fff;
  border: 1px solid rgba(10, 3, 1, 0.08);
  border-radius: var(--cska-radius);
  padding: 32px 28px 30px;
  transition:
    transform 0.4s var(--cska-ease-out),
    border-color 0.4s var(--cska-ease-out),
    box-shadow 0.4s var(--cska-ease-out);
}

.cska-fac-card:hover {
  transform: translateY(-4px);
  border-color: rgba(174, 31, 191, 0.35);
  box-shadow: 0 18px 32px -20px rgba(10, 3, 1, 0.18);
}

.cska-fac-card__tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cska-purple);
  margin-bottom: 18px;
}

.cska-fac-card__title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--cska-ink);
  margin: 0 0 14px;
  padding: 0;
}

.cska-fac-card__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--cska-ink-soft);
}

.cska-fac-card__text {
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--cska-muted);
  margin: 0;
  padding: 0;
}

@media (max-width: 980px) {
  .cska-fac-services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 600px) {
  .cska-fac-services__grid { grid-template-columns: 1fr; gap: 14px; }
  .cska-fac-card { padding: 26px 22px 24px; }
}

.cska-fac-gallery {
  padding: 0 24px clamp(64px, 8vw, 120px);
  background: #fff;
}

.cska-fac-gallery__inner {
  max-width: 1320px;
  margin: 0 auto;
  padding-top: clamp(48px, 7vw, 100px);
}

.cska-fac-gallery__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.cska-fac-gallery__item {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--cska-radius);
  background: var(--cska-mist);
  aspect-ratio: 3 / 4;
  box-shadow: var(--cska-shadow-sm);
  transition: box-shadow 0.5s var(--cska-ease-out);
}

.cska-fac-gallery__item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s var(--cska-ease-out);
}

.cska-fac-gallery__item:hover {
  box-shadow: var(--cska-shadow-md);
}

.cska-fac-gallery__item:hover img {
  transform: scale(1.04);
}

@media (max-width: 980px) {
  .cska-fac-gallery__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 600px) {
  .cska-fac-gallery__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
}

/* ============================================================
   17. SCROLL-REVEAL utilitaires
   ============================================================ */

.cska-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.85s var(--cska-ease-out),
    transform 0.85s var(--cska-ease-out);
}

.cska-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   18. PRÉFÉRENCES ACCESSIBILITÉ
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .et_pb_section_0::after { display: none; }
}

/* ============================================================
   19. NAVIGATION — tous les liens en noir (override final)
   ============================================================ */

nav.et-menu-nav > ul.nav > li > a,
#top-menu > li > a,
nav.et-menu-nav > ul.nav > li:first-child > a,
#top-menu > li:first-child > a,
nav.et-menu-nav > ul.nav > li:nth-child(2) > a,
#top-menu > li:nth-child(2) > a,
nav.et-menu-nav > ul.nav > li.menu-item-565 > a,
nav.et-menu-nav > ul.nav > li.cska-menu-facade > a,
#top-menu li.cska-menu-facade > a,
nav.et-menu-nav > ul.nav > li.menu-item-566 > a,
#top-menu > li.menu-item-566 > a,
nav.et-menu-nav > ul.nav > li:nth-last-child(2) > a,
#top-menu > li:nth-last-child(2) > a,
nav.et-menu-nav > ul.nav > li:last-child > a,
#top-menu > li:last-child > a,
nav.et-menu-nav > ul.nav > li.current-menu-item > a,
nav.et-menu-nav > ul.nav > li.current_page_item > a,
.sub-menu li a,
.et-menu .nav li ul li a,
.et_mobile_menu li a,
.et_mobile_menu li.current-menu-item > a {
  color: #000 !important;
}

nav.et-menu-nav > ul.nav > li > a:hover,
#top-menu > li > a:hover,
.sub-menu li a:hover,
.et-menu .nav li ul li a:hover,
.et_mobile_menu li a:hover {
  color: #000 !important;
  background: rgba(0, 0, 0, 0.04) !important;
  filter: none;
}

/* ============================================================
   20. GALERIES DIVI — pages services (override grid)
   ============================================================ */

/* Force l'affichage et grille auto-fit pour le bloc galerie services */
.et_pb_section_1 .et_pb_row {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 18px !important;
  max-width: 1240px !important;
  width: 92% !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.et_pb_section_1 .et_pb_row::after { content: none !important; }

.et_pb_section_1 .et_pb_row .et_pb_column {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  float: none !important;
  display: flex !important;
  flex-direction: column;
}

.et_pb_section_1 .et_pb_module.et_pb_image {
  margin: 0 !important;
  width: 100% !important;
}

.et_pb_section_1 .et_pb_module.et_pb_image .et_pb_image_wrap {
  display: block !important;
  width: 100% !important;
  position: relative;
  overflow: hidden;
  border-radius: var(--cska-radius);
  background: var(--cska-mist);
  aspect-ratio: 4 / 3;
}

.et_pb_section_1 .et_pb_module.et_pb_image .et_pb_image_wrap img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: var(--cska-radius) !important;
  transition: transform 0.6s var(--cska-ease-out) !important;
}

.et_pb_section_1 .et_pb_module.et_pb_image:hover .et_pb_image_wrap img {
  transform: scale(1.04);
}

/* Texte vide qui suit chaque image dans la galerie pavage : on cache */
.et_pb_section_1 .et_pb_module.et_pb_text {
  display: none !important;
}

/* Section galerie : padding cohérent (fond géré ailleurs) */
.et_pb_section_1.et_pb_section {
  padding: clamp(56px, 7vw, 96px) 0 !important;
}

/* ============================================================
   21. CTA BAND — typographie française (espace ?)
   ============================================================ */

.cska-cta-band__title {
  hyphens: none;
}

/* ============================================================
   22. BREADCRUMB — séparateur visible
   ============================================================ */

.cska-breadcrumb__sep {
  opacity: 0.85 !important;
  font-size: 12px;
  margin: 0 2px;
  color: rgba(255, 255, 255, 0.6);
}

.cska-breadcrumb {
  font-size: 13px;
  padding: 22px 0 4px;
}

/* ============================================================
   23. HERO TEXTE — meilleur wrap
   ============================================================ */

.et_pb_section_0 .et_pb_text_1 p {
  text-wrap: pretty;
}

/* ============================================================
   24. SECTION CONTACT — fond et alignement
   ============================================================ */

.et_pb_section_3 {
  background: linear-gradient(160deg, var(--cska-purple-deep) 0%, var(--cska-purple) 60%, var(--cska-purple-deep) 100%) !important;
}

.et_pb_section_3 .et_pb_row {
  max-width: 1180px !important;
  width: 92% !important;
}

/* Force le label "Envoi" à utiliser la police texte (et non ETmodules
   qui transforme certaines lettres en glyphs icônes). */
.et_pb_button_module_wrapper input.et_pb_contact_submit,
.et_pb_button.et_pb_contact_submit,
.et_pb_contact_submit.et_pb_button {
  font-family: var(--cska-font) !important;
  text-transform: none !important;
}

.et_pb_contact_submit.et_pb_button::before,
.et_pb_contact_submit.et_pb_button::after {
  display: none !important;
  content: none !important;
}

/* Champs contact : labels cachés (placeholder suffit), focus visible */
.et_pb_contact_form_label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.et_pb_contact_field input::placeholder,
.et_pb_contact_field textarea::placeholder,
input.input::placeholder,
textarea.input::placeholder {
  color: rgba(255, 255, 255, 0.78) !important;
}

/* ============================================================
   25. FORMULAIRE CONTACT — layout mobile correct
   ============================================================ */

@media (max-width: 700px) {
  .et_pb_contact_field {
    width: 100% !important;
    margin-right: 0 !important;
    float: none !important;
  }
  .et_pb_contact_field_half {
    width: 100% !important;
  }
}

/* ============================================================
   26. FOOTER — alignement et lisibilité
   ============================================================ */

.cska-footer-rich__inner {
  align-items: start;
}

.cska-footer-col {
  min-width: 0;
}

.cska-footer-col__title {
  margin-top: 0;
}

.cska-footer-col p,
.cska-footer-col li,
.cska-footer-col a {
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

.cska-footer-brand img {
  filter: none;
}

/* Masque le footer-info Divi natif sur toutes les pages avec rich footer */
body:has(.cska-footer-rich) #footer-info,
body:has(.cska-footer-rich) #footer-bottom {
  display: none !important;
}

/* ============================================================
   27. PAGES SERIES — éviter background blanc résiduel
   ============================================================ */

.et_pb_section_1.et_pb_section,
.et_pb_section_2.et_pb_section {
  background: transparent !important;
}

/* La section CTA-band wrapper — fond transparent (pas de fond noir) */
.cska-cta-band {
  margin: 0 auto !important;
  width: 92% !important;
}

.cska-cta-band-wrap {
  background: transparent;
  padding: clamp(56px, 7vw, 96px) 0;
}

/* ============================================================
   28. MENTIONS LÉGALES — section custom
   ============================================================ */

.cska-legal {
  background: var(--cska-mist);
  padding: clamp(64px, 8vw, 110px) 0 clamp(48px, 6vw, 96px);
}

.cska-legal__inner {
  max-width: 760px;
  width: 92%;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--cska-line);
  border-radius: var(--cska-radius-lg);
  padding: clamp(32px, 5vw, 56px);
  box-shadow: var(--cska-shadow-sm);
}

.cska-legal__title {
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 8px;
  color: var(--cska-ink);
}

.cska-legal__lede {
  font-size: 15px;
  color: var(--cska-muted);
  margin: 0 0 32px;
}

.cska-legal h2 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--cska-ink);
  margin: 28px 0 8px;
}

.cska-legal p,
.cska-legal address {
  font-size: 15px;
  line-height: 1.65;
  color: var(--cska-ink-soft);
  font-style: normal;
  margin: 0 0 6px;
}

.cska-legal a {
  color: var(--cska-purple);
  text-decoration: none;
  font-weight: 600;
}
.cska-legal a:hover { text-decoration: underline; }

/* ============================================================
   29. PRÉFÉRENCES MOTION — couvrir cska-fac-card
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  .cska-fac-card,
  .cska-fac-card:hover,
  .cska-fac-gallery__item,
  .cska-fac-gallery__item:hover img,
  .services-grid__col a,
  .services-grid__col a:hover {
    transform: none !important;
    transition: none !important;
  }
}

/* ============================================================
   30. CTA pill primary "Nous contacter" hero
   ============================================================ */

.et_pb_section_0 .et_pb_button {
  background: #fff !important;
  color: var(--cska-purple-deep) !important;
  border: 1px solid rgba(255, 255, 255, 0.4) !important;
  padding: 14px 28px !important;
  font-weight: 700 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.16);
}

.et_pb_section_0 .et_pb_button:hover {
  background: var(--cska-amber) !important;
  color: var(--cska-ink) !important;
  border-color: var(--cska-amber) !important;
}

/* ============================================================
   31. BACKDROP-FILTER fallback (Safari iOS)
   ============================================================ */

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  #main-header,
  .et_pb_section.et_pb_section_0_tb_header {
    background-color: rgba(255, 255, 255, 0.92) !important;
  }
}

/* ============================================================
   32. CSKA chips façade — wrap propre
   ============================================================ */

.cska-facade-chips {
  max-width: 720px;
}

@media (max-width: 700px) {
  .cska-facade-chips__chip {
    font-size: 12px;
    padding: 6px 12px;
  }
}

/* ============================================================
   33. Hero text wrap balance + container
   ============================================================ */

body.home .et_pb_section_0 h1,
body.page-id-43 .et_pb_section_0 h1 {
  text-wrap: balance;
  max-width: 22ch;
}

@media (max-width: 700px) {
  .et_pb_section_0 .et_pb_text_0 h1 {
    font-size: clamp(30px, 8vw, 44px) !important;
    max-width: 100% !important;
  }
  .et_pb_section_0 .et_pb_text_1 p {
    font-size: 15px !important;
  }
  body.home .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner::before,
  body.page-id-43 .et_pb_section_0 .et_pb_text_0 .et_pb_text_inner::before {
    font-size: 10px;
    letter-spacing: 0.12em;
    padding: 5px 11px;
    margin-bottom: 14px;
  }
}

/* ============================================================
   34. Section titres — poids cohérent
   ============================================================ */

.et_pb_section_3 h1,
.et_pb_section_3 h2,
.et_pb_section_3 h3 {
  font-size: clamp(28px, 3.6vw, 48px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  line-height: 1.0 !important;
  margin: 0 0 24px !important;
  color: #fff !important;
  text-wrap: balance;
}

/* ============================================================
   35. Page contact — supprimer min-height excessif si no hero
   ============================================================ */

body.cska-page-contact .et_pb_section_3 {
  min-height: auto !important;
  padding-top: clamp(96px, 12vw, 140px) !important;
  padding-bottom: clamp(64px, 8vw, 112px) !important;
}

/* ============================================================
   36. Section section_2 (démolition home) — séparateur visuel
   ============================================================ */

.et_pb_section_2 {
  border-top: 0;
}

/* ============================================================
   37. FIX — Grille services (home) ne doit pas hériter du grid
   des galeries services. Les hexagones PNG transparents doivent
   garder leur ratio carré, sans crop ni aspect-ratio 4/3.
   ============================================================ */

.et_pb_section_1 .et_pb_row.services-grid,
.et_pb_section_2 .et_pb_row.services-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 220px)) !important;
  gap: 28px !important;
  justify-content: center !important;
  align-items: start !important;
  max-width: 1180px !important;
  width: 92% !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.et_pb_section_1 .et_pb_row.services-grid--row2 {
  grid-template-columns: repeat(3, minmax(0, 220px)) !important;
  margin-top: 28px !important;
}

.et_pb_section_2 .et_pb_row.services-grid--demolition {
  grid-template-columns: repeat(3, minmax(0, 240px)) !important;
  gap: 32px !important;
  max-width: 920px !important;
}

.et_pb_section_1 .services-grid__col,
.et_pb_section_2 .services-grid__col {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  float: none !important;
  display: block !important;
  flex-direction: initial !important;
}

.services-grid__col .et_pb_module.et_pb_image,
.services-grid__col .et_pb_module.et_pb_image .et_pb_image_wrap {
  position: static !important;
  inset: auto !important;
  display: block !important;
  background: transparent !important;
  border-radius: 0 !important;
  aspect-ratio: auto !important;
  overflow: visible !important;
  height: auto !important;
  width: 100% !important;
  margin: 0 !important;
}

.services-grid__col .et_pb_module.et_pb_image .et_pb_image_wrap img {
  position: static !important;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 0 !important;
  display: block !important;
  transform: none !important;
}

.services-grid__col .et_pb_module.et_pb_image:hover .et_pb_image_wrap img {
  transform: none !important;
}

/* Le titre H3 "Travaux Publics" (section_1 sur la home) ne doit pas être
   caché par la règle qui masque les blocs texte vides des galeries. */
body.cska-page-home .et_pb_section_1 .et_pb_module.et_pb_text {
  display: block !important;
}

@media (max-width: 980px) {
  .et_pb_section_1 .et_pb_row.services-grid,
  .et_pb_section_2 .et_pb_row.services-grid {
    grid-template-columns: repeat(3, minmax(0, 200px)) !important;
  }
  .et_pb_section_1 .et_pb_row.services-grid--row2 {
    grid-template-columns: repeat(3, minmax(0, 200px)) !important;
  }
}

@media (max-width: 700px) {
  .et_pb_section_1 .et_pb_row.services-grid,
  .et_pb_section_1 .et_pb_row.services-grid--row2,
  .et_pb_section_2 .et_pb_row.services-grid--demolition {
    grid-template-columns: repeat(2, minmax(0, 200px)) !important;
    gap: 18px !important;
  }
}

@media (max-width: 480px) {
  .et_pb_section_1 .et_pb_row.services-grid,
  .et_pb_section_1 .et_pb_row.services-grid--row2,
  .et_pb_section_2 .et_pb_row.services-grid--demolition {
    grid-template-columns: minmax(0, 280px) !important;
  }
}

/* ============================================================
   38. PASSE FINALE — corrections de bugs visuels (boutons, focus,
   typo, palette, conflits, etc.)
   ============================================================ */

/* 38.2 — Focus-visible : forme adaptée à l'élément (pas tout en pill) */
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--cska-amber);
  outline-offset: 3px;
  border-radius: inherit;
}
.et_pb_button:focus-visible,
.cska-cta-band__btn:focus-visible,
.cska-nav-cta:focus-visible {
  border-radius: 999px;
}
.cska-related__card:focus-visible,
.cska-fac-gallery__item:focus-visible {
  border-radius: var(--cska-radius);
}
.cska-fac-card:focus-visible {
  border-radius: var(--cska-radius);
}
.cska-breadcrumb a:focus-visible {
  border-radius: 6px;
}

/* 38.3 — Bouton primaire : feedback couleur réel sur hover */
.et_pb_button:hover {
  background: var(--cska-amber) !important;
  color: var(--cska-ink) !important;
}

/* 38.4 — Bouton hero pages services : retirer le bord blanc invisible */
.et_pb_section_0 .et_pb_button {
  border: 0 !important;
}

/* 38.5 — Bouton submit form : centré dans son container, pas collé à gauche */
.et_contact_bottom_container {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-top: 8px;
}

/* 38.6 — Hero meta separator : disparaît en mobile pour ne pas avoir de
   barres flottantes orphelines quand les items wrappent */
@media (max-width: 700px) {
  .cska-hero-meta__item:not(:last-child)::after {
    display: none;
  }
  .cska-hero-meta {
    gap: 18px;
    padding-top: 18px;
  }
  .cska-hero-meta__item {
    padding-right: 0;
  }
}

/* 38.7 — Mentions légales : aligner les tailles avec le reste du site */
.cska-legal__inner {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}
.cska-legal {
  background: #fff;
}
.cska-legal__inner {
  max-width: 760px;
}
.cska-legal h2 {
  font-size: clamp(20px, 2vw, 26px);
  margin: 36px 0 12px;
}
.cska-legal p,
.cska-legal address {
  font-size: 17px;
  line-height: 1.7;
}
.cska-legal__lede {
  font-size: 17px;
  line-height: 1.6;
  margin: 0 0 40px;
}
/* Le H1 de la card ne s'affiche plus (on l'a déplacé dans le hero violet) */
.cska-page-legal .cska-legal__title,
.cska-page-legal .cska-legal__lede {
  display: none;
}

/* 38.8 — Card related : feedback couleur sur les enfants au hover */
.cska-related__card-title {
  transition: color 0.25s var(--cska-ease);
}
.cska-related__card-arrow {
  transition: color 0.25s var(--cska-ease), transform 0.25s var(--cska-ease);
}
.cska-related__card-arrow::after {
  transition: transform 0.25s var(--cska-ease);
  display: inline-block;
}
.cska-related__card:hover .cska-related__card-title {
  color: var(--cska-purple);
}
.cska-related__card:hover .cska-related__card-arrow::after {
  transform: translateX(4px);
}

/* 38.9 — Mobile menu : styling cohérent avec le reste du site */
.mobile_nav .mobile_menu_bar::before {
  color: var(--cska-ink) !important;
  font-size: 24px !important;
  transition: color 0.25s var(--cska-ease);
}
.mobile_nav.opened .mobile_menu_bar::before {
  color: var(--cska-purple) !important;
}
.et_mobile_menu {
  background: #fff !important;
  border-top: 1px solid var(--cska-line) !important;
  box-shadow: var(--cska-shadow-md) !important;
  padding: 12px 0 !important;
}
.et_mobile_menu li {
  border-color: var(--cska-line) !important;
}
.et_mobile_menu li a {
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 12px 20px !important;
  color: var(--cska-ink) !important;
  transition: background 0.2s var(--cska-ease), color 0.2s var(--cska-ease);
}
.et_mobile_menu li a:hover {
  background: var(--cska-purple-50) !important;
  color: var(--cska-purple) !important;
}

/* 38.10 — Form submit : alignement et largeur cohérents */
.et_pb_contact_submit.et_pb_button {
  margin-top: 8px !important;
  border: 0 !important;
}

/* 38.11 — Card façade italic : éviter italic synthétique laid si la fonte
   ne fournit pas de variant italic */
.cska-fac-card__title em {
  font-synthesis: style;
  font-weight: 400;
  font-style: italic;
}

/* 38.12 — Gallery item : ajout d'un overlay subtil sur hover pour signaler
   l'interaction au-delà du scale */
.cska-fac-gallery__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(20, 16, 28, 0.35) 100%);
  opacity: 0;
  transition: opacity 0.4s var(--cska-ease-out);
  pointer-events: none;
  z-index: 1;
}
.cska-fac-gallery__item:hover::after {
  opacity: 1;
}

/* 38.13 — Footer : ajouter espacement minimal sur la rangée bas en mobile */
.cska-footer-bottom {
  gap: 12px 16px;
}
@media (max-width: 600px) {
  .cska-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    padding-bottom: 12px;
  }
}

/* 38.14 — Section_2 : pas de border (fond et contour retirés des hexagones) */
.et_pb_section_2 {
  border-top: 0;
}

/* 38.15 — Pages services : le H3 de la galerie restait masqué (rule générale
   `.et_pb_section_1 .et_pb_module.et_pb_text { display:none }`).
   On la limite aux blocs texte qui suivent une image (cas des pages pavage). */
.et_pb_section_1 .et_pb_module.et_pb_text {
  display: block !important;
}
.et_pb_section_1 .et_pb_module.et_pb_image + .et_pb_module.et_pb_text:empty,
.et_pb_section_1 .et_pb_module.et_pb_image + .et_pb_module.et_pb_text:has(.pointer-events-none) {
  display: none !important;
}

/* 38.17 — Bouton hero CTA : transition fluide entre states */
.et_pb_section_0 .et_pb_button {
  transition:
    transform 0.25s var(--cska-ease),
    background-color 0.25s var(--cska-ease),
    color 0.25s var(--cska-ease),
    box-shadow 0.25s var(--cska-ease) !important;
}

/* 38.18 — Card façade : couleur de border hover liée à la variable
   plutôt qu'hardcodée */
.cska-fac-card:hover {
  border-color: rgba(174, 31, 191, 0.35);
}

/* 38.19 — Hero h1 max-width consolidée (résolution des conflits 18ch/22ch) */
body.home .et_pb_section_0 h1,
body.cska-page-home .et_pb_section_0 h1 {
  max-width: 22ch;
}
body:not(.home):not(.cska-page-home) .et_pb_section_0 h1 {
  max-width: 18ch;
}

/* 38.20 — Form input focus : box-shadow visible pour signaler l'état */
.et_pb_contact_field input:focus,
.et_pb_contact_field textarea:focus,
.input:focus {
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.18) !important;
}

/* 38.21 — Buttons : retirer overflow:hidden inutile (pas de pseudo
   à clipper) — restaurer un comportement standard */
.et_pb_button {
  overflow: visible;
}

/* 38.22 — Footer adjacency : le bouton du formulaire flottait hors de la
   section contact sur l'accueil, créant une bande blanche avant le footer. */
.et_pb_contact_form::after,
.et_pb_contact::after {
  content: "";
  display: block;
  clear: both;
}

.et_contact_bottom_container {
  float: none !important;
  clear: both !important;
  width: 100% !important;
  justify-content: flex-end;
  margin-top: 24px !important;
}

body.home .et_pb_section_3,
body.cska-page-home .et_pb_section_3 {
  padding-bottom: clamp(72px, 8vw, 116px) !important;
  margin-bottom: 0 !important;
}

body.home .et_pb_section_1.et_pb_section,
body.cska-page-home .et_pb_section_1.et_pb_section {
  padding-bottom: 0 !important;
}

@media (max-width: 700px) {
  body.et-tb-has-header #main-content {
    padding-top: 0 !important;
  }

  body.et-tb-has-header .et_pb_section_0 {
    width: 100% !important;
    min-width: 100% !important;
    max-width: none !important;
  }

  body.et-tb-has-header .et_pb_section_0 > .et_pb_row {
    width: 92% !important;
    max-width: 92% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .et_contact_bottom_container {
    justify-content: center;
  }
}

/* ============================================================
   39. FIX — masque le liseré violet présent dans les PNG
   des hexagones de la home (services-grid). On applique un
   clip-path octogonal légèrement à l'intérieur pour cacher
   le contour parasite cuit dans l'image, et on neutralise
   le box-shadow / border-radius hérités des galeries services.
   ============================================================ */
.et_pb_section_1 .services-grid__col .et_pb_image .et_pb_image_wrap img,
.et_pb_section_2 .services-grid__col .et_pb_image .et_pb_image_wrap img,
.services-grid__col .et_pb_image .et_pb_image_wrap img,
.services-grid__col img {
  clip-path: polygon(
    32% 4%, 68% 4%,
    96% 32%, 96% 68%,
    68% 96%, 32% 96%,
    4% 68%, 4% 32%
  ) !important;
  -webkit-clip-path: polygon(
    32% 4%, 68% 4%,
    96% 32%, 96% 68%,
    68% 96%, 32% 96%,
    4% 68%, 4% 32%
  ) !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  filter: none !important;
}

/* ============================================================
   40. FIX — Espacement images, toutes pages
   Bug : galeries Divi multi-rows et grilles cards/related
   avaient des espaces trop petits ou inexistants entre images.
   Solution : gaps unifiés à 24px et margin-bottom robuste sur
   toutes les rangées de section_1.
   ============================================================ */

/* Section_1 (galeries pages services) : grille avec gap horizontal ET vertical */
.et_pb_section_1 .et_pb_row:not(.services-grid) {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 24px !important;
  max-width: 1240px !important;
  width: 92% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 !important;
}

/* Espace vertical entre rangées (chaque row est sa propre grid) */
.et_pb_section_1 > .et_pb_row:not(.services-grid) + .et_pb_row:not(.services-grid),
.et_pb_section_1 .et_builder_inner_content > .et_pb_row:not(.services-grid) + .et_pb_row:not(.services-grid) {
  margin-top: 24px !important;
}

.et_pb_section_1 .et_pb_row:not(.services-grid):not(:last-child) {
  margin-bottom: 0 !important;
}

@media (max-width: 700px) {
  .et_pb_section_1 .et_pb_row:not(.services-grid) {
    gap: 16px !important;
  }
  .et_pb_section_1 > .et_pb_row:not(.services-grid) + .et_pb_row:not(.services-grid),
  .et_pb_section_1 .et_builder_inner_content > .et_pb_row:not(.services-grid) + .et_pb_row:not(.services-grid) {
    margin-top: 16px !important;
  }
}

/* Espace vertical entre rangées sur sections services accueil */
.et_pb_row.services-grid + .et_pb_row.services-grid {
  margin-top: 28px !important;
}

/* ============================================================
   41. FIX — Galerie façade : gap plus généreux
   ============================================================ */
.cska-fac-gallery__grid {
  gap: 22px !important;
}
@media (max-width: 600px) {
  .cska-fac-gallery__grid { gap: 14px !important; }
}

/* ============================================================
   42. FIX — Cards "related services" en bas des pages
   ============================================================ */
.cska-related__grid {
  gap: 20px !important;
}
@media (max-width: 900px) {
  .cska-related__grid { gap: 16px !important; }
}

/* ============================================================
   43. FIX — Sécurité images individuelles (pas d'overlap)
   ============================================================ */

.et_pb_section_1 .et_pb_module.et_pb_image .et_pb_image_wrap {
  min-height: 1px;
  display: block !important;
}

.et_pb_section_1 .et_pb_module.et_pb_image {
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.et_pb_section_1 .et_pb_row .et_pb_column {
  padding: 0 !important;
  margin: 0 !important;
}

.cska-fac-gallery__item {
  position: relative;
  overflow: hidden;
}

