.elementor-3339 .elementor-element.elementor-element-6e0f36a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-3339 .elementor-element.elementor-element-973d3a5{--display:flex;}.elementor-3339 .elementor-element.elementor-element-9234939{--display:flex;}.elementor-3339 .elementor-element.elementor-element-97e5772{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-3339 .elementor-element.elementor-element-f8b77cc{--display:flex;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-3339 .elementor-element.elementor-element-9234939{--content-width:980px;}}/* Start custom CSS *//* ============================================================
   VIAGER MULHOUSE - CSS COMPLET (parties 1 et 2)
   À coller dans : Réglages de la page > Avancé > CSS personnalisé
   ============================================================ */

.ov-mulhouse *, .ov-mulhouse *::before, .ov-mulhouse *::after,
.ov-mulhouse2 *, .ov-mulhouse2 *::before, .ov-mulhouse2 *::after {
  box-sizing: border-box !important;
}

/* ===== VARIABLES ===== */
.ov-mulhouse {
  --bleu: #213c47;
  --bleu-light: #2e5263;
  --bleu-pale: #e6eef1;
  --bleu-tres-pale: #f4f7f8;
  --orange: #ec6052;
  --orange-dark: #d44e41;
  --white: #ffffff;
  --text: #2d2d2d;
  --text-light: #5a6a72;
  --radius: 12px;
  --shadow: 0 4px 24px rgba(33,60,71,0.10);
}
.ov-mulhouse2 {
  --bleu: #213c47;
  --bleu-light: #2e5263;
  --bleu-pale: #e6eef1;
  --bleu-tres-pale: #f4f7f8;
  --orange: #ec6052;
  --orange-dark: #d44e41;
  --text: #2d2d2d;
  --text-light: #5a6a72;
  --radius: 12px;
  --shadow: 0 4px 24px rgba(33,60,71,0.10);
  --shadow-hover: 0 8px 32px rgba(33,60,71,0.16);
}

/* ============================================================
   PARTIE 1 - HERO + BREADCRUMB + INTRO
   ============================================================ */

.ov-mulhouse .hero {
  position: relative !important;
  background: var(--bleu) !important;
  min-height: 560px !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}
.ov-mulhouse .hero__bg {
  position: absolute !important;
  inset: 0 !important;
  background-image: url('https://osez-viager.fr/wp-content/uploads/2026/03/Vendre-et-acheter-en-viager-a-Mulhouse.webp') !important;
  background-size: cover !important;
  background-position: center top !important;
  opacity: 0.55 !important;
}
.ov-mulhouse .hero__overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(100deg, rgba(33,60,71,0.82) 50%, rgba(33,60,71,0.25) 100%) !important;
}
.ov-mulhouse .hero__content {
  position: relative !important;
  z-index: 2 !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 80px 40px !important;
  width: 100% !important;
}
.ov-mulhouse .hero__tag {
  display: inline-block !important;
  background: var(--orange) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  font-family: 'Montserrat', sans-serif !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 6px 14px !important;
  border-radius: 4px !important;
  margin-bottom: 20px !important;
}
.ov-mulhouse .hero__title {
  font-size: clamp(26px, 4vw, 42px) !important;
  font-weight: 800 !important;
  font-family: 'Montserrat', sans-serif !important;
  color: #ffffff !important;
  line-height: 1.2 !important;
  max-width: 620px !important;
  margin-bottom: 20px !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.ov-mulhouse .hero__title em { color: var(--orange) !important; font-style: normal !important; }
.ov-mulhouse .hero__subtitle {
  color: rgba(255,255,255,0.90) !important;
  font-size: 15px !important;
  font-family: 'Montserrat', sans-serif !important;
  max-width: 540px !important;
  font-weight: 500 !important;
  margin-bottom: 0 !important;
}

.ov-mulhouse .breadcrumb {
  background: var(--bleu-tres-pale) !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid #dde6ea !important;
  margin: 0 !important;
}
.ov-mulhouse .breadcrumb__inner {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 40px !important;
  font-size: 12px !important;
  font-family: 'Montserrat', sans-serif !important;
  color: var(--text-light) !important;
}
.ov-mulhouse .breadcrumb__inner a { color: var(--bleu) !important; text-decoration: none !important; font-weight: 600 !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse .breadcrumb__inner a:hover { text-decoration: underline !important; }
.ov-mulhouse .breadcrumb__inner span { margin: 0 8px !important; }

.ov-mulhouse .intro-section { max-width: 1100px !important; margin: 0 auto !important; padding: 48px 40px 40px !important; }
.ov-mulhouse .intro-section p { font-size: 14px !important; font-family: 'Montserrat', sans-serif !important; color: var(--text) !important; line-height: 1.7 !important; margin-bottom: 16px !important; }
.ov-mulhouse .intro-section p:last-child { margin-bottom: 0 !important; }

/* ============================================================
   PARTIE 2 - CONTENU PRINCIPAL
   ============================================================ */

.ov-mulhouse2 .page-wrapper { max-width: 1100px !important; margin: 0 auto !important; padding: 0 40px !important; }
.ov-mulhouse2 .content-grid { display: grid !important; grid-template-columns: 1fr 320px !important; gap: 60px !important; padding: 48px 0 60px !important; align-items: start !important; }

.ov-mulhouse2 .section-title {
  font-size: 22px !important; font-weight: 800 !important; color: var(--bleu) !important;
  margin-top: 0 !important; margin-bottom: 20px !important; padding-bottom: 12px !important;
  border-bottom: 3px solid var(--orange) !important; display: block !important;
  width: fit-content !important; font-family: 'Montserrat', sans-serif !important;
  text-transform: none !important; letter-spacing: normal !important; line-height: 1.3 !important;
}
.ov-mulhouse2 .subsection-title {
  font-size: 16px !important; font-weight: 700 !important; color: var(--bleu) !important;
  margin: 40px 0 14px !important; font-family: 'Montserrat', sans-serif !important;
  text-transform: none !important; letter-spacing: normal !important; line-height: 1.3 !important;
}
.ov-mulhouse2 p { margin-bottom: 16px !important; color: var(--text) !important; font-size: 14px !important; font-family: 'Montserrat', sans-serif !important; line-height: 1.7 !important; }
.ov-mulhouse2 a.link-orange { color: var(--orange) !important; font-weight: 700 !important; text-decoration: none !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 a.link-orange:hover { text-decoration: underline !important; }

.ov-mulhouse2 .section-block { margin: 56px 0 !important; }
.ov-mulhouse2 .section-block:first-child { margin-top: 0 !important; }

/* KEY POINTS */
.ov-mulhouse2 .key-points { display: flex !important; flex-direction: column !important; gap: 12px !important; margin: 24px 0 32px !important; }
.ov-mulhouse2 .key-point { display: flex !important; align-items: flex-start !important; gap: 14px !important; background: var(--bleu-tres-pale) !important; border-radius: var(--radius) !important; padding: 18px 20px !important; border-left: 4px solid var(--orange) !important; }
.ov-mulhouse2 .key-point__icon { flex-shrink: 0 !important; width: 28px !important; height: 28px !important; background: var(--orange) !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #fff !important; font-size: 14px !important; font-weight: 700 !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .key-point__text { font-size: 13px !important; line-height: 1.65 !important; font-family: 'Montserrat', sans-serif !important; color: var(--text) !important; }
.ov-mulhouse2 .key-point__text strong { color: var(--bleu) !important; }

/* MARCHE IMMOBILIER (nouveau) */
.ov-mulhouse2 .marche-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 14px !important; margin: 24px 0 28px !important; }
.ov-mulhouse2 .marche-stat { background: var(--bleu-tres-pale) !important; border-radius: var(--radius) !important; padding: 20px 16px !important; text-align: center !important; border-top: 3px solid var(--bleu) !important; }
.ov-mulhouse2 .marche-stat:nth-child(even) { border-top-color: var(--orange) !important; }
.ov-mulhouse2 .marche-stat__value { font-size: 18px !important; font-weight: 800 !important; color: var(--bleu) !important; font-family: 'Montserrat', sans-serif !important; margin-bottom: 6px !important; line-height: 1.3 !important; }
.ov-mulhouse2 .marche-stat:nth-child(even) .marche-stat__value { color: var(--orange) !important; }
.ov-mulhouse2 .marche-stat__label { font-size: 11px !important; color: var(--text-light) !important; font-family: 'Montserrat', sans-serif !important; line-height: 1.4 !important; }

/* COMMUNES (nouveau) */
.ov-mulhouse2 .communes-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 10px !important; margin: 20px 0 !important; }
.ov-mulhouse2 .commune-tag { background: var(--bleu-tres-pale) !important; border-radius: 8px !important; padding: 10px 14px !important; font-size: 12.5px !important; font-weight: 600 !important; color: var(--bleu) !important; font-family: 'Montserrat', sans-serif !important; text-align: center !important; border-left: 3px solid var(--orange) !important; }

/* TYPE CARDS */
.ov-mulhouse2 .type-card { background: var(--bleu-tres-pale) !important; border-radius: var(--radius) !important; padding: 24px 26px !important; margin: 20px 0 !important; border-left: 4px solid var(--bleu) !important; transition: box-shadow 0.2s !important; }
.ov-mulhouse2 .type-card:hover { box-shadow: var(--shadow) !important; }
.ov-mulhouse2 .type-card:nth-child(even) { border-left-color: var(--orange) !important; }
.ov-mulhouse2 .type-card p { margin-bottom: 12px !important; }
.ov-mulhouse2 .type-card p:last-of-type { margin-bottom: 14px !important; }
.ov-mulhouse2 .type-card .btn-link { display: inline-flex !important; align-items: center !important; gap: 6px !important; font-size: 12px !important; font-weight: 700 !important; font-family: 'Montserrat', sans-serif !important; color: var(--orange) !important; text-decoration: none !important; text-transform: uppercase !important; letter-spacing: 0.04em !important; }
.ov-mulhouse2 .type-card .btn-link:hover { text-decoration: underline !important; }
.ov-mulhouse2 .type-card .btn-link::after { content: '→' !important; }

/* QUARTIER CARDS */
.ov-mulhouse2 .quartiers-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 16px !important; margin: 24px 0 !important; }
.ov-mulhouse2 .quartier-card { background: #fff !important; border-radius: var(--radius) !important; padding: 22px !important; border-top: 4px solid var(--bleu) !important; box-shadow: var(--shadow) !important; transition: transform 0.2s, box-shadow 0.2s !important; }
.ov-mulhouse2 .quartier-card:hover { transform: translateY(-2px) !important; box-shadow: var(--shadow-hover) !important; }
.ov-mulhouse2 .quartier-card:nth-child(2) { border-top-color: var(--orange) !important; }
.ov-mulhouse2 .quartier-card:nth-child(4) { border-top-color: var(--orange) !important; }
.ov-mulhouse2 .quartier-card--full { grid-column: 1 / -1 !important; }
.ov-mulhouse2 .quartier-card__name { font-size: 14px !important; font-weight: 800 !important; color: var(--bleu) !important; margin-bottom: 10px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .quartier-card__points { list-style: none !important; padding: 0 !important; margin: 0 !important; display: flex !important; flex-direction: column !important; gap: 6px !important; }
.ov-mulhouse2 .quartier-card__points li { font-size: 12px !important; line-height: 1.55 !important; padding-left: 16px !important; position: relative !important; color: var(--text) !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .quartier-card__points li::before { content: '·' !important; position: absolute !important; left: 0 !important; font-weight: 700 !important; font-size: 18px !important; line-height: 1 !important; color: var(--orange) !important; }

/* INFO BOX */
.ov-mulhouse2 .info-box { background: var(--bleu-tres-pale) !important; border-radius: var(--radius) !important; padding: 24px 28px !important; margin: 24px 0 !important; border-left: 4px solid var(--bleu) !important; }
.ov-mulhouse2 .info-box--warning { background: #fff8f7 !important; border-left-color: var(--orange) !important; }
.ov-mulhouse2 .info-box__title { font-size: 13px !important; font-weight: 700 !important; color: var(--bleu) !important; margin-bottom: 8px !important; display: flex !important; align-items: center !important; gap: 8px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .info-box p { margin-bottom: 0 !important; font-size: 13px !important; }

/* FAQ */
.ov-mulhouse2 .faq-section { margin: 56px 0 !important; }
.ov-mulhouse2 .faq-list { display: flex !important; flex-direction: column !important; gap: 10px !important; list-style: none !important; padding: 0 !important; }
.ov-mulhouse2 .faq-item { border-radius: var(--radius) !important; border: 1.5px solid #dde6ea !important; overflow: hidden !important; transition: box-shadow 0.2s !important; margin: 0 !important; background: #fff !important; }
.ov-mulhouse2 .faq-item.open { box-shadow: var(--shadow) !important; border-color: var(--bleu) !important; }
.ov-mulhouse2 .faq-question-heading { margin: 0 !important; }
.ov-mulhouse2 .faq-question { width: 100% !important; background: #fff !important; border: none !important; padding: 20px 24px !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 16px !important; cursor: pointer !important; text-align: left !important; font-size: 14px !important; font-weight: 700 !important; color: var(--bleu) !important; font-family: 'Montserrat', sans-serif !important; transition: background 0.15s !important; text-transform: none !important; letter-spacing: normal !important; line-height: 1.4 !important; box-shadow: none !important; outline: none !important; }
.ov-mulhouse2 .faq-question:hover { background: var(--bleu-tres-pale) !important; }
.ov-mulhouse2 .faq-item.open .faq-question { background: var(--bleu) !important; color: #fff !important; }
.ov-mulhouse2 .faq-chevron { flex-shrink: 0 !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; background: var(--bleu-tres-pale) !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: transform 0.3s, background 0.2s !important; min-width: 28px !important; }
.ov-mulhouse2 .faq-item.open .faq-chevron { transform: rotate(180deg) !important; background: rgba(255,255,255,0.2) !important; }
.ov-mulhouse2 .faq-chevron svg { display: block !important; }
.ov-mulhouse2 .faq-item.open .faq-chevron svg path { stroke: #fff !important; }
.ov-mulhouse2 .faq-answer { max-height: 0 !important; overflow: hidden !important; transition: max-height 0.4s ease !important; }
.ov-mulhouse2 .faq-item.open .faq-answer { max-height: none !important; }
.ov-mulhouse2 .faq-answer__inner { padding: 20px 24px !important; font-size: 13px !important; line-height: 1.75 !important; color: var(--text) !important; background: #fff !important; border-top: 1px solid #eef2f4 !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .faq-answer__inner a { color: var(--orange) !important; font-weight: 600 !important; text-decoration: none !important; }
.ov-mulhouse2 .faq-answer__inner a:hover { text-decoration: underline !important; }

/* SIDEBAR */
.ov-mulhouse2 .sidebar { position: sticky !important; top: 24px !important; display: flex !important; flex-direction: column !important; gap: 20px !important; }
.ov-mulhouse2 .sidebar-nav, .ov-mulhouse2 .sidebar-links { background: var(--bleu-tres-pale) !important; border-radius: var(--radius) !important; padding: 20px 22px !important; }
.ov-mulhouse2 .sidebar-nav__title, .ov-mulhouse2 .sidebar-links__title { font-size: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: 0.08em !important; color: var(--bleu) !important; margin-bottom: 14px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .sidebar-nav-list, .ov-mulhouse2 .sidebar-link-list { list-style: none !important; display: flex !important; flex-direction: column !important; gap: 0 !important; padding: 0 !important; margin: 0 !important; }
.ov-mulhouse2 .sidebar-nav-list li a, .ov-mulhouse2 .sidebar-link-list li a { display: flex !important; align-items: center !important; gap: 8px !important; padding: 9px 0 !important; font-size: 12.5px !important; font-weight: 600 !important; color: var(--bleu) !important; text-decoration: none !important; border-bottom: 1px solid #dde6ea !important; transition: color 0.15s !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .sidebar-nav-list li:last-child a, .ov-mulhouse2 .sidebar-link-list li:last-child a { border-bottom: none !important; }
.ov-mulhouse2 .sidebar-nav-list li a:hover, .ov-mulhouse2 .sidebar-link-list li a:hover { color: var(--orange) !important; }
.ov-mulhouse2 .sidebar-nav-list li a::before { content: '#' !important; color: var(--orange) !important; font-weight: 700 !important; font-size: 11px !important; }
.ov-mulhouse2 .sidebar-link-list li a::before { content: '→' !important; color: var(--orange) !important; font-weight: 700 !important; }

.ov-mulhouse2 .sidebar-cta { background: var(--bleu) !important; border-radius: var(--radius) !important; padding: 28px 24px !important; text-align: center !important; }
.ov-mulhouse2 .sidebar-cta__icon { font-size: 32px !important; margin-bottom: 12px !important; }
.ov-mulhouse2 .sidebar-cta__title { font-size: 16px !important; font-weight: 800 !important; margin-bottom: 10px !important; color: #fff !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .sidebar-cta__text { font-size: 12.5px !important; color: rgba(255,255,255,0.75) !important; margin-bottom: 20px !important; line-height: 1.6 !important; font-family: 'Montserrat', sans-serif !important; }

.ov-mulhouse2 .btn-primary { display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 8px !important; background: var(--orange) !important; color: #fff !important; font-size: 13px !important; font-weight: 700 !important; font-family: 'Montserrat', sans-serif !important; padding: 14px 28px !important; border-radius: var(--radius) !important; text-decoration: none !important; border: none !important; cursor: pointer !important; transition: background 0.2s, transform 0.2s, box-shadow 0.2s !important; box-shadow: 0 4px 16px rgba(236,96,82,0.35) !important; width: 100% !important; margin-top: 20px !important; }
.ov-mulhouse2 .btn-primary:hover { background: var(--orange-dark) !important; transform: translateY(-2px) !important; box-shadow: 0 8px 24px rgba(236,96,82,0.4) !important; }

.ov-mulhouse2 .sidebar-note { background: var(--orange) !important; border-radius: var(--radius) !important; padding: 20px 22px !important; color: #fff !important; }
.ov-mulhouse2 .sidebar-note__title { font-size: 13px !important; font-weight: 700 !important; margin-bottom: 8px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .sidebar-note p { font-size: 12px !important; color: rgba(255,255,255,0.9) !important; margin-bottom: 0 !important; font-family: 'Montserrat', sans-serif !important; }

/* CTA BAND */
.ov-mulhouse2 .cta-band { background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-light) 100%) !important; padding: 56px 40px !important; text-align: center !important; margin: 0 !important; }
.ov-mulhouse2 .cta-band__title { font-size: 24px !important; font-weight: 800 !important; color: #fff !important; margin-bottom: 12px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .cta-band__sub { font-size: 15px !important; color: rgba(255,255,255,0.75) !important; margin-bottom: 36px !important; font-family: 'Montserrat', sans-serif !important; }
.ov-mulhouse2 .cta-band .btn-primary { font-size: 14px !important; padding: 16px 36px !important; width: auto !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .ov-mulhouse .hero__content { padding: 60px 20px 48px !important; }
  .ov-mulhouse .breadcrumb__inner { padding: 0 20px !important; }
  .ov-mulhouse .intro-section { padding: 36px 20px 32px !important; }
  .ov-mulhouse2 .content-grid { grid-template-columns: 1fr !important; gap: 40px !important; }
  .ov-mulhouse2 .sidebar { position: static !important; }
  .ov-mulhouse2 .quartiers-grid { grid-template-columns: 1fr !important; }
  .ov-mulhouse2 .marche-grid { grid-template-columns: 1fr 1fr !important; }
  .ov-mulhouse2 .communes-grid { grid-template-columns: 1fr 1fr !important; }
  .ov-mulhouse2 .page-wrapper { padding: 0 20px !important; }
  .ov-mulhouse2 .cta-band { padding: 40px 20px !important; }
}
@media (max-width: 480px) {
  .ov-mulhouse .hero__title { font-size: 22px !important; }
  .ov-mulhouse2 .marche-grid { grid-template-columns: 1fr !important; }
  .ov-mulhouse2 .btn-primary { width: 100% !important; }
}/* End custom CSS */