@import url('https://fonts.googleapis.com/css2?family=DM+Sans&family=DM+Serif+Display&display=swap');

/* ─── Typographie globale du module (priorité sur le thème via #ventilhome) ─── */
#ventilhome h2 {
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
}

#ventilhome p {
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif !important;
  line-height: 1.7 !important;
  color: #4a6278 !important;
}

/* Paragraphes sur fond sombre : couleurs lisibles (surcharge du #ventilhome p) */
#ventilhome .ventilhome__hero-panel p,
#ventilhome .ventilhome__hero-body p {
  color: inherit !important;
}

#ventilhome .ventilhome__norm-box p,
#ventilhome .ventilhome__norm-box-text p,
#ventilhome .ventilhome__norm-box-title p {
  color: inherit !important;
}

#ventilhome .ventilhome__clients-subtitle p,
#ventilhome .ventilhome__clients-label p {
  color: inherit !important;
}

#ventilhome .ventilhome__clients-detail {
  color: rgba(190, 214, 230, 0.92) !important;
}

#ventilhome .ventilhome__contact-band-text p {
  color: inherit !important;
}

.ventilhome {
  --vh-color-primary: #0e3a52;
  --vh-color-primary-strong: #0a2f42;
  --vh-color-accent: #1f7ea9;
  --vh-color-accent-bright: #1e6bbd;
  --vh-color-orange: #e05c20;
  --vh-color-bg-soft: #f4f8fb;
  --vh-color-border-soft: rgba(204, 218, 236, 0.65);
  --vh-color-text: #22313f;
  --vh-maquette-text: #1a2a38;
  --vh-maquette-title-blue: #1a4a72;
  --vh-color-muted: #5d6b76;
  --vh-radius: 16px;
  --vh-shadow: 0 12px 32px rgba(14, 58, 82, 0.1);
  color: var(--vh-color-text);
}

.ventilhome .ventilhome__section {
  padding: 3.5rem 0;
}

.ventilhome .ventilhome__hero {
  background: #fff;
  padding-bottom: 0;
  margin-bottom: 0;
}

.ventilhome .ventilhome__hero + .ventilhome__gamme {
  padding-top: 0;
  margin-top: 0;
}

.ventilhome .ventilhome__section:nth-child(even):not(.ventilhome__gamme) {
  background: var(--vh-color-bg-soft);
}

.ventilhome .ventilhome__section.ventilhome__gamme {
  background: #fff;
  border-bottom: 1px solid var(--vh-color-border-soft);
}

.ventilhome .ventilhome__title {
  margin: 0 0 1rem;
  font-size: clamp(1.5rem, 2.5vw, 2.1rem);
  line-height: 1.2;
  color: var(--vh-color-primary);
}

.ventilhome .ventilhome__subtitle {
  margin: 0 auto 1.75rem;
  max-width: 760px;
  color: var(--vh-color-muted);
  text-align: center;
}

.ventilhome .ventilhome__text {
  margin-bottom: 1.25rem;
  line-height: 1.7;
  color: var(--vh-color-text);
}

.ventilhome .ventilhome__media {
  margin: 0;
  border-radius: var(--vh-radius);
  overflow: hidden;
  box-shadow: var(--vh-shadow);
  background: #fff;
}

.ventilhome .ventilhome__media img {
  width: 100%;
  height: auto;
  display: block;
}

.ventilhome .ventilhome__badges {
  margin: 0 0 1.5rem;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ventilhome .ventilhome__badges li {
  border: 1px solid rgba(14, 58, 82, 0.2);
  color: var(--vh-color-primary);
  border-radius: 999px;
  padding: 0.35rem 0.85rem;
  font-size: 0.875rem;
  background: #fff;
}

.ventilhome .ventilhome__hero-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  min-height: 430px;
  overflow: hidden;
  width: 100%;
  max-width: none;
}

.ventilhome .ventilhome__hero-col {
  min-width: 0;
  width: 100%;
  display: flex;
}

.ventilhome .ventilhome__hero-media {
  margin: 0;
  height: 100%;
  width: 100%;
  flex: 1 1 auto;
}

.ventilhome .ventilhome__hero-media img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  display: block;
}

.ventilhome .ventilhome__hero-media-placeholder {
  width: 100%;
  min-height: 430px;
  height: 100%;
  background: linear-gradient(135deg, #1a4a6a 0%, #0b2b45 50%, #0a2036 100%);
}

.ventilhome .ventilhome__hero-panel {
  background: #0f3655;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  padding: 2.4rem 2.3rem;
}

.ventilhome .ventilhome__hero-accent {
  display: inline-block;
  width: 32px;
  height: 3px;
  border-radius: 2px;
  background: #2f8ab8;
  margin-bottom: 1.15rem;
}

.ventilhome .ventilhome__hero-title {
  color: #fff;
  margin: 0 0 1.15rem;
}

.ventilhome .ventilhome__hero-title h1,
.ventilhome .ventilhome__hero-title h2,
.ventilhome .ventilhome__hero-title h3,
.ventilhome .ventilhome__hero-title h4,
.ventilhome .ventilhome__hero-title h5,
.ventilhome .ventilhome__hero-title h6 {
  color: inherit !important;
  margin: 0 0 1.15rem !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  text-transform: none !important;
}

.ventilhome .ventilhome__hero-title * {
  text-transform: none !important;
}

.ventilhome .ventilhome__hero-title h2 {
  font-size: revert !important;
}

.ventilhome .ventilhome__hero-title p {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  text-transform: none;
}

.ventilhome .ventilhome__hero-body {
  color: rgba(255, 255, 255, 0.86);
  font-size: 16px;
  line-height: 1.75;
}

.ventilhome .ventilhome__hero-body p {
  margin: 0 0 1.25rem;
}

.ventilhome .ventilhome__hero-body p:last-child {
  margin-bottom: 1.35rem;
}

.ventilhome .ventilhome__hero-body ul,
.ventilhome .ventilhome__hero-body ol {
  margin: 0 0 1.25rem;
  padding-left: 1.25rem;
}

.ventilhome .ventilhome__hero-badges {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ventilhome .ventilhome__hero-badges li {
  border: 1px solid rgba(120, 188, 225, 0.35);
  color: #dbeef7;
  border-radius: 999px;
  padding: 0.35rem 0.85rem;
  font-size: 0.85rem;
  background: rgba(40, 112, 151, 0.5);
}

.ventilhome .ventilhome__gamme-head {
  margin-bottom: 1.5rem;
}

.ventilhome .ventilhome__gamme .ventilhome__title {
  margin: 0 0 1rem;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.5rem, 2.5vw, 2.1rem);
  line-height: 1.2;
  font-weight: 600;
  color: var(--vh-maquette-title-blue);
}

.ventilhome .ventilhome__gamme .ventilhome__title h1,
.ventilhome .ventilhome__gamme .ventilhome__title h2,
.ventilhome .ventilhome__gamme .ventilhome__title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__gamme-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 700;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  color: #2a7fb0;
}

.ventilhome .ventilhome__gamme-line {
  width: 28px;
  height: 2px;
  background: #2a7fb0;
  border-radius: 1px;
}

.ventilhome .ventilhome__gamme-subtitle {
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.05rem, 1.45vw, 1.2rem);
  font-weight: 700;
  line-height: 1.3;
  color: var(--vh-maquette-text);
  margin-bottom: 0.75rem;
}

.ventilhome .ventilhome__gamme-subtitle h3 {
  margin: 0 0 0.75rem;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__gamme .ventilhome__gamme-content .ventilhome__text {
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--vh-maquette-text);
}

.ventilhome .ventilhome__gamme .ventilhome__gamme-content .ventilhome__text p {
  margin: 0 0 0.9rem;
}

.ventilhome .ventilhome__gamme .ventilhome__gamme-content .ventilhome__text p:last-child {
  margin-bottom: 0;
}

.ventilhome .ventilhome__gamme-note {
  margin: 1rem 0;
  background: #e9f3fb;
  border-left: 3px solid #2a7fb0;
  padding: 0.75rem 0.9rem;
  border-radius: 8px;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 15px;
  color: var(--vh-maquette-text);
}

.ventilhome .ventilhome__gamme-actions {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.ventilhome .ventilhome__gamme-btn {
  border-radius: 999px;
  font-weight: 600;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

.ventilhome .ventilhome__gamme-list {
  margin-top: 0.9rem;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 15px;
  line-height: 1.65;
  color: var(--vh-maquette-text) !important;
  font-weight: 400;
}

.ventilhome .ventilhome__gamme-list ul {
  margin: 0;
  padding-left: 1.2rem;
  list-style: disc outside !important;
  color: inherit !important;
}

.ventilhome .ventilhome__gamme-list ol {
  margin: 0;
  padding-left: 1.2rem;
  list-style: decimal outside !important;
  color: inherit !important;
}

.ventilhome .ventilhome__gamme-list li {
  margin-bottom: 0.35rem;
  color: inherit !important;
  font-weight: 400 !important;
}

.ventilhome .ventilhome__gamme-list li::marker {
  color: inherit !important;
}

/* Si le contenu BO est saisi en paragraphes au lieu de <ul><li> */
.ventilhome .ventilhome__gamme-list > p {
  position: relative;
  margin: 0 0 0.35rem;
  padding-left: 1rem;
}

.ventilhome .ventilhome__gamme-list > p::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--vh-maquette-text);
}

figure.ventilhome__media.ventilhome__gamme-media {
  position: relative;
  max-width: 100%;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  box-shadow: 0 12px 28px rgba(14, 58, 82, 0.1);
}

figure.ventilhome__media.ventilhome__gamme-media::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    145deg,
    rgba(26, 74, 114, 0.2) 0%,
    rgba(30, 107, 189, 0.1) 42%,
    transparent 68%
  );
  pointer-events: none;
}

figure.ventilhome__media.ventilhome__gamme-media img {
  position: relative;
  z-index: 0;
}

@media (min-width: 992px) {
  figure.ventilhome__media.ventilhome__gamme-media {
    margin-left: 0;
    margin-right: 0;
  }
}

.ventilhome .ventilhome__cta {
  border-radius: 999px;
  padding: 0.6rem 1.15rem;
  font-weight: 600;
}

/* ─── Désenfumage (maquette section-bg + feature-row + norm-box) ─── */
.ventilhome .ventilhome__desenfumage {
  background: var(--vh-color-bg-soft);
  border-bottom: 1px solid var(--vh-color-border-soft);
}

.ventilhome .ventilhome__des-head {
  margin-bottom: 0.5rem;
}

.ventilhome .ventilhome__des-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.5rem;
}

.ventilhome .ventilhome__des-line {
  width: 36px;
  height: 3px;
  flex-shrink: 0;
  border-radius: 2px;
  background: var(--vh-color-orange);
}

.ventilhome .ventilhome__des-eyebrow-text {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--vh-color-orange);
}

.ventilhome .ventilhome__des-eyebrow-text p {
  margin: 0;
}

.ventilhome .ventilhome__des-main-title {
  margin: 0 0 0.25rem;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.5rem, 2.4vw, 1.75rem);
  line-height: 1.2;
  color: var(--vh-color-text);
}

.ventilhome .ventilhome__des-main-title h1,
.ventilhome .ventilhome__des-main-title h2,
.ventilhome .ventilhome__des-main-title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: 600;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__des-row {
  display: grid;
  /* Maquette : ~45 % visuel, ~55 % texte */
  grid-template-columns: minmax(0, 0.45fr) minmax(0, 0.55fr);
  gap: clamp(1.75rem, 4vw, 3.5rem);
  align-items: start;
  margin-top: 2rem;
}

.ventilhome .ventilhome__des-figure {
  margin: 0;
  border-radius: var(--vh-radius);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: 0 12px 32px rgba(14, 58, 82, 0.12);
  background: #e8eef5;
}

.ventilhome .ventilhome__des-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(28%);
}

.ventilhome .ventilhome__des-subtitle {
  margin: 0 0 0.75rem;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  line-height: 1.28;
  color: var(--vh-color-primary-strong);
}

.ventilhome .ventilhome__des-subtitle h3,
.ventilhome .ventilhome__des-subtitle p {
  margin: 0;
  font-size: inherit;
  font-weight: 700;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__des-prose--maquette .ventilhome__des-body {
  font-size: 0.875rem;
}

.ventilhome .ventilhome__des-body {
  font-size: 0.9rem;
  line-height: 1.72;
  color: var(--vh-color-muted);
}

.ventilhome .ventilhome__des-body p {
  margin: 0 0 0.9rem;
}

.ventilhome .ventilhome__des-body p:last-child {
  margin-bottom: 0;
}

.ventilhome .ventilhome__des-prose--maquette .ventilhome__des-body strong {
  color: var(--vh-color-text);
  font-weight: 600;
}

.ventilhome .ventilhome__norm-box {
  margin-top: 1rem;
  padding: 1.35rem 1.4rem;
  border-radius: var(--vh-radius);
  background: #0f2d4a;
  color: #fff;
}

.ventilhome .ventilhome__norm-box-title {
  margin: 0 0 0.55rem;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #7ec6f5;
}

.ventilhome .ventilhome__norm-box-title p,
.ventilhome .ventilhome__norm-box-title h4 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  color: inherit;
}

.ventilhome .ventilhome__norm-badge {
  display: inline-block;
  margin-bottom: 0.65rem;
  padding: 0.4rem 1rem;
  border-radius: 6px;
  background: var(--vh-color-orange);
  color: #fff;
  font-size: 0.88rem;
  font-weight: 700;
}

.ventilhome .ventilhome__norm-box-text {
  font-size: 0.82rem;
  line-height: 1.6;
  color: #9eb8cc;
}

.ventilhome .ventilhome__norm-box-text p {
  margin: 0;
}

.ventilhome .ventilhome__des-actions {
  margin-top: 1.5rem;
}

.ventilhome .ventilhome__des-cta {
  display: inline-block;
  padding: 0.625rem 1.25rem;
  border-radius: 10px;
  font-size: 0.8125rem;
  font-weight: 600;
  background: var(--vh-color-accent-bright);
  color: #fff !important;
  border: none;
  text-decoration: none;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
}

.ventilhome .ventilhome__des-cta:hover,
.ventilhome .ventilhome__des-cta:focus {
  background: #1856a3;
  color: #fff !important;
}

/* ─── HSE / charbon actif (maquette section-white + feature-row) ─── */
.ventilhome .ventilhome__section.ventilhome__hse,
.ventilhome .ventilhome__section.ventilhome__hse:nth-child(even) {
  background: #fff;
  border-bottom: 1px solid var(--vh-color-border-soft);
}

.ventilhome .ventilhome__hse-head {
  margin-bottom: 0.25rem;
}

.ventilhome .ventilhome__hse-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.5rem;
}

.ventilhome .ventilhome__hse-line {
  width: 36px;
  height: 3px;
  flex-shrink: 0;
  border-radius: 2px;
  background: var(--vh-color-accent-bright);
}

.ventilhome .ventilhome__hse-eyebrow-text {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  font-weight: 700;
  color: #2a7fb0;
}

.ventilhome .ventilhome__hse-eyebrow-text p {
  margin: 0;
}

.ventilhome .ventilhome__hse-main-title {
  margin: 0;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.5rem, 2.4vw, 1.75rem);
  line-height: 1.2;
  color: var(--vh-color-text);
}

.ventilhome .ventilhome__hse-main-title h1,
.ventilhome .ventilhome__hse-main-title h2,
.ventilhome .ventilhome__hse-main-title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: 600;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__hse-row {
  display: grid;
  grid-template-columns: minmax(0, 0.62fr) minmax(0, 0.38fr);
  gap: clamp(1.75rem, 4vw, 3.5rem);
  align-items: start;
  margin-top: 2rem;
}

.ventilhome .ventilhome__hse-subtitle {
  margin: 0 0 0.75rem;
  font-family: inherit;
  font-size: clamp(1rem, 1.35vw, 1.125rem);
  font-weight: 700;
  line-height: 1.35;
  color: var(--vh-color-primary-strong);
}

.ventilhome .ventilhome__hse-subtitle h3,
.ventilhome .ventilhome__hse-subtitle p {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__hse-body {
  font-size: 0.875rem;
  line-height: 1.72;
  color: var(--vh-color-muted);
}

.ventilhome .ventilhome__hse-body p {
  margin: 0 0 0.9rem;
}

.ventilhome .ventilhome__hse-body p:last-child {
  margin-bottom: 0;
}

.ventilhome .ventilhome__hse-body strong {
  color: var(--vh-color-text);
  font-weight: 600;
}

.ventilhome .ventilhome__hse-note {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  background: #e8f2fb;
  border-left: 3px solid var(--vh-color-accent-bright);
  border-radius: 0 10px 10px 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: #0f2d4a;
}

.ventilhome .ventilhome__hse-note p {
  margin: 0;
}

.ventilhome .ventilhome__hse-actions {
  margin-top: 1.5rem;
}

.ventilhome .ventilhome__hse-cta {
  display: inline-block;
  padding: 0.625rem 1.25rem;
  border-radius: 10px;
  font-size: 0.8125rem;
  font-weight: 600;
  background: var(--vh-color-accent-bright);
  color: #fff !important;
  border: none;
  text-decoration: none;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
}

.ventilhome .ventilhome__hse-cta:hover,
.ventilhome .ventilhome__hse-cta:focus {
  background: #1856a3;
  color: #fff !important;
}

.ventilhome .ventilhome__hse-sidebar {
  background: #e8f4fc;
  border-radius: var(--vh-radius);
  padding: 1.65rem 1.5rem;
  border: 1px solid rgba(30, 107, 189, 0.12);
}

.ventilhome .ventilhome__hse-sidebar-title {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--vh-color-primary-strong);
  font-family: inherit;
}

.ventilhome .ventilhome__hse-sidebar-list ul {
  margin: 0;
  padding-left: 1.15rem;
}

.ventilhome .ventilhome__hse-sidebar-list li {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--vh-color-muted);
  margin-bottom: 0.4rem;
}

.ventilhome .ventilhome__hse-sidebar-list li strong {
  color: var(--vh-color-text);
  font-weight: 600;
}

.ventilhome .ventilhome__hse-sidebar-block--adv {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(204, 218, 236, 0.9);
}

.ventilhome .ventilhome__panel {
  height: 100%;
  border-radius: var(--vh-radius);
  background: #fff;
  box-shadow: var(--vh-shadow);
  padding: 1.25rem;
}

.ventilhome .ventilhome__panel h3 {
  margin: 0 0 0.75rem;
  font-size: 1.05rem;
  color: var(--vh-color-primary);
}

.ventilhome .ventilhome__list {
  margin: 0 0 1rem 1rem;
  padding: 0;
}

.ventilhome .ventilhome__list li {
  margin-bottom: 0.45rem;
}

/* ─── Expertises (maquette exp-grid + exp-card, section-bg + cartes blanches) ─── */
.ventilhome .ventilhome__section.ventilhome__expertises {
  background: var(--vh-color-bg-soft);
  border-bottom: 1px solid var(--vh-color-border-soft);
}

.ventilhome .ventilhome__exp-head {
  margin-bottom: 0;
}

.ventilhome .ventilhome__exp-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.5rem;
}

.ventilhome .ventilhome__exp-line {
  width: 36px;
  height: 3px;
  flex-shrink: 0;
  border-radius: 2px;
  background: var(--vh-color-accent-bright);
}

.ventilhome .ventilhome__exp-eyebrow-text {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  font-weight: 700;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  color: #2a7fb0;
}

.ventilhome .ventilhome__exp-eyebrow-text p {
  margin: 0;
}

.ventilhome .ventilhome__exp-main-title {
  margin: 0 0 0.65rem;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.45rem, 2.2vw, 1.85rem);
  line-height: 1.2;
  color: #0f2d4a;
}

.ventilhome .ventilhome__exp-main-title h1,
.ventilhome .ventilhome__exp-main-title h2,
.ventilhome .ventilhome__exp-main-title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: 600;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__exp-sub {
  margin: 0 0 1.75rem;
  max-width: 720px;
  font-size: 0.9375rem;
  line-height: 1.55;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  color: #4a6278;
}

.ventilhome .ventilhome__exp-sub p {
  margin: 0;
}

.ventilhome .ventilhome__exp-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 0;
}

.ventilhome .ventilhome__exp-card {
  position: relative;
  height: 100%;
  background: #fff;
  border: 1px solid #ccdaec;
  border-radius: var(--vh-radius);
  padding: 1.75rem 1.5rem 1.5rem;
  cursor: default;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.ventilhome .ventilhome__exp-card:hover {
  border-color: var(--vh-color-accent-bright);
  box-shadow: 0 4px 16px rgba(15, 45, 74, 0.08);
}

.ventilhome .ventilhome__exp-card--featured {
  border-color: var(--vh-color-accent-bright);
  box-shadow: 0 0 0 1px rgba(30, 107, 189, 0.25);
}

.ventilhome .ventilhome__exp-tag {
  position: absolute;
  top: 14px;
  right: 14px;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  line-height: 1.3;
}

.ventilhome .ventilhome__exp-tag--norm {
  background: #e8f2fb;
  color: #1e6bbd;
}

.ventilhome .ventilhome__exp-tag--fab {
  background: #d8f0e4;
  color: #1e6e3c;
  text-transform: none;
  letter-spacing: 0.02em;
  font-weight: 600;
  font-size: 0.65rem;
}

.ventilhome .ventilhome__exp-tag--custom {
  background: #e8f2fb;
  color: #1e6bbd;
}

.ventilhome .ventilhome__exp-icon {
  margin-bottom: 1rem;
}

.ventilhome .ventilhome__exp-icon-inner {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ventilhome .ventilhome__exp-card-title {
  margin: 0 0 0.65rem;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--vh-maquette-text);
}

.ventilhome .ventilhome__exp-card-text {
  margin: 0 0 0.9rem;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 13px;
  color: #4a6278;
  line-height: 1.65;
}

.ventilhome .ventilhome__exp-link {
  display: inline-block;
  font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--vh-color-accent-bright);
  text-decoration: none;
  transition: color 0.15s ease;
}

.ventilhome .ventilhome__exp-link:hover,
.ventilhome .ventilhome__exp-link:focus {
  color: #1856a3;
  text-decoration: underline;
}

.ventilhome .ventilhome__exp-link--static {
  cursor: default;
  pointer-events: none;
}

@media (max-width: 991.98px) {
  .ventilhome .ventilhome__section {
    padding: 2.4rem 0;
  }

  /* Après le padding général des sections, sinon le bas du hero repasse à 2.4rem (trou blanc). */
  .ventilhome .ventilhome__hero {
    padding-bottom: 0;
  }

  .ventilhome .ventilhome__hero + .ventilhome__gamme {
    padding-top: 0;
  }

  .ventilhome .ventilhome__hero-layout {
    min-height: 0;
    grid-template-columns: 1fr;
  }

  .ventilhome .ventilhome__hero-col {
    max-width: 100%;
  }

  .ventilhome .ventilhome__hero-media img {
    min-height: 280px;
  }

  .ventilhome .ventilhome__hero-panel {
    padding: 1.65rem;
  }

  .ventilhome .ventilhome__des-row {
    grid-template-columns: 1fr;
    margin-top: 1.25rem;
    gap: 1.35rem;
  }

  .ventilhome .ventilhome__des-figure {
    min-height: 200px;
    max-height: 340px;
  }

  .ventilhome .ventilhome__gamme-head {
    margin-bottom: 1rem;
  }

  .ventilhome .ventilhome__hse-row {
    grid-template-columns: 1fr;
    margin-top: 1.25rem;
    gap: 1.35rem;
  }

  .ventilhome .ventilhome__exp-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 1.5rem;
    gap: 1rem;
  }
}

@media (max-width: 575.98px) {
  .ventilhome .ventilhome__panel {
    padding: 1rem;
  }

  .ventilhome .ventilhome__exp-grid {
    grid-template-columns: 1fr;
  }

  .ventilhome .ventilhome__exp-card {
    padding: 1.35rem 1.1rem 1.1rem;
  }
}

/* Priorité sur le thème PrestaShop (chargé après ce fichier) + collage garanti */
#ventilhome.ventilhome > .ventilhome__hero.ventilhome__section {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

#ventilhome.ventilhome > .ventilhome__hero.ventilhome__section + .ventilhome__gamme.ventilhome__section {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

#ventilhome .ventilhome__gamme .ventilhome__gamme-head {
  padding-top: 2rem !important;
}

#ventilhome .ventilhome__section.ventilhome__gamme {
  background: #fff !important;
}

#ventilhome .ventilhome__section.ventilhome__expertises {
  background: var(--vh-color-bg-soft) !important;
}

#ventilhome .ventilhome__section.ventilhome__clients,
#ventilhome .ventilhome__section.ventilhome__contact-band {
  background: #0e4166 !important;
}

/* Section clients/CTA en pleine largeur viewport (fond bleu bord a bord) */
#ventilhome .ventilhome__section.ventilhome__clients,
#ventilhome .ventilhome__section.ventilhome__contact-band {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Evite la capitalisation automatique imposee par certains themes (y compris sur p, span, etc.) */
#ventilhome .ventilhome__title,
#ventilhome .ventilhome__title *,
#ventilhome .ventilhome__gamme-subtitle,
#ventilhome .ventilhome__gamme-subtitle *,
#ventilhome .ventilhome__des-main-title,
#ventilhome .ventilhome__des-main-title *,
#ventilhome .ventilhome__des-subtitle,
#ventilhome .ventilhome__des-subtitle *,
#ventilhome .ventilhome__hse-main-title,
#ventilhome .ventilhome__hse-main-title *,
#ventilhome .ventilhome__hse-subtitle,
#ventilhome .ventilhome__hse-subtitle *,
#ventilhome .ventilhome__exp-main-title,
#ventilhome .ventilhome__exp-main-title *,
#ventilhome .ventilhome__exp-sub,
#ventilhome .ventilhome__exp-sub *,
#ventilhome .ventilhome__exp-card-title,
#ventilhome .ventilhome__exp-card-title *,
#ventilhome .ventilhome__clients-title,
#ventilhome .ventilhome__clients-title *,
#ventilhome .ventilhome__clients-subtitle,
#ventilhome .ventilhome__clients-subtitle *,
#ventilhome .ventilhome__contact-band-title,
#ventilhome .ventilhome__contact-band-title * {
  text-transform: none !important;
}

/* ─── Nos clients + bande contact (fond identique bande CTA) ─── */
.ventilhome .ventilhome__section.ventilhome__clients {
  background: #0e4166;
  color: #fff;
  border-bottom: none;
}

.ventilhome .ventilhome__clients-head {
  margin-bottom: 1.4rem;
}

.ventilhome .ventilhome__clients-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.5rem;
}

.ventilhome .ventilhome__clients-line {
  width: 34px;
  height: 2px;
  border-radius: 2px;
  background: rgba(126, 198, 245, 0.6);
}

.ventilhome .ventilhome__clients-label {
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-size: 0.72rem;
  font-weight: 700;
  color: #7ec6f5;
}

.ventilhome .ventilhome__clients-label p {
  margin: 0;
}

.ventilhome .ventilhome__clients-title {
  margin: 0 0 0.5rem;
  color: #fff;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.55rem, 2.35vw, 2rem);
  line-height: 1.2;
}

.ventilhome .ventilhome__clients-title h1,
.ventilhome .ventilhome__clients-title h2,
.ventilhome .ventilhome__clients-title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__clients-subtitle {
  margin: 0;
  max-width: 760px;
  color: rgba(214, 233, 245, 0.92);
  font-size: 0.95rem;
  line-height: 1.6;
}

.ventilhome .ventilhome__clients-subtitle p {
  margin: 0;
}

.ventilhome .ventilhome__clients-grid {
  margin-top: 1.35rem;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
}

.ventilhome .ventilhome__clients-item {
  padding: 1.25rem 1rem 1rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(126, 198, 245, 0.18);
  text-align: center;
}

.ventilhome .ventilhome__clients-icon {
  display: block;
  margin: 0 0 0.7rem;
  font-size: 1.35rem;
  line-height: 1;
}

.ventilhome .ventilhome__clients-name {
  margin: 0 0 0.45rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
}

.ventilhome .ventilhome__clients-detail {
  margin: 0;
  color: rgba(190, 214, 230, 0.92);
  font-size: 0.8125rem;
  line-height: 1.55;
}

.ventilhome .ventilhome__section.ventilhome__contact-band {
  background: #0e4166;
  color: #fff;
  padding-top: 1.65rem;
  padding-bottom: 1.65rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.ventilhome .ventilhome__contact-band-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.ventilhome .ventilhome__contact-band-title {
  margin: 0 0 0.4rem;
  color: #fff;
  font-family: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  font-size: clamp(1.35rem, 2.1vw, 1.85rem);
  line-height: 1.2;
}

.ventilhome .ventilhome__contact-band-title h1,
.ventilhome .ventilhome__contact-band-title h2,
.ventilhome .ventilhome__contact-band-title h3 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

.ventilhome .ventilhome__contact-band-text {
  margin: 0;
  color: rgba(224, 239, 250, 0.9);
  font-size: 0.95rem;
}

.ventilhome .ventilhome__contact-band-text p {
  margin: 0;
}

.ventilhome .ventilhome__contact-btn--static {
  cursor: default;
  pointer-events: none;
  opacity: 0.85;
}

.ventilhome .ventilhome__contact-band-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.65rem;
  margin-right: clamp(0.5rem, 1.5vw, 1.5rem);
}

.ventilhome .ventilhome__contact-phone {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.ventilhome .ventilhome__contact-phone-label {
  display: block;
  margin-bottom: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.68rem;
  color: rgba(196, 225, 245, 0.9);
}

.ventilhome .ventilhome__contact-phone-number {
  color: #fff;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.ventilhome .ventilhome__contact-btn {
  display: inline-block;
  border-radius: 10px;
  padding: 0.625rem 1rem;
  background: #1e6bbd;
  color: #fff !important;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 600;
  transition: background 0.2s ease;
}

.ventilhome .ventilhome__contact-btn:hover,
.ventilhome .ventilhome__contact-btn:focus {
  background: #1856a3;
  color: #fff !important;
}

@media (max-width: 1199.98px) {
  .ventilhome .ventilhome__clients-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .ventilhome .ventilhome__clients-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ventilhome .ventilhome__contact-band-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .ventilhome .ventilhome__contact-band-right,
  .ventilhome .ventilhome__contact-phone {
    align-items: flex-start;
  }

  .ventilhome .ventilhome__contact-band-right {
    margin-right: 0;
  }
}

@media (max-width: 575.98px) {
  .ventilhome .ventilhome__clients-grid {
    grid-template-columns: 1fr;
  }
}


.header-top {
  background: #ffffff !important;
}

.header-top .container,
.header-top .row,
.header-top .col {
  background: transparent !important;
}