u
  background-color: var(--color-bg) !important;
  color: var(--color-white) !important;
  font-family: var(--font-body) !important;
}

/* ===== MARGE LATÉRALE GLOBALE =====
   Crée un espace harmonieux de chaque côté du contenu.
   On ne touche PAS au header ni au hero (plein écran voulu). */
.vehicles-section,
.features-bar,
.cta-section,
.site-footer,
.post-829 .page-content,
body.archive .site-main,
body.post-type-archive-voiture .site-main {
  padding-left: clamp(20px, 6vw, 100px) !important;
  padding-right: clamp(20px, 6vw, 100px) !important;
}


/* ===== HEADER ===== */
#site-header, header.site-header, .site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  z-index: 9999 !important;
  background: transparent !important;
  backdrop-filter: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  transition: top 0.8s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
#site-header.header-hidden,
header.site-header.header-hidden,
.site-header.header-hidden {
  top: -200px !important;
}

/* Header : on NE force PAS le layout (Elementor le gère nativement).
   On règle uniquement la taille du logo. */
.site-header .elementor-widget-image img,
.site-header img.custom-logo {
  max-width: 250px !important;   
  height: auto !important;
}
<div class="swiss-badge">
  <span class="swiss-flag"></span>
  <span class="swiss-text">Entreprise Suisse</span>
</div>

/* ===== MASQUER BOUTON ESTIMATION & TITRES ===== */
.btn-estimation { display: none !important; }
.page-title, .entry-title, .page-header, h1.page-title,
.elementor-page-title, .archive-header,
.page-header.archive-header { display: none !important; }

/* ===== NAV ===== */
nav a, .elementor-nav-menu a {
  color: var(--color-white) !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}
nav a:hover, .elementor-nav-menu a:hover { color: var(--color-gold) !important; }

/* ===== HERO ===== */
.hero-section {
  min-height: 100vh !important;
  background-image: linear-gradient(to right, rgba(10,10,10,0.85) 45%, rgba(10,10,10,0.3) 100%),
                    url('https://duocars.ch/wp-content/uploads/2026/06/ChatGPT-Image-10-juin-2026-08_05_20.png') !important;
  background-size: cover !important;
  background-position: left center !important;
  background-attachment: fixed !important;
  display: flex !important;
  align-items: center !important;
  padding: 120px 80px 80px !important;
  position: relative !important;
}
.hero-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.85) 100%);
  pointer-events: none;
}
.hero-title {
  font-family: var(--font-display) !important;
  font-size: clamp(2.5rem, 5vw, 4.5rem) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
  color: var(--color-gold) !important;
  margin: 0 0 20px !important;
}
.hero-title span { color: var(--color-white) !important; }
.hero-subtitle {
  font-size: 1rem !important;
  color: var(--color-gray) !important;
  margin: 0 0 40px !important;
  max-width: 450px !important;
  line-height: 1.7 !important;
}
.hero-buttons {
  display: flex !important;
  gap: 15px !important;
  flex-wrap: wrap !important;
}

/* ===== BOUTONS ===== */
.btn-primary-gold {
  background: var(--color-gold) !important;
  color: #0a0a0a !important;
  padding: 14px 28px !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  border: none !important;
  display: inline-block !important;
  transition: var(--transition) !important;
}
.btn-primary-gold:hover {
  background: var(--color-gold-light) !important;
  transform: translateY(-2px) !important;
  color: #0a0a0a !important;
}
.btn-outline-white {
  background: transparent !important;
  color: var(--color-white) !important;
  border: 1px solid rgba(255,255,255,0.4) !important;
  padding: 14px 28px !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  display: inline-block !important;
  transition: var(--transition) !important;
}
.btn-outline-white:hover {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
}

/* ===== BANDEAU ATOUTS ===== */
.features-bar {
  background: #111111 !important;
  border-top: 1px solid var(--color-border) !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: 30px 80px !important;
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}
.feature-item {
  display: flex !important;
  align-items: center !important;
  gap: 15px !important;
}
.feature-item p {
  font-size: 0.7rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--color-gray) !important;
  margin: 0 !important;
  line-height: 1.5 !important;
}

/* ===== LABELS & TITRES ===== */
.section-label {
  font-size: 0.7rem !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--color-gold) !important;
  margin-bottom: 20px !important;
  display: block !important;
}
.section-title {
  font-family: var(--font-display) !important;
  font-size: clamp(1.8rem, 3vw, 3rem) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  line-height: 1.15 !important;
  margin: 0 0 30px !important;
  color: var(--color-white) !important;
}

/* ===== À PROPOS (page d'accueil) =====
   Même marge latérale que les autres sections pour l'alignement.
   Mise en page : image + texte côte à côte. */
.about-section {
  background: #0a0a0a !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 60px !important;
  align-items: center !important;
  padding: 100px clamp(20px, 6vw, 100px) !important;
}
.about-image {
  background: url('https://duocars.ch/wp-content/uploads/2026/06/ChatGPT-Image-10-juin-2026-08_05_20.png') center/cover no-repeat !important;
  min-height: 420px !important;
  filter: brightness(0.85) !important;
}
.about-content {
  display: flex !important;
  flex-direction: column !important;
}
.about-content p {
  color: var(--color-gray) !important;
  font-size: 0.92rem !important;
  line-height: 1.9 !important;
  margin: 0 0 18px !important;
}

/* ===== VÉHICULES (page d'accueil) ===== */
.vehicles-section { padding: 100px clamp(20px, 6vw, 100px) !important; background: #0a0a0a !important; }
.section-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
  margin-bottom: 40px !important;
}
.vehicle-card {
  background: #111 !important;
  overflow: hidden !important;
  transition: var(--transition) !important;
}
.vehicle-card:hover { transform: translateY(-4px) !important; }
.vehicle-card img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
}
.vehicle-card-body { padding: 20px !important; }
.vehicle-name {
  font-family: var(--font-display) !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  margin-bottom: 6px !important;
  color: var(--color-white) !important;
}
.vehicle-meta {
  font-size: 0.72rem !important;
  color: var(--color-gray) !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  margin-bottom: 12px !important;
}
.vehicle-price {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--color-gold) !important;
}

/* ===== SECTION SERVICES (page d'accueil) =====
   Cartes damier : photo d'un côté, texte de l'autre.
   Icônes dorées, polices du site, alternance gauche/droite. */
.services-section {
  background: #0a0a0a !important;
  padding: 100px clamp(20px, 6vw, 100px) !important;
}
.services-section > .section-label { margin-bottom: 18px !important; }
.services-section > .section-title { margin-bottom: 50px !important; }

.services-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}

.service-card {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  align-items: stretch !important;
  background: #111 !important;
  border: 0.5px solid rgba(201, 168, 76, 0.25) !important;
  overflow: hidden !important;
  min-height: 280px !important;
  transition: var(--transition) !important;
}
.service-card:hover {
  border-color: rgba(201, 168, 76, 0.5) !important;
  transform: translateY(-3px) !important;
}

/* L'image de la carte */
.service-card-image {
  display: block !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  min-height: 280px !important;
}

/* Alternance damier : 1 photo à gauche, 2 photo à droite, 3 gauche, 4 droite */
.service-card:nth-child(even) .service-card-image { order: 2 !important; }
.service-card:nth-child(even) .service-card-content { order: 1 !important; }

.service-card-content {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 14px !important;
  padding: 44px 48px !important;
}
.service-icon {
  color: var(--color-gold) !important;
}
.service-icon svg {
  width: 32px !important;
  height: 32px !important;
}
.service-card-content h3 {
  font-family: var(--font-display) !important;
  font-size: 1.6rem !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  margin: 0 !important;
}
.service-card-content p {
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  color: var(--color-gray) !important;
  line-height: 1.8 !important;
  margin: 0 !important;
}

/* ===== PAGE ARCHIVE VÉHICULES ===== */
/* (consolidé : une seule valeur de padding-top = 160px) */
body.post-type-archive-voiture .site-main,
body.archive .site-main {
  padding-top: 160px !important;
  padding-left: 60px !important;
  padding-right: 60px !important;
}
main.vehicles-archive {
  padding-top: 160px !important;
  padding-left: 60px !important;
  padding-right: 60px !important;
}
.vehicles-grid,
div.vehicles-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  padding-top: 30px !important;
}

/* ===== PAGE SERVICES ===== */
/* Design d'origine restauré :
   - hauteur auto (le contenu respire, pas de coupe)
   - images cachées partout SAUF première et dernière colonne */
.post-829 main,
.post-829 .page-content,
.page-id-829 main {
  padding-top: 120px !important;
}

.post-829 .page-content section[style*="grid"] {
  overflow: hidden !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  align-items: stretch !important;
  height: auto !important;
}

.post-829 .page-content section[style*="grid"] > div {
  padding: 50px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  overflow: hidden !important;
  height: auto !important;
}

/* On masque les icônes-images des colonnes du milieu */
.post-829 .page-content section[style*="grid"] > div img {
  display: none !important;
}

/* Sauf la première et la dernière colonne : grandes images d'illustration */
.post-829 .page-content section[style*="grid"] > div:first-child img,
.post-829 .page-content section[style*="grid"] > div:last-child img {
  display: block !important;
  width: 100% !important;
  height: 500px !important;
  object-fit: cover !important;
  object-position: center !important;
}

/* ===== CTA ===== */
.cta-section {
  padding: 100px 80px !important;
  background: linear-gradient(to right, rgba(10,10,10,0.95) 50%, rgba(10,10,10,0.7)) !important;
}
.cta-section h2 {
  font-family: var(--font-display) !important;
  font-size: clamp(2rem, 4vw, 3.5rem) !important;
  text-transform: uppercase !important;
  margin: 0 0 20px !important;
  color: var(--color-white) !important;
}
.cta-section h2 span { color: var(--color-gold) !important; }
.cta-section p {
  color: var(--color-gray) !important;
  max-width: 500px !important;
  margin: 0 0 35px !important;
  line-height: 1.8 !important;
}

/* ===== FOOTER ===== */
.site-footer {
  background: #080808 !important;
  border-top: 1px solid var(--color-border) !important;
  padding: 60px 80px 30px !important;
  display: grid !important;
  grid-template-columns: 2fr 1fr 1fr 1fr !important;
  gap: 40px !important;
}
.footer-logo {
  font-family: var(--font-display) !important;
  font-size: 1.6rem !important;
  color: var(--color-white) !important;
  margin-bottom: 15px !important;
}
.footer-logo span { color: var(--color-gold) !important; font-weight: 700 !important; }
.footer-desc {
  font-size: 0.82rem !important;
  color: var(--color-gray) !important;
  line-height: 1.7 !important;
}
.footer-heading {
  font-size: 0.7rem !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: var(--color-white) !important;
  margin: 0 0 20px !important;
}
.footer-links { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.footer-links li { margin-bottom: 10px !important; }
.footer-links a {
  font-size: 0.82rem !important;
  color: var(--color-gray) !important;
  transition: var(--transition) !important;
}
.footer-links a:hover { color: var(--color-gold) !important; }

/* Tous les liens du footer (y compris téléphone et email) en gris,
   doré au survol — fini le rouge par défaut */
.site-footer a,
.site-footer a:link,
.site-footer a:visited {
  color: var(--color-gray) !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
}
.site-footer a:hover {
  color: var(--color-gold) !important;
}
.footer-bottom {
  border-top: 1px solid var(--color-border) !important;
  padding-top: 25px !important;
  margin-top: 40px !important;
  display: flex !important;
  justify-content: space-between !important;
  font-size: 0.72rem !important;
  color: var(--color-gray) !important;
  grid-column: 1 / -1 !important;
}

/* ===== FICHE VÉHICULE ===== */
.vehicle-card-single {
  background: #0f0f0f;
  border: 0.5px solid rgba(201,168,76,0.25);
  font-family: var(--font-body);
  max-width: 800px;
  margin: 0 auto;
}
.vehicle-card-single .vc-header {
  background: #111;
  border-bottom: 1px solid rgba(201,168,76,0.2);
  padding: 28px 32px 24px;
}
.vehicle-card-single .vc-label {
  font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--color-gold); margin-bottom: 10px; display: block;
}
.vehicle-card-single .vc-title {
  font-family: var(--font-display); font-size: 30px; font-weight: 700;
  color: var(--color-white); text-transform: uppercase; line-height: 1.1; margin: 0 0 6px;
}
.vehicle-card-single .vc-subtitle {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: #888; margin: 0;
}
.vehicle-card-single .vc-divider { width: 40px; height: 1px; background: var(--color-gold); margin: 14px 0; }
.vehicle-card-single .vc-price-row {
  display: flex; align-items: center; justify-content: space-between; margin-top: 20px;
}
.vehicle-card-single .vc-price {
  font-family: var(--font-display); font-size: 34px; font-weight: 700; color: var(--color-gold);
}
.vehicle-card-single .vc-badge {
  background: rgba(201,168,76,0.1); border: 0.5px solid rgba(201,168,76,0.4);
  color: var(--color-gold); font-size: 9px; letter-spacing: 0.25em;
  text-transform: uppercase; padding: 6px 14px;
}
.vehicle-card-single .vc-specs {
  display: grid; grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.vehicle-card-single .vc-spec {
  padding: 16px 20px;
  border-right: 0.5px solid rgba(255,255,255,0.06);
  border-bottom: 0.5px solid rgba(255,255,255,0.06);
}
.vehicle-card-single .vc-spec:nth-child(even) { border-right: none; }
.vehicle-card-single .vc-spec-label {
  font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: #555; margin-bottom: 5px;
}
.vehicle-card-single .vc-spec-value { font-size: 13px; font-weight: 500; color: #fff; }
.vehicle-card-single .vc-spec-value span { color: var(--color-gold); }
.vehicle-card-single .vc-equip {
  padding: 24px 32px; border-bottom: 1px solid rgba(255,255,255,0.06);
}
.vehicle-card-single .vc-equip-title {
  font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 16px;
}
.vehicle-card-single .vc-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.vehicle-card-single .vc-tag {
  background: rgba(255,255,255,0.04); border: 0.5px solid rgba(255,255,255,0.1);
  color: #ccc; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding: 6px 12px;
}
.vehicle-card-single .vc-desc {
  padding: 24px 32px; border-bottom: 1px solid rgba(255,255,255,0.06);
}
.vehicle-card-single .vc-desc-title {
  font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 12px;
}
.vehicle-card-single .vc-desc p { font-size: 13px; color: #888; line-height: 1.8; margin: 0; }
.vehicle-card-single .vc-footer {
  padding: 20px 32px; display: flex; align-items: center; justify-content: space-between;
}
.vehicle-card-single .vc-ref { font-size: 9px; letter-spacing: 0.2em; color: #444; text-transform: uppercase; }
.vehicle-card-single .vc-cta {
  background: var(--color-gold); color: #0a0a0a; font-size: 10px; letter-spacing: 0.25em;
  text-transform: uppercase; font-weight: 700; padding: 12px 24px; border: none;
  cursor: pointer; font-family: var(--font-body); text-decoration: none; display: inline-block;
}
.vehicle-card-single .vc-cta:hover { background: var(--color-gold-light); color: #0a0a0a; }

/* ===== CONTACT FORM 7 ===== */
.cf7-duo .wpcf7-form-control-wrap { display: block; margin-bottom: 12px; }
.cf7-duo input[type="text"],
.cf7-duo input[type="email"],
.cf7-duo input[type="tel"],
.cf7-duo textarea {
  width: 100% !important; background: #111 !important;
  border: 0.5px solid rgba(201,168,76,0.3) !important;
  color: var(--color-white) !important; padding: 14px 18px !important;
  font-family: var(--font-body) !important; font-size: 12px !important;
  letter-spacing: 0.1em !important; outline: none !important; border-radius: 0 !important;
}
.cf7-duo input:focus, .cf7-duo textarea:focus { border-color: var(--color-gold) !important; }
.cf7-duo textarea { min-height: 120px !important; resize: vertical !important; }
.cf7-duo input[type="submit"] {
  background: var(--color-gold) !important; color: #0a0a0a !important; border: none !important;
  padding: 14px 32px !important; font-family: var(--font-body) !important; font-size: 11px !important;
  letter-spacing: 0.25em !important; text-transform: uppercase !important; font-weight: 700 !important;
  cursor: pointer !important; width: 100% !important; margin-top: 8px !important;
}
.cf7-duo input[type="submit"]:hover { background: var(--color-gold-light) !important; }
.cf7-duo input::placeholder, .cf7-duo textarea::placeholder { color: rgba(255,255,255,0.4) !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .vehicles-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .features-bar { grid-template-columns: repeat(2, 1fr) !important; padding: 30px 40px !important; }
  .site-footer { grid-template-columns: 1fr 1fr !important; padding: 40px !important; }

  /* Header : logo plus petit sur tablette/mobile (layout géré par Elementor) */
  .site-header .elementor-widget-image img,
  .site-header img.custom-logo {
    max-width: 130px !important;
  }
}

@media (max-width: 768px) {
  .hero-section { padding: 100px 30px 60px !important; }
  .about-section { grid-template-columns: 1fr !important; }
  .about-image { height: 350px !important; }
  .about-content { padding: 50px 30px !important; }
  .vehicles-grid, .features-bar { grid-template-columns: 1fr !important; }
  .service-card { grid-template-columns: 1fr !important; min-height:0 !important; }
  .service-card-image { min-height: 200px !important; }
  .service-card:nth-child(even) .service-card-image { order: 0 !important; }
  .service-card:nth-child(even) .service-card-content { order: 0 !important; }
  .service-card-content { padding: 28px 24px !important; gap: 14px !important; }
  .vehicles-section, .services-section, .cta-section { padding: 50px 30px !important; }
  .section-header { flex-direction: column !important; align-items: flex-start !important; gap: 20px !important; }
  .site-footer { grid-template-columns: 1fr !important; padding: 40px 30px !important; }
  body.post-type-archive-voiture .site-main,
  body.archive .site-main { padding: 100px 20px 40px !important; }
  .vehicles-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 600px) {
  .vehicle-card-single .vc-specs { grid-template-columns: 1fr; }
  .vehicle-card-single .vc-spec { border-right: none; }
  .vehicle-card-single .vc-header,
  .vehicle-card-single .vc-equip,
  .vehicle-card-single .vc-desc,
  .vehicle-card-single .vc-footer { padding: 20px; }
  .vehicle-card-single .vc-price { font-size: 26px; }
}

/* ===== AÉRATION DU FORMULAIRE CONTACT ===== */

/* Espace entre chaque champ */
.wpcf7-form p {
    margin-bottom: 28px;
}

/* Espace entre le label et son champ */
.wpcf7-form label {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    margin-bottom: 0;
    color: var(--color-white);
}

/* Un peu d'air sous le texte du label, avant le champ */
.wpcf7-form label br {
    display: block;
    content: "";
    margin-top: 8px;
}

/* Hauteur de la zone message plus raisonnable */
.wpcf7-form textarea {
    height: 120px;
}

/* Padding interne des champs un poil plus confortable */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea,
.wpcf7-form select {
    padding: 14px 18px;
    margin-bottom: 0;
}

/* Espace au-dessus du bouton d'envoi */
.wpcf7-form input[type="submit"] {
    margin-top: 10px;
    padding: 16px 36px;
}

/* ===== PAGE CONTACT ===== */
.contact-wrapper {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 80px !important;
  align-items: start !important;
  padding: 160px clamp(20px, 6vw, 100px) 100px !important;
}
.contact-label {
  font-size: 0.7rem !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--color-gold) !important;
  margin: 0 0 8px !important;
}
@media (max-width: 768px) {
  .contact-wrapper {
    grid-template-columns: 1fr !important;
    gap: 50px !important;
    padding: 120px 30px 60px !important;
  }
}

/* ===== BADGE SUISSE (hero) ===== */
.swiss-badge {
  position: absolute !important;
  top: 110px !important;
  right: clamp(20px, 6vw, 80px) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  z-index: 10 !important;
  background: rgba(10,10,10,0.45) !important;
  backdrop-filter: blur(6px) !important;
  border: 0.5px solid rgba(255,255,255,0.15) !important;
  padding: 8px 14px !important;
}
.swiss-flag {
  width: 20px !important;
  height: 20px !important;
  background: #d52b1e !important;
  position: relative !important;
  flex-shrink: 0 !important;
}
.swiss-flag::before,
.swiss-flag::after {
  content: '' !important;
  position: absolute !important;
  background: #fff !important;
}
.swiss-flag::before {
  width: 12px !important; height: 4px !important;
  top: 8px !important; left: 4px !important;
}
.swiss-flag::after {
  width: 4px !important; height: 12px !important;
  top: 4px !important; left: 8px !important;
}
.swiss-text {
  font-size: 0.62rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--color-white) !important;
  white-space: nowrap !important;
}

/* ===== HERO + BADGE : COHÉRENCE MOBILE ===== */
@media (max-width: 768px) {
  .hero-section {
    background-attachment: scroll !important;   /* fixed casse sur mobile */
    background-position: center right !important; /* garde la voiture cadrée */
  }
  .swiss-badge {
    top: 90px !important;
    right: 20px !important;
    padding: 6px 10px !important;
    gap: 7px !important;
  }
  .swiss-flag { width: 16px !important; height: 16px !important; }
  .swiss-flag::before { width: 10px !important; height: 3px !important; top: 6.5px !important; left: 3px !important; }
  .swiss-flag::after  { width: 3px !important; height: 10px !important; top: 3px !important; left: 6.5px !important; }
  .swiss-text { font-size: 0.55rem !important; letter-spacing: 0.15em !important; }
}

/* ===== BADGE ENTREPRISE SUISSE (hero) ===== */
.swiss-badge {
  position: absolute;
  top: 110px;
  right: clamp(20px, 6vw, 80px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 10;
}
.swiss-flag {
  width: 26px;
  height: 26px;
  background: #d52b1e;
  position: relative;
  border-radius: 3px;
}
.swiss-flag::before,
.swiss-flag::after {
  content: '';
  position: absolute;
  background: #fff;
}
/* barre horizontale de la croix */
.swiss-flag::before {
  width: 15px; height: 5px;
  top: 10.5px; left: 5.5px;
}
/* barre verticale de la croix */
.swiss-flag::after {
  width: 5px; height: 15px;
  top: 5.5px; left: 10.5px;
}
.swiss-text {
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-white);
  white-space: nowrap;
  opacity: 0.85;
}

/* Mobile : badge plus petit et repositionné */
@media (max-width: 768px) {
  .swiss-badge {
    top: 95px;
    right: 20px;
    gap: 6px;
  }
  .swiss-flag { width: 22px; height: 22px; }
  .swiss-flag::before { width: 13px; height: 4px; top: 9px; left: 4.5px; }
  .swiss-flag::after  { width: 4px; height: 13px; top: 4.5px; left: 9px; }
  .swiss-text { font-size: 0.55rem; letter-spacing: 0.15em; }
}

@media (max-width: 781px) {
  .wp-block-cover,
  .wp-block-cover .wp-block-cover__image-background {
    background-position: left center !important;
    object-position: left center !important;
  }
}

body,
html,
.site,
.elementor,
main {
    background-color: #0a0a0a !important;
}