/* ===================================================================
   HDB PATRIMOINE — theme.css (v3)
   Header, footer, base + finitions Elementor + blocs scroll horizontal mobile.
   =================================================================== */
:root{
	--hdb-gold:#c09436; --hdb-gold2:#d4aa55;
	--hdb-black:#0a0a0a; --hdb-black2:#111111;
	--hdb-ink:#2c2c2c; --hdb-grey:#6b6b6b;
	--hdb-ivory:#f8f5f0; --hdb-white:#ffffff;
	--hdb-serif:'Cormorant Garamond',Georgia,serif;
	--hdb-sans:'Manrope','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
	--hdb-header-h:84px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--hdb-sans);color:var(--hdb-ink);background:var(--hdb-white);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--hdb-gold);text-decoration:none;transition:.25s}
a:hover{color:var(--hdb-black)}
.hdb-skip{position:absolute;left:-9999px;top:0;background:var(--hdb-black);color:var(--hdb-gold);padding:10px 18px;z-index:100000}
.hdb-skip:focus{left:0}

.hdb-btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--hdb-sans);font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:15px 30px;border:1px solid transparent;border-radius:2px;cursor:pointer;transition:.25s;white-space:nowrap}
.hdb-btn-gold{background:var(--hdb-gold);color:var(--hdb-black);border-color:var(--hdb-gold)}
.hdb-btn-gold:hover{background:var(--hdb-black);color:var(--hdb-white);border-color:var(--hdb-black)}
.hdb-btn-block{display:flex;width:100%;margin-top:14px}
.hdb-container{max-width:1180px;margin:0 auto;padding:0 24px}

/* ===================== HEADER ===================== */
.hdb-header{position:relative;z-index:50;background:rgba(255,255,255,.98);border-bottom:1px solid #ece6da;height:var(--hdb-header-h);display:flex;align-items:center}
.hdb-header.is-scrolled{box-shadow:none}
.hdb-header-inner{max-width:1280px;margin:0 auto;padding:0 28px;width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.hdb-header-logo img{max-height:52px;width:auto}
.hdb-logo-text{display:inline-flex;align-items:baseline;gap:8px;line-height:1}
.hdb-logo-mark{font-family:var(--hdb-serif);font-size:28px;font-weight:600;color:var(--hdb-black);letter-spacing:2px}
.hdb-logo-mark span{color:var(--hdb-gold)}
.hdb-logo-sub{font-family:var(--hdb-sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--hdb-grey)}
.hdb-header-nav{flex:1;display:flex;justify-content:center}
.hdb-menu{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:34px}
.hdb-menu a{font-family:var(--hdb-sans);font-size:13px;font-weight:500;letter-spacing:.8px;text-transform:uppercase;color:var(--hdb-black);padding:6px 0;position:relative}
.hdb-menu a:after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--hdb-gold);transition:.3s}
.hdb-menu a:hover,.hdb-menu .current-menu-item>a{color:var(--hdb-gold)}
.hdb-menu a:hover:after,.hdb-menu .current-menu-item>a:after{width:100%}
.hdb-header-cta{display:flex;align-items:center;gap:16px}
.hdb-burger{display:none;flex-direction:column;gap:5px;width:30px;background:none;border:0;cursor:pointer;padding:6px}
.hdb-burger span{height:1.5px;width:100%;background:var(--hdb-black);transition:.3s}
.hdb-burger.is-active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hdb-burger.is-active span:nth-child(2){opacity:0}
.hdb-burger.is-active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.hdb-mobile-panel{position:absolute;top:100%;left:0;right:0;background:var(--hdb-black);padding:24px;transform:translateY(-12px);opacity:0;visibility:hidden;transition:.3s;z-index:999;max-height:calc(100vh - var(--hdb-header-h));overflow-y:auto}
.hdb-mobile-panel.is-open{transform:translateY(0);opacity:1;visibility:visible}
.hdb-mobile-menu{list-style:none;margin:0 0 10px;padding:0}
.hdb-mobile-menu a{display:block;padding:14px 0;color:rgba(255,255,255,.9);font-family:var(--hdb-serif);font-size:21px;border-bottom:1px solid rgba(192,148,54,.2)}
.hdb-mobile-menu a:hover{color:var(--hdb-gold)}

/* ===================== MAIN ===================== */
.hdb-main{padding-top:0}
.hdb-page-full{width:100%}
.hdb-stdpage{padding:60px 0}
.hdb-404-code{font-family:var(--hdb-serif);font-size:96px;color:var(--hdb-gold);line-height:1}
.hdb-404 h1{font-family:var(--hdb-serif);font-size:36px;color:var(--hdb-black)}

/* ===================== FOOTER ===================== */
.hdb-footer{background:var(--hdb-black);color:rgba(255,255,255,.7)}
.hdb-footer-inner{max-width:1280px;margin:0 auto;padding:70px 28px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:48px}
.hdb-footer-logo{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.hdb-footer-logo .hdb-logo-mark{color:#fff;font-size:24px}
.hdb-footer-logo .hdb-logo-mark span{color:var(--hdb-gold)}
.hdb-footer-logo .hdb-logo-sub{color:rgba(255,255,255,.6)}
.hdb-footer-baseline{font-family:var(--hdb-serif);font-size:17px;color:var(--hdb-gold);margin:0 0 14px;line-height:1.5}
.hdb-footer-about{font-size:14px;color:rgba(255,255,255,.6);line-height:1.7}
.hdb-footer-col h4{font-family:var(--hdb-serif);font-size:18px;font-weight:600;color:var(--hdb-gold);margin:0 0 16px}
.hdb-footer-col ul{list-style:none;margin:0;padding:0}
.hdb-footer-col li{margin-bottom:9px}
.hdb-footer-col a{font-size:14px;color:rgba(255,255,255,.65)}
.hdb-footer-col a:hover{color:var(--hdb-gold)}
.hdb-footer-col p{margin:0 0 8px;font-size:14px}
.hdb-footer-legal{border-top:1px solid rgba(192,148,54,.15);background:#070707}
.hdb-disclaimer-mini{max-width:1280px;margin:0 auto;padding:18px 28px 0;font-size:12.5px;font-style:italic;color:rgba(255,255,255,.4);line-height:1.6}
.hdb-footer-bottom{max-width:1280px;margin:0 auto;padding:14px 28px 24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:rgba(255,255,255,.45)}
.hdb-footer-bottom a{color:rgba(255,255,255,.55)}
.hdb-footer-bottom a:hover{color:var(--hdb-gold)}

/* ===================== ELEMENTOR : finitions ===================== */
.elementor-widget-heading .elementor-heading-title{font-family:var(--hdb-serif)}
.elementor-widget-text-editor{font-family:var(--hdb-sans)}
.elementor-button{font-family:var(--hdb-sans)!important;letter-spacing:1.5px}
.elementor-accordion .elementor-tab-title{font-family:var(--hdb-serif)}
blockquote.elementor-heading-title{font-style:normal}

/* ===================================================================
   BLOCS SCROLL HORIZONTAL SUR MOBILE (classe hdb-hscroll)
   Desktop : grille normale. Mobile : défilement horizontal interne propre.
   =================================================================== */
@media (max-width:767px){
	.hdb-hscroll > .elementor-container{
		flex-wrap:nowrap!important;
		overflow-x:auto;
		overflow-y:hidden;
		scroll-snap-type:x mandatory;
		-webkit-overflow-scrolling:touch;
		padding:4px 16px 16px;
		gap:0;
		scrollbar-width:thin;
		scrollbar-color:var(--hdb-gold) #e7e1d6;
	}
	.hdb-hscroll > .elementor-container > .elementor-column{
		flex:0 0 84%!important;
		max-width:84%!important;
		width:84%!important;
		scroll-snap-align:start;
	}
	.hdb-hscroll > .elementor-container::-webkit-scrollbar{height:6px}
	.hdb-hscroll > .elementor-container::-webkit-scrollbar-thumb{background:var(--hdb-gold);border-radius:3px}
	.hdb-hscroll > .elementor-container::-webkit-scrollbar-track{background:#e7e1d6}
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1024px){.hdb-footer-inner{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:900px){.hdb-header-nav{display:none}.hdb-burger{display:flex}.hdb-header-cta .hdb-btn-gold{display:none}}
@media (max-width:768px){
	:root{--hdb-header-h:72px}
	.hdb-footer-inner{grid-template-columns:1fr;gap:28px;padding:50px 24px 30px}
	.hdb-footer-bottom{flex-direction:column;text-align:center}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto!important}}

/* ===================================================================
   CONTENU DE SECOURS premium (affiché si Elementor inactif)
   =================================================================== */
.hdb-fb-wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.hdb-fb-eyebrow{display:block;font-family:var(--hdb-sans);font-size:12.5px;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;color:var(--hdb-gold);margin-bottom:14px}
.hdb-fb-eyebrow.gold2{color:var(--hdb-gold2)}
.hdb-fb-eyebrow.center{text-align:center}
.hdb-fb-rule{display:block;width:70px;height:1px;background:var(--hdb-gold);margin:0 0 24px}
.hdb-fb-rule.center{margin-left:auto;margin-right:auto}
.hdb-fb-btn{display:inline-block;font-family:var(--hdb-sans);font-size:12.5px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;padding:17px 36px;border:1px solid transparent;border-radius:1px;transition:.25s;cursor:pointer}
.hdb-fb-btn.sm{padding:13px 26px;font-size:11.5px}
.hdb-fb-btn.gold{background:var(--hdb-gold);color:var(--hdb-black);border-color:var(--hdb-gold)}
.hdb-fb-btn.gold:hover{background:var(--hdb-black);color:#fff}
.hdb-fb-btn.light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.hdb-fb-btn.light:hover{background:var(--hdb-gold);color:var(--hdb-black);border-color:var(--hdb-gold)}
.hdb-fb-btn.outline{background:transparent;color:var(--hdb-black);border-color:var(--hdb-black)}
.hdb-fb-btn.outline:hover{background:var(--hdb-black);color:#fff}

/* Hero */
.hdb-fb-hero{background:var(--hdb-black);color:#fff;padding:170px 0 0;background-size:cover;background-position:center}
.hdb-fb-hero .hdb-fb-wrap:first-child{padding-bottom:96px}
.hdb-fb-hero h1{font-family:var(--hdb-serif);font-size:clamp(36px,6vw,62px);font-weight:600;line-height:1.07;color:#fff;margin:14px 0 22px;max-width:17ch}
.hdb-fb-hero .lead{font-size:18px;color:rgba(255,255,255,.82);line-height:1.78;max-width:60ch;margin:0 0 34px}
.hdb-fb-btns{display:flex;flex-wrap:wrap;gap:14px}
.hdb-fb-band{background:var(--hdb-black2);border-top:1px solid rgba(192,148,54,.2)}
.hdb-fb-band-row{display:flex;padding-top:28px;padding-bottom:28px;gap:0}
.hdb-fb-band-row span{flex:1;text-align:center;color:var(--hdb-gold2);font-size:13.5px;font-weight:600;letter-spacing:.5px;border-left:1px solid rgba(192,148,54,.3)}
.hdb-fb-band-row span:first-child{border-left:0}

/* Sections */
.hdb-fb-sec{padding:104px 0}
.hdb-fb-sec.ivory{background:var(--hdb-ivory)}
.hdb-fb-sec h2{font-family:var(--hdb-serif);font-size:clamp(28px,4vw,40px);font-weight:600;color:var(--hdb-black);line-height:1.16;margin:0 0 16px}
.hdb-fb-sec .lead2{font-size:16.5px;color:var(--hdb-grey);max-width:64ch;margin:0 auto 28px}
.hdb-fb-center{text-align:center}
.hdb-fb-center .hdb-fb-rule{margin-left:auto;margin-right:auto}

/* Éditorial */
.hdb-fb-edito{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hdb-fb-col-img img{width:100%;border-radius:2px;display:block}
.hdb-fb-col-txt h2{margin-top:6px}
.hdb-fb-col-txt p{font-size:16.5px;color:#3a3a3a;line-height:1.9;margin:0 0 16px}
.hdb-fb-col-txt ul{list-style:none;padding:0;margin:16px 0 24px}
.hdb-fb-col-txt li{position:relative;padding-left:24px;margin-bottom:10px;color:#3a3a3a}
.hdb-fb-col-txt li:before{content:'';position:absolute;left:0;top:12px;width:12px;height:1px;background:var(--hdb-gold)}
.hdb-fb-quote-in{font-family:var(--hdb-serif);font-style:italic;font-size:21px;color:var(--hdb-gold);line-height:1.5;margin:0 0 24px!important}

/* Grilles repères / docs / steps */
.hdb-fb-grid{display:grid;gap:30px;margin-top:44px}
.hdb-fb-grid.g2{grid-template-columns:repeat(2,1fr)}
.hdb-fb-grid.g3{grid-template-columns:repeat(3,1fr)}
.hdb-fb-grid.g4{grid-template-columns:repeat(4,1fr)}
.hdb-fb-pillar{border-left:1px solid rgba(192,148,54,.45);padding:4px 20px}
.hdb-fb-pillar .num{font-family:var(--hdb-serif);font-size:32px;color:var(--hdb-gold)}
.hdb-fb-pillar h3{font-family:var(--hdb-serif);font-size:21px;color:var(--hdb-black);margin:8px 0}
.hdb-fb-pillar p{font-size:14.5px;color:var(--hdb-grey);line-height:1.6;margin:0}
.hdb-fb-dir{border-left:2px solid rgba(192,148,54,.4);padding:6px 22px}
.hdb-fb-dir h3{font-family:var(--hdb-serif);font-size:24px;color:var(--hdb-black);margin:0 0 8px}
.hdb-fb-dir p{font-size:15px;color:var(--hdb-grey);line-height:1.7;margin:0}
.hdb-fb-step{border-left:2px solid rgba(192,148,54,.4);padding:6px 18px}
.hdb-fb-step .num{font-family:var(--hdb-serif);font-size:34px;color:var(--hdb-gold)}
.hdb-fb-step h3{font-family:var(--hdb-serif);font-size:19px;color:var(--hdb-black);margin:6px 0 0}
.hdb-fb-doc{background:#fff;border:1px solid #ece6da;border-top:2px solid var(--hdb-gold);padding:30px 24px}
.hdb-fb-sec.ivory .hdb-fb-doc{background:var(--hdb-ivory)}
.hdb-fb-doc h3{font-family:var(--hdb-serif);font-size:21px;margin:6px 0 8px;color:var(--hdb-black)}
.hdb-fb-doc p{font-size:14.5px;color:var(--hdb-grey);line-height:1.6;margin:0 0 18px}

/* Programmes (scroll mobile) */
.hdb-fb-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.hdb-fb-prog{background:#fff;border:1px solid #ece6da}
.hdb-fb-prog img{width:100%;height:230px;object-fit:cover;display:block}
.hdb-fb-prog-b{padding:22px}
.hdb-fb-prog-b h3{font-family:var(--hdb-serif);font-size:23px;color:var(--hdb-black);margin:6px 0;line-height:1.2}
.hdb-fb-prog-b .loc{font-size:14px;color:var(--hdb-gold);font-weight:600;margin:0 0 10px}
.hdb-fb-prog-b .inf{font-size:14.5px;color:var(--hdb-grey);line-height:1.7;margin:0 0 18px}

/* Accordéons natifs */
.hdb-fb-acc{max-width:880px;margin:40px auto 0}
.hdb-fb-acc details{border:1px solid #e3dccd;border-bottom:0;background:#fff}
.hdb-fb-sec.ivory .hdb-fb-acc details{background:#fff}
.hdb-fb-acc details:last-child{border-bottom:1px solid #e3dccd}
.hdb-fb-acc summary{list-style:none;cursor:pointer;padding:22px 26px;font-family:var(--hdb-serif);font-size:23px;font-weight:600;color:var(--hdb-black);display:flex;justify-content:space-between;align-items:center}
.hdb-fb-acc summary::-webkit-details-marker{display:none}
.hdb-fb-acc summary .ico{position:relative;width:16px;height:16px;flex:0 0 16px}
.hdb-fb-acc summary .ico:before,.hdb-fb-acc summary .ico:after{content:'';position:absolute;background:var(--hdb-gold);transition:.25s}
.hdb-fb-acc summary .ico:before{top:7px;left:0;width:16px;height:2px}
.hdb-fb-acc summary .ico:after{top:0;left:7px;width:2px;height:16px}
.hdb-fb-acc details[open] summary{color:var(--hdb-gold)}
.hdb-fb-acc details[open] summary .ico:after{transform:scaleY(0)}
.hdb-fb-acc-body{padding:0 26px 24px}
.hdb-fb-acc-body p{font-size:15.5px;color:#3a3a3a;line-height:1.8;margin:0 0 10px}

/* Citation pleine largeur */
.hdb-fb-quote{background:var(--hdb-black);color:#fff;padding:110px 0;text-align:center;background-size:cover;background-position:center}
.hdb-fb-quote p{font-family:var(--hdb-serif);font-size:clamp(24px,4vw,40px);color:#fff;line-height:1.38;margin:0;font-weight:500}

/* CTA */
.hdb-fb-cta{background:var(--hdb-black);color:#fff;padding:112px 0;text-align:center}
.hdb-fb-cta h2{font-family:var(--hdb-serif);font-size:clamp(28px,4vw,44px);color:#fff;margin:0 0 18px}
.hdb-fb-cta p{font-size:17px;color:rgba(255,255,255,.78);max-width:64ch;margin:0 auto 32px;line-height:1.78}

/* Contact */
.hdb-fb-contact{display:grid;grid-template-columns:58% 42%;gap:0}
.hdb-fb-form{background:#fff;border:1px solid #ece6da;padding:44px;margin-right:16px}
.hdb-fb-form h2{margin:0 0 16px}
.hdb-fb-form p{font-size:15px;color:var(--hdb-grey);margin:0 0 16px}
.hdb-fb-info{background:var(--hdb-black);color:#fff;padding:44px 38px}
.hdb-fb-info h3{font-family:var(--hdb-serif);font-size:24px;color:#fff;margin:0 0 14px}
.hdb-fb-info p{font-size:15px;color:rgba(255,255,255,.82);line-height:1.7;margin:0 0 20px}
.hdb-fb-info .hdb-fb-rule{margin:8px 0 24px}

.hdb-fb-disclaimer{font-size:13.5px;font-style:italic;color:var(--hdb-grey);border-left:3px solid var(--hdb-gold);padding:18px 22px;background:#fff;line-height:1.7}

@media (max-width:980px){
	.hdb-fb-edito{grid-template-columns:1fr;gap:30px}
	.hdb-fb-grid.g4{grid-template-columns:repeat(2,1fr)}
	.hdb-fb-contact{grid-template-columns:1fr}
	.hdb-fb-form{margin:0 0 16px}
}
@media (max-width:767px){
	.hdb-fb-sec{padding:60px 0}
	.hdb-fb-hero{padding-top:120px}
	.hdb-fb-hero .hdb-fb-wrap:first-child{padding-bottom:56px}
	.hdb-fb-band-row{flex-wrap:wrap;gap:14px 0}
	.hdb-fb-band-row span{flex:0 0 50%}
	.hdb-fb-band-row span:nth-child(odd){border-left:0}
	.hdb-fb-grid.g3,.hdb-fb-grid.g2{grid-template-columns:1fr}
	.hdb-fb-grid.g4{grid-template-columns:repeat(2,1fr)}
	/* Programmes : scroll horizontal interne */
	.hdb-fb-scroll{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:14px}
	.hdb-fb-prog{flex:0 0 84%;scroll-snap-align:start}
	.hdb-fb-scroll::-webkit-scrollbar{height:6px}
	.hdb-fb-scroll::-webkit-scrollbar-thumb{background:var(--hdb-gold);border-radius:3px}
}

/* ===================================================================
   MOBILE RESPONSIVE — corrections overflow et lisibilité
   =================================================================== */
html { overflow-x: hidden; }
body { overflow-x: hidden; max-width: 100vw; }

.elementor-section { overflow-x: hidden; }
.hdb-hscroll { overflow-x: auto !important; }

/* Titres fluides sur mobile */
@media (max-width: 767px) {
  .elementor-widget-heading h1.elementor-heading-title {
    font-size: clamp(26px, 7.5vw, 52px) !important;
    line-height: 1.12 !important;
    overflow-wrap: break-word;
    word-break: break-word;
  }
  .elementor-widget-heading h2.elementor-heading-title {
    font-size: clamp(20px, 6vw, 38px) !important;
    overflow-wrap: break-word;
  }
  .elementor-widget-heading h3.elementor-heading-title {
    font-size: clamp(17px, 5vw, 26px) !important;
  }

  /* Textes : coupure propre */
  .elementor-widget-text-editor p,
  .elementor-widget-text-editor li {
    overflow-wrap: break-word;
    word-wrap: break-word;
    max-width: 100%;
  }

  /* Boutons : pas de débordement */
  .elementor-button {
    white-space: normal !important;
    word-break: break-word !important;
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .elementor-widget-button .elementor-button-wrapper {
    max-width: 100%;
  }

  /* Images */
  .elementor-widget-image img {
    max-width: 100% !important;
    height: auto !important;
  }

  /* Colonnes stacked : reset horizontal padding */
  .elementor-column > .elementor-widget-wrap {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Columns contact / form : garder padding interne */
  .hdb-form-col > .elementor-widget-wrap {
    padding: 28px !important;
  }

  /* Bandeau hero repères : 2 colonnes sur mobile */
  .hdb-band .elementor-container { flex-wrap: wrap !important; }
  .hdb-band .elementor-column { flex: 0 0 50% !important; max-width: 50% !important; }
  .hdb-band .elementor-column:nth-child(odd) { border-left: 0 !important; }

  /* Scroll horizontal sections (programmes/resources) */
  .hdb-hscroll > .elementor-container {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding-bottom: 14px;
  }
  .hdb-hscroll > .elementor-container > .elementor-column {
    flex: 0 0 85% !important;
    max-width: 85% !important;
    scroll-snap-align: start;
  }

  /* Head-center : padding horizontal déjà géré par hdb_sec mobile */
  .elementor-widget-heading[data-widget_type="heading.default"] {
    max-width: 100%;
  }
}

@media (max-width: 480px) {
  .hdb-hscroll > .elementor-container > .elementor-column {
    flex: 0 0 90% !important;
    max-width: 90% !important;
  }
}

/* ===================================================================
   TIMELINE — sections numérotées (hdb_reperes_asym)
   =================================================================== */

/* Ligne verticale dorée sur le côté droit (right column) */
.hdb-tl .elementor-column:last-child > .elementor-widget-wrap {
  position: relative;
}
.hdb-tl .elementor-column:last-child > .elementor-widget-wrap::before {
  content: '';
  position: absolute;
  left: 7%;
  top: 12px;
  bottom: 12px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(192,148,54,0.35) 8%, rgba(192,148,54,0.35) 92%, transparent);
  pointer-events: none;
  z-index: 0;
}

/* Dot doré sur chaque item */
.hdb-tl-item .elementor-col-14::after {
  content: '';
  position: absolute;
  right: -6px;
  top: 12px;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--hdb-gold);
  z-index: 2;
  border: 2px solid var(--hdb-ivory,#f8f5f0);
  transition: transform 0.3s ease;
}
.hdb-tl-item:hover .elementor-col-14::after { transform: scale(1.4); }

/* Dark variant */
.hdb-tl.elementor-section[data-settings*="dark"] .elementor-col-14::after,
.hdb-tl .elementor-col-14::after { border-color: var(--hdb-ivory,#f8f5f0); }

/* Nombre : position relative pour le dot */
.hdb-tl-item .elementor-col-14 { position: relative; }

/* Animation staggerée (opacity+translateY) */
.hdb-tl-item { opacity: 0; transform: translateY(20px); }
.hdb-tl-item.hdb-vis {
  animation: hdb-in 0.6s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.hdb-tl-item.hdb-vis:nth-child(1) { animation-delay: 0s; }
.hdb-tl-item.hdb-vis:nth-child(2) { animation-delay: 0.1s; }
.hdb-tl-item.hdb-vis:nth-child(3) { animation-delay: 0.2s; }
.hdb-tl-item.hdb-vis:nth-child(4) { animation-delay: 0.3s; }
.hdb-tl-item.hdb-vis:nth-child(5) { animation-delay: 0.4s; }
.hdb-tl-item.hdb-vis:nth-child(6) { animation-delay: 0.5s; }

@keyframes hdb-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ===================================================================
   STEPS — sections d'étapes (hdb_step_col)
   =================================================================== */

/* Ligne horizontale dorée qui relie les étapes */
.hdb-steps-row > .elementor-container { position: relative; }
.hdb-steps-row > .elementor-container::after {
  content: '';
  position: absolute;
  top: 48px;
  left: 4%;
  right: 4%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(192,148,54,0.45) 8%, rgba(192,148,54,0.45) 92%, transparent);
  z-index: 0;
  pointer-events: none;
}

/* Dot de connexion sur chaque étape */
.hdb-steps-row .elementor-column { position: relative; }
.hdb-steps-row .elementor-column::before {
  content: '';
  position: absolute;
  top: 41px;
  left: 0;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--hdb-gold);
  z-index: 1;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.hdb-steps-row .elementor-column:hover::before {
  transform: scale(1.5);
  box-shadow: 0 0 0 4px rgba(192,148,54,0.2);
}

/* Animation staggerée des étapes */
.hdb-steps-row .elementor-column {
  opacity: 0; transform: translateY(16px);
}
.hdb-steps-row .elementor-column.hdb-vis {
  animation: hdb-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.hdb-steps-row .elementor-column.hdb-vis:nth-child(1) { animation-delay: 0s; }
.hdb-steps-row .elementor-column.hdb-vis:nth-child(2) { animation-delay: 0.08s; }
.hdb-steps-row .elementor-column.hdb-vis:nth-child(3) { animation-delay: 0.16s; }
.hdb-steps-row .elementor-column.hdb-vis:nth-child(4) { animation-delay: 0.24s; }

/* ===================================================================
   MOBILE HORIZONTAL SCROLL — étapes (.hdb-hscroll-m)
   =================================================================== */
@media (max-width: 767px) {
  .hdb-hscroll-m > .elementor-container {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 14px;
    gap: 14px;
    /* Pas de pseudo-ligne horizontale en mode scroll */
  }
  .hdb-hscroll-m > .elementor-container::after { display: none; }
  .hdb-hscroll-m > .elementor-container > .elementor-column {
    flex: 0 0 80% !important;
    max-width: 80% !important;
    scroll-snap-align: start;
  }
  .hdb-hscroll-m > .elementor-container > .elementor-column::before { display: none; }
  .hdb-hscroll-m::-webkit-scrollbar { height: 4px; }
  .hdb-hscroll-m::-webkit-scrollbar-thumb { background: var(--hdb-gold); border-radius: 2px; }
}

/* ===================================================================
   FORMULAIRE CF7 — design premium HDB
   =================================================================== */
.wpcf7 { width:100%; }
.wpcf7-form { width:100%; display:flex; flex-direction:column; gap:4px; }
.wpcf7-form p { margin:0; }

/* Labels */
.wpcf7-form label {
  display:block;
  font-family:var(--hdb-sans, Manrope, sans-serif);
  font-size:10.5px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--hdb-gold,#c09436);
  margin:18px 0 7px;
}
.wpcf7-form > p:first-child label,
.wpcf7-form label:first-child { margin-top:0; }

/* Champs */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="date"],
.wpcf7-form select,
.wpcf7-form textarea {
  width:100%;
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(0,0,0,0.16);
  border-radius:0;
  padding:13px 2px;
  font-family:var(--hdb-sans, Manrope, sans-serif);
  font-size:15.5px; font-weight:400;
  color:var(--hdb-ink,#2c2c2c);
  outline:none; box-shadow:none; -webkit-appearance:none; appearance:none;
  transition:border-color .25s ease, background .25s ease;
}
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder { color:rgba(0,0,0,0.32); }
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
  border-bottom-color:var(--hdb-gold,#c09436);
}
.wpcf7-form textarea { min-height:104px; resize:vertical; line-height:1.6; }
.wpcf7-form select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c09436' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 4px center; padding-right:26px; cursor:pointer;
}

/* Acceptance / cases à cocher */
.wpcf7-form .wpcf7-acceptance,
.wpcf7-form .wpcf7-checkbox { margin-top:18px; }
.wpcf7-form .wpcf7-list-item { margin:0; display:flex; align-items:flex-start; gap:10px; }
.wpcf7-form input[type="checkbox"] { width:16px; height:16px; flex:0 0 16px; margin-top:3px; accent-color:var(--hdb-gold,#c09436); }
.wpcf7-form .wpcf7-list-item-label { font-size:12.5px; color:var(--hdb-grey,#6b6b6b); line-height:1.55; text-transform:none; letter-spacing:0; font-weight:400; }

/* Bouton submit */
.wpcf7-form .wpcf7-submit {
  display:block; width:100%; margin-top:30px;
  padding:18px 32px;
  background:var(--hdb-gold,#c09436); color:var(--hdb-black,#0a0a0a);
  border:1px solid var(--hdb-gold,#c09436);
  font-family:var(--hdb-sans, Manrope, sans-serif);
  font-size:11.5px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  cursor:pointer; border-radius:1px;
  transition:background .25s ease, color .25s ease;
}
.wpcf7-form .wpcf7-submit:hover { background:transparent; color:var(--hdb-gold,#c09436); }
.wpcf7-spinner { display:none; }

/* Messages */
.wpcf7-not-valid-tip { font-size:11.5px; color:#c0392b; margin-top:5px; letter-spacing:0; text-transform:none; font-weight:500; }
.wpcf7-response-output {
  margin:18px 0 0 !important; padding:13px 16px !important;
  font-family:var(--hdb-sans, Manrope, sans-serif); font-size:13px;
  border:none !important; border-left:3px solid var(--hdb-gold,#c09436) !important; border-radius:1px;
}
.wpcf7-mail-sent-ok { background:rgba(192,148,54,0.08) !important; color:var(--hdb-ink,#2c2c2c) !important; }
.wpcf7-mail-sent-ng, .wpcf7-validation-errors { background:rgba(192,58,54,0.06) !important; border-left-color:#c0392b !important; }

/* ---- Variante sur bloc NOIR (.hdb-form-dark) ---- */
.hdb-form-dark .wpcf7-form input[type="text"],
.hdb-form-dark .wpcf7-form input[type="email"],
.hdb-form-dark .wpcf7-form input[type="tel"],
.hdb-form-dark .wpcf7-form input[type="number"],
.hdb-form-dark .wpcf7-form select,
.hdb-form-dark .wpcf7-form textarea {
  border-bottom-color:rgba(255,255,255,0.22);
  color:#fff;
}
.hdb-form-dark .wpcf7-form input::placeholder,
.hdb-form-dark .wpcf7-form textarea::placeholder { color:rgba(255,255,255,0.4); }
.hdb-form-dark .wpcf7-form input:focus,
.hdb-form-dark .wpcf7-form select:focus,
.hdb-form-dark .wpcf7-form textarea:focus { border-bottom-color:var(--hdb-gold,#c09436); background:rgba(192,148,54,0.05); }
.hdb-form-dark .wpcf7-form select option { color:#2c2c2c; }
.hdb-form-dark .wpcf7-list-item-label { color:rgba(255,255,255,0.65); }
.hdb-form-dark .wpcf7-form .wpcf7-submit { background:var(--hdb-gold,#c09436); color:#0a0a0a; }
.hdb-form-dark .wpcf7-form .wpcf7-submit:hover { background:transparent; color:var(--hdb-gold,#c09436); }


/* ===================================================================
   LOGO RÉEL HDB (remplace le texte H D B)
   =================================================================== */
.hdb-logo-img-wrap { display:flex; align-items:center; text-decoration:none; }
.hdb-logo-img { height:56px; width:auto; display:block; }
.hdb-logo-white { display:none; }
.hdb-logo-color { display:block; }
/* Header clair non-sticky : logo couleur toujours visible */
.hdb-header.is-scrolled .hdb-logo-white { display:none; }
.hdb-header.is-scrolled .hdb-logo-color { display:block; }
/* Dans le panel mobile (fond sombre) : toujours blanc */
.hdb-mobile-panel .hdb-logo-white { display:block !important; }
.hdb-mobile-panel .hdb-logo-color { display:none !important; }
/* Footer logo déjà en texte — garder */
@media (max-width:767px) { .hdb-logo-img { height:44px; } }

/* ===================================================================
   FIX MOBILE — solution définitive anti-débordement texte
   =================================================================== */

/* 1. Empêcher tout scroll horizontal */
html, body { overflow-x: hidden !important; max-width: 100%; }
* { box-sizing: border-box; }

/* 2. Forcer du padding dans chaque section sur mobile
      (rule CSS directe, indépendante de l'Elementor cached CSS) */
@media (max-width: 767px) {

  /* Toutes les sections top-level → padding horizontal 18px */
  .elementor-section:not(.elementor-inner-section) > .elementor-container {
    padding-left: 18px !important;
    padding-right: 18px !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  /* Sauf les sections à scroll horizontal (géré par elles-mêmes) */
  .hdb-hscroll > .elementor-container,
  .hdb-hscroll-m > .elementor-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Reset horizontal du padding colonnes (géré par le container parent) */
  .elementor-section:not(.elementor-inner-section):not(.hdb-hscroll):not(.hdb-hscroll-m)
    > .elementor-container
    > .elementor-column
    > .elementor-widget-wrap {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Exceptions : colonnes avec fond propre (form, info) gardent leur padding vertical */
  /* (le padding horizontal est retiré, seul le vertical est conservé) */

  /* Titres : clamp pour ne jamais dépasser */
  h1, h2, h3, h4 { overflow-wrap: break-word; word-break: break-word; }
  .elementor-widget-heading .elementor-heading-title {
    overflow-wrap: break-word;
    word-break: break-word;
    max-width: 100%;
    hyphens: auto;
  }

  /* Textes */
  .elementor-widget-text-editor { overflow-wrap: break-word; }
  .elementor-widget-text-editor p,
  .elementor-widget-text-editor li { max-width: 100%; }

  /* Images */
  img { max-width: 100% !important; height: auto !important; }
  .elementor-widget-image { max-width: 100%; }
  .elementor-widget-image img { width: 100% !important; }

  /* Boutons */
  .elementor-widget-button .elementor-button {
    white-space: normal !important;
    max-width: 100% !important;
    width: auto;
  }

  /* Bandeau hero repères */
  .hdb-band > .elementor-container {
    flex-wrap: wrap !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .hdb-band > .elementor-container > .elementor-column {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}

/* ===================================================================
   HERO — meilleure respiration du texte (header non sticky)
   =================================================================== */
.hdb-hero > .elementor-container { max-width:1280px; }
/* Décaler le bloc texte vers l'intérieur sur desktop */
.hdb-hero > .elementor-container > .elementor-column:first-child > .elementor-widget-wrap {
  padding-left: 6%;
}
@media (max-width:1024px){
  .hdb-hero > .elementor-container > .elementor-column:first-child > .elementor-widget-wrap { padding-left:34px; }
}
@media (max-width:767px){
  .hdb-hero > .elementor-container > .elementor-column:first-child > .elementor-widget-wrap { padding-left:6px; padding-right:6px; }
}
/* Hero simple (pages internes) : garder centré, respiration latérale */
.hdb-hero-simple > .elementor-container { max-width:1000px; }

/* ===================================================================
   TIMELINE premium — numéros 01/02/03 plus travaillés
   =================================================================== */
/* Numéro : style éditorial, grand, fin */
.hdb-tl-item .elementor-col-14 .elementor-heading-title {
  font-size:34px !important;
  line-height:1 !important;
  letter-spacing:-1px;
  opacity:.92;
}
/* Trait court doré sous le numéro */
.hdb-tl-item .elementor-col-14 { position:relative; }
.hdb-tl-item .elementor-col-14 > .elementor-widget-wrap::after {
  content:''; display:block; width:22px; height:2px;
  background:var(--hdb-gold,#c09436); margin-top:10px; opacity:.7;
}
/* Ligne verticale dorée le long de la colonne droite */
.hdb-tl .elementor-column:last-child > .elementor-widget-wrap::before {
  left:6.5%; opacity:.9;
}
/* Titre de l'item un peu plus présent */
.hdb-tl-item .elementor-col-86 h3.elementor-heading-title { letter-spacing:.2px; }

/* ===================================================================
   FIN DE PAGE — Instagram, FAQ, CTA, footer
   =================================================================== */

/* Instagram : cadre propre même avant chargement du plugin */
.hdb-ig-frame .elementor-widget-shortcode {
  min-height:240px;
  border:1px solid rgba(192,148,54,.22);
  border-radius:3px;
  padding:14px;
  background:linear-gradient(180deg, rgba(192,148,54,.03), transparent);
  display:flex; align-items:center; justify-content:center;
}
.hdb-ig-frame .elementor-widget-shortcode:empty::before,
.hdb-ig-frame .sb_instagram_header { /* laisse le plugin gérer */ }
.hdb-ig-frame .elementor-widget-shortcode .sbi_no_js,
.hdb-ig-frame .elementor-widget-shortcode > .shortcode-placeholder { color:var(--hdb-grey); font-size:13px; }

/* FAQ : accordéons plus aérés et premium */
.elementor-accordion .elementor-accordion-item {
  border:none !important;
  border-bottom:1px solid #e7e1d6 !important;
  margin-bottom:0;
}
.elementor-accordion .elementor-tab-title {
  padding:22px 4px !important;
  font-family:var(--hdb-serif) !important;
  font-size:19px !important;
  font-weight:500 !important;
  transition:color .2s;
}
.elementor-accordion .elementor-tab-title.elementor-active { color:var(--hdb-gold,#c09436) !important; }
.elementor-accordion .elementor-tab-content { padding:0 4px 22px !important; font-size:15.5px; line-height:1.8; color:#4a4a4a; }
.elementor-accordion .elementor-tab-title .elementor-accordion-icon { color:var(--hdb-gold,#c09436); }

/* CTA final : plus de respiration */
.hdb-cta-final, .hdb-quote { letter-spacing:.2px; }

/* Footer : hiérarchie renforcée */
.hdb-footer-inner { padding-top:84px; padding-bottom:48px; }
.hdb-footer-col h4 {
  font-size:13px !important;
  letter-spacing:2px; text-transform:uppercase;
  font-family:var(--hdb-sans) !important; font-weight:700 !important;
  padding-bottom:14px; position:relative; margin-bottom:18px !important;
}
.hdb-footer-col h4::after {
  content:''; position:absolute; left:0; bottom:0; width:28px; height:2px; background:var(--hdb-gold,#c09436);
}
.hdb-footer-col li { margin-bottom:11px; }
.hdb-footer-col a { transition:color .2s, padding-left .2s; }
.hdb-footer-col a:hover { padding-left:4px; }
.hdb-footer-baseline { font-size:18px; line-height:1.55; }

/* ===================================================================
   CARDS mobile — carousel horizontal propre (renfort)
   =================================================================== */
@media (max-width:767px){
  .hdb-hscroll > .elementor-container,
  .hdb-hscroll-m > .elementor-container {
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    gap:14px; padding-bottom:16px;
    scrollbar-width:thin; scrollbar-color:var(--hdb-gold) transparent;
  }
  .hdb-hscroll > .elementor-container > .elementor-column,
  .hdb-hscroll-m > .elementor-container > .elementor-column {
    flex:0 0 82% !important; max-width:82% !important; scroll-snap-align:start;
  }
  .hdb-hscroll > .elementor-container::-webkit-scrollbar,
  .hdb-hscroll-m > .elementor-container::-webkit-scrollbar { height:4px; }
  .hdb-hscroll > .elementor-container::-webkit-scrollbar-thumb,
  .hdb-hscroll-m > .elementor-container::-webkit-scrollbar-thumb { background:var(--hdb-gold); border-radius:2px; }
  /* Indice visuel de défilement */
  .hdb-hscroll > .elementor-container > .elementor-column:last-child,
  .hdb-hscroll-m > .elementor-container > .elementor-column:last-child { margin-right:18px; }
}
