.elementor-11728 .elementor-element.elementor-element-503c853{--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;--margin-top:50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-32d81c3{--display:flex;--min-height:460px;--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;--justify-content:flex-end;--overlay-opacity:0.5;--border-radius:20px 20px 20px 20px;--padding-top:60px;--padding-bottom:48px;--padding-left:48px;--padding-right:48px;}.elementor-11728 .elementor-element.elementor-element-32d81c3::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .elementor-background-video-container::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .e-con-inner > .elementor-background-video-container::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .elementor-background-slideshow::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .e-con-inner > .elementor-background-slideshow::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:var( --e-global-color-text );--background-overlay:'';}.elementor-11728 .elementor-element.elementor-element-32d81c3:hover::before, .elementor-11728 .elementor-element.elementor-element-32d81c3:hover > .elementor-background-video-container::before, .elementor-11728 .elementor-element.elementor-element-32d81c3:hover > .e-con-inner > .elementor-background-video-container::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .elementor-background-slideshow:hover::before, .elementor-11728 .elementor-element.elementor-element-32d81c3 > .e-con-inner > .elementor-background-slideshow:hover::before{background-color:var( --e-global-color-dfb856f );--background-overlay:'';}.elementor-11728 .elementor-element.elementor-element-32d81c3:not(.elementor-motion-effects-element-type-background), .elementor-11728 .elementor-element.elementor-element-32d81c3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-11728 .elementor-element.elementor-element-32d81c3:hover{--overlay-opacity:0.5;}.elementor-11728 .elementor-element.elementor-element-32d81c3, .elementor-11728 .elementor-element.elementor-element-32d81c3::before{--overlay-transition:2.3s;}.elementor-widget-heading .elementor-heading-title{color:var( --e-global-color-primary );}.elementor-widget-theme-post-title .elementor-heading-title{color:var( --e-global-color-primary );}.elementor-11728 .elementor-element.elementor-element-8e78f84 .elementor-heading-title{color:var( --e-global-color-8a2f13f );}.elementor-11728 .elementor-element.elementor-element-b0a4d0b .elementor-heading-title{color:var( --e-global-color-secondary );}.elementor-11728 .elementor-element.elementor-element-cb5ea22{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-7fa064d{--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-widget-icon-box.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-primary );}.elementor-widget-icon-box.elementor-view-framed .elementor-icon, .elementor-widget-icon-box.elementor-view-default .elementor-icon{fill:var( --e-global-color-primary );color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-widget-icon-box .elementor-icon-box-title{color:var( --e-global-color-primary );}.elementor-widget-icon-box:has(:hover) .elementor-icon-box-title,
					 .elementor-widget-icon-box:has(:focus) .elementor-icon-box-title{color:var( --e-global-color-primary );}.elementor-widget-icon-box .elementor-icon-box-description{color:var( --e-global-color-text );}.elementor-11728 .elementor-element.elementor-element-dd3b275 .elementor-icon-box-wrapper{gap:15px;}.elementor-11728 .elementor-element.elementor-element-5eae5bc{--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-11728 .elementor-element.elementor-element-a0adcc5 .elementor-icon-box-wrapper{gap:15px;}.elementor-11728 .elementor-element.elementor-element-ca1621c{--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-11728 .elementor-element.elementor-element-cefa033 .elementor-icon-box-wrapper{gap:15px;}.elementor-11728 .elementor-element.elementor-element-5cbba1d{--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-11728 .elementor-element.elementor-element-21b6d71 .elementor-icon-box-wrapper{gap:15px;}.elementor-11728 .elementor-element.elementor-element-c56a92a{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 20px;--row-gap:0px;--column-gap:20px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:50px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-eebcc7c{--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;--padding-top:0px;--padding-bottom:0px;--padding-left:20px;--padding-right:0px;}.elementor-widget-text-editor{color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-11728 .elementor-element.elementor-element-45306eb > .elementor-widget-container{padding:0px 0px 0px 0px;}.elementor-11728 .elementor-element.elementor-element-610e173 .elementor-heading-title{font-size:20px;line-height:25px;}.elementor-11728 .elementor-element.elementor-element-8c8f616 .elementor-heading-title{font-size:20px;line-height:20px;}.elementor-11728 .elementor-element.elementor-element-d666ff9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-25d63fe{--display:grid;--e-con-grid-template-columns:repeat(2, 1fr);--e-con-grid-template-rows:repeat(3, 1fr);--gap:10px 10px;--row-gap:10px;--column-gap:10px;--grid-auto-flow:row;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-47c0fb7 .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-b6fc5de .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-4e935bb .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-1ca942a .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-b3699ef .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-93ee658 .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-7f5b375 .elementor-heading-title{font-size:20px;line-height:20px;}.elementor-11728 .elementor-element.elementor-element-ab44f49{--display:flex;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-7e9180b .elementor-heading-title{font-size:20px;line-height:20px;}.elementor-11728 .elementor-element.elementor-element-88590a7{--display:flex;}.elementor-11728 .elementor-element.elementor-element-474949a .elementor-heading-title{font-size:20px;line-height:20px;}.elementor-11728 .elementor-element.elementor-element-f0a249b{--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-11728 .elementor-element.elementor-element-5a7db7b{--display:flex;--min-height:180px;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--border-radius:20px 20px 20px 20px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-1afb07d{--display:flex;--min-height:200px;--border-radius:20px 20px 0px 0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-bbfbede .elementor-heading-title{font-weight:700;color:var( --e-global-color-text );}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );}.elementor-11728 .elementor-element.elementor-element-51b2359 .elementor-button{background-color:var( --e-global-color-8a2f13f );text-transform:uppercase;fill:var( --e-global-color-secondary );color:var( --e-global-color-secondary );}.elementor-11728 .elementor-element.elementor-element-51b2359 .elementor-button-content-wrapper{flex-direction:row-reverse;}.elementor-11728 .elementor-element.elementor-element-566b006{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-a815a7a{--display:flex;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-bde1d3f .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-bde1d3f .elementor-icon{font-size:25px;}.elementor-11728 .elementor-element.elementor-element-a81e6a9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-65a7e0c .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-65a7e0c .elementor-icon{font-size:25px;}.elementor-11728 .elementor-element.elementor-element-0929690{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-c09179a{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-ea5901e{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-5b5bf19 .elementor-icon-box-wrapper{align-items:start;gap:15px;}.elementor-11728 .elementor-element.elementor-element-5b5bf19 .elementor-icon{font-size:25px;}.elementor-11728 .elementor-element.elementor-element-8fd8d9e{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-8e9c740{--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;--margin-top:0px;--margin-bottom:20px;--margin-left:0px;--margin-right:0px;--padding-top:30px;--padding-bottom:30px;--padding-left:30px;--padding-right:30px;}.elementor-11728 .elementor-element.elementor-element-5d07449{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11728 .elementor-element.elementor-element-650c18f{text-align:start;}.elementor-11728 .elementor-element.elementor-element-650c18f .elementor-heading-title{font-size:20px;line-height:20px;}@media(max-width:1024px){.elementor-11728 .elementor-element.elementor-element-25d63fe{--grid-auto-flow:row;}}@media(min-width:768px){.elementor-11728 .elementor-element.elementor-element-cb5ea22{--content-width:1024px;}.elementor-11728 .elementor-element.elementor-element-7fa064d{--width:25%;}.elementor-11728 .elementor-element.elementor-element-5eae5bc{--width:25%;}.elementor-11728 .elementor-element.elementor-element-ca1621c{--width:25%;}.elementor-11728 .elementor-element.elementor-element-5cbba1d{--width:25%;}.elementor-11728 .elementor-element.elementor-element-eebcc7c{--width:65%;}.elementor-11728 .elementor-element.elementor-element-f0a249b{--width:35%;}}@media(max-width:767px){.elementor-11728 .elementor-element.elementor-element-25d63fe{--e-con-grid-template-columns:repeat(1, 1fr);--grid-auto-flow:row;}}/* Start custom CSS *//* =============================================================
   FICHE SURF CAMP · CSS Customizer · VERSION FINALE v3
   Adapté aux Flexbox Containers Elementor (e-con-boxed / e-con-full)
   Apparence → Personnaliser → CSS additionnel
============================================================= */

:root {
  --navy: #1a2744;
  --navy-dark: #0f1830;
  --gold: #f5a623;
  --gold-light: #fdf3e0;
  --sand: #f9f3e8;
  --ocean: #1a6b9a;
  --green: #25d366;
  --gray-text: #6b7280;
  --border: #dde1e9;
  --shadow-soft: 0 8px 24px rgba(26,39,68,.08);
  --shadow-hover: 0 16px 40px rgba(26,39,68,.18);
}

/* ===========================================================
   HERO · image de fond + overlay + badge + titre + loc
=========================================================== */
.fiche-hero-overlay {
    position: relative;
    border-radius: 20px !important;
    overflow: hidden !important;
    min-height: 460px !important;
}
.fiche-hero-overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15,24,48,.3) 0%, rgba(15,24,48,.92) 100%);
    z-index: 1;
    pointer-events: none;
}
.fiche-hero-overlay > * {
    position: relative;
    z-index: 2;
}

/* Badge "Recommandé" */
.fiche-badge .elementor-widget-container .elementor-heading-title {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    background: var(--gold) !important;
    color: var(--navy) !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    font-size: 12px !important;
    letter-spacing: .15em !important;
    padding: 8px 18px !important;
    border-radius: 50px !important;
    text-transform: uppercase !important;
    width: fit-content;
}

/* H1 titre du camp */
.fiche-hero-title .elementor-heading-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 800 !important;
    font-size: 42px !important;
    line-height: 1.05 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
    margin: 0 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.5);
}

/* Localisation */
.fiche-hero-loc .elementor-heading-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 14px !important;
    color: var(--gold) !important;
    letter-spacing: .2em !important;
    text-transform: uppercase !important;
    margin-top: 14px !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.5);
}

/* ===========================================================
   QUICK STATS BAR · 4 cartes qui débordent sur le hero
=========================================================== */
.quick-stats {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px !important;
    box-shadow: var(--shadow-soft) !important;
    margin-top: -60px !important;
    position: relative;
    z-index: 3;
    padding: 0 !important;
}

.quick-stats-card {
    padding: 22px 16px !important;
    text-align: center !important;
    border-right: 1px solid var(--border);
}
.quick-stats > .e-con-inner > :last-child .quick-stats-card {
    border-right: none;
}

.quick-stats-card .elementor-icon-box-wrapper {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center !important;
}

.quick-stats-card .elementor-icon-box-icon {
    margin: 0 !important;
}

.quick-stats-card .elementor-icon {
    color: var(--gold) !important;
    font-size: 28px !important;
}

/* Title du widget = LABEL (petit gris) */
.quick-stats-card .elementor-icon-box-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 11px !important;
    color: var(--gray-text) !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    margin: 0 0 2px !important;
    line-height: 1.3 !important;
}

/* Description du widget = VALEUR (gros navy) */
.quick-stats-card .elementor-icon-box-description {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    color: var(--navy) !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
}

/* ===========================================================
   LEAD INTRO · description_short · style premium
=========================================================== */
.lead .elementor-widget-container {
    position: relative;
    border-left: 5px solid var(--gold);
    background: linear-gradient(90deg, rgba(245,166,35,.06) 0%, rgba(245,166,35,0) 100%);
    padding: 20px 24px 20px 26px !important;
    border-radius: 0 14px 14px 0;
    font-size: 16px !important;
    line-height: 1.6 !important;
    font-weight: 500 !important;
    color: #2d3748 !important;
    transition: background .3s ease;
}
.lead .elementor-widget-container:hover {
    background: linear-gradient(90deg, rgba(245,166,35,.12) 0%, rgba(245,166,35,0) 100%);
}
.lead p { margin: 0 !important; }
.lead strong { color: var(--navy); }
.lead a {
    color: var(--navy);
    text-decoration: underline;
    text-decoration-color: var(--gold);
    text-underline-offset: 3px;
    font-weight: 600;
}

/* ===========================================================
   H2 MAIN · barre gold à gauche
=========================================================== */
.fiche-h2 .elementor-heading-title {
    position: relative;
    padding-left: 18px !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 800 !important;
    font-size: 24px !important;
    color: var(--navy) !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
    margin-top: 40px !important;
    margin-bottom: 14px !important;
}
.fiche-h2 .elementor-heading-title::before {
    content: '';
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 5px;
    background: var(--gold);
    border-radius: 4px;
}

/* ===========================================================
   INFOS PRATIQUES · 6 cartes icône · style premium
   Contenu centré verticalement, toutes cards à la même hauteur
=========================================================== */
.info-item-card {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    padding: 18px 20px !important;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    position: relative;
    overflow: hidden;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    min-height: 110px;
}
.info-item-card .elementor-widget-container {
    width: 100%;
    display: flex;
    align-items: center;
}
.info-item-card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 3px;
    background: var(--gold);
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform .35s ease;
}
.info-item-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 30px rgba(245,166,35,.18);
    border-color: var(--gold) !important;
}
.info-item-card:hover::before {
    transform: scaleY(1);
    transform-origin: top;
}

.info-item-card .elementor-icon-box-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    text-align: left !important;
}

.info-item-card .elementor-icon-box-icon {
    margin: 0 !important;
    flex-shrink: 0;
}

.info-item-card .elementor-icon {
    width: 44px !important;
    height: 44px !important;
    background: linear-gradient(135deg, var(--gold-light) 0%, #fff2d6 100%) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--navy) !important;
    font-size: 19px !important;
    box-shadow: inset 0 2px 4px rgba(245,166,35,.15);
    transition: transform .3s ease, box-shadow .3s ease;
}
.info-item-card:hover .elementor-icon {
    transform: scale(1.08) rotate(-5deg);
    box-shadow: inset 0 2px 6px rgba(245,166,35,.25), 0 4px 12px rgba(245,166,35,.2);
}

.info-item-card .elementor-icon-box-content {
    text-align: left !important;
}

/* Title = LABEL petit uppercase gris */
.info-item-card .elementor-icon-box-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 11px !important;
    letter-spacing: .15em !important;
    color: var(--gray-text) !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    margin: 0 0 2px !important;
}

/* Description = VALEUR normale bold navy */
.info-item-card .elementor-icon-box-description {
    font-weight: 600 !important;
    color: var(--navy) !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
    font-family: 'Barlow', sans-serif !important;
}

/* ===========================================================
   TABLEAU VAGUES (shortcode [fiche_waves])
=========================================================== */
.table-waves {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 12px 0 24px;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 14px rgba(26,39,68,.06);
}
.table-waves th {
    background: var(--navy);
    color: #fff;
    font-family: 'Barlow Condensed', sans-serif;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: 13px;
    padding: 12px 14px;
    text-align: left;
    font-weight: 700;
}
.table-waves td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    font-size: 15px;
    color: var(--navy);
}
.table-waves tr:last-child td { border-bottom: none; }
.table-waves tr:nth-child(even) td { background: #f8f9fb; }
.table-waves strong { color: var(--navy); font-weight: 700; }

/* ===========================================================
   AVIS BLOCK GOLD · Mot du camp · style premium
=========================================================== */
.avis-block-gold {
    background: linear-gradient(135deg, var(--gold-light) 0%, #fff7e3 60%, #fffdf7 100%) !important;
    border: 1px solid #f1d9a8 !important;
    border-radius: 24px !important;
    padding: 44px 40px 36px !important;
    margin: 36px 0 !important;
    position: relative;
    box-shadow: 0 10px 40px rgba(245,166,35,.12);
    overflow: hidden;
}
.avis-block-gold::before {
    content: '201C';
    position: absolute;
    top: -20px;
    left: 24px;
    font-family: Georgia, serif;
    font-size: 160px;
    line-height: 1;
    color: var(--gold);
    opacity: .3;
    font-weight: 900;
    pointer-events: none;
}
.avis-block-gold::after {
    content: '';
    position: absolute;
    bottom: -60px;
    right: -60px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245,166,35,.15) 0%, transparent 70%);
    pointer-events: none;
}
.avis-block-gold .elementor-widget-text-editor {
    position: relative;
    z-index: 1;
}
.avis-block-gold .elementor-widget-text-editor p {
    font-style: italic !important;
    font-size: 17px !important;
    line-height: 1.6 !important;
    color: var(--navy) !important;
    font-weight: 500 !important;
    margin: 0 !important;
    position: relative;
}

/* Signature avec barre gold avant le nom */
.avis-block-gold .elementor-widget-heading {
    position: relative;
    z-index: 1;
    margin-top: 24px !important;
}
.avis-block-gold .elementor-widget-heading .elementor-heading-title {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin: 0 !important;
    padding-left: 0 !important;
    font-size: 14px !important;
    color: var(--navy) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .1em !important;
    font-family: 'Barlow Condensed', sans-serif !important;
}
.avis-block-gold .elementor-widget-heading .elementor-heading-title::before {
    content: '';
    display: inline-block;
    width: 32px;
    height: 2px;
    background: var(--gold);
    flex-shrink: 0;
}

/* ===========================================================
   FAQ (shortcode [fiche_faq])
=========================================================== */
.faq details {
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 14px 18px;
    margin-bottom: 8px;
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
}
.faq details[open] {
    border-color: var(--gold);
    box-shadow: 0 6px 20px rgba(245,166,35,.15);
}
.faq summary {
    cursor: pointer;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    font-size: 17px;
    color: var(--navy);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
    content: '+';
    color: var(--gold);
    font-size: 24px;
    font-weight: 300;
    line-height: 1;
    flex-shrink: 0;
    transition: transform .2s;
}
.faq details[open] summary::after {
    content: '−';
}
.faq details p {
    margin-top: 10px !important;
    font-size: 16px;
    line-height: 1.6;
    color: #444;
}
.faq details a {
    color: var(--navy);
    text-decoration: underline;
    text-decoration-color: var(--gold);
}

/* ===========================================================
   WIDGET GUIDE · sidebar
=========================================================== */
.sidebar-guide-elem {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    padding: 0 !important;
    box-shadow: var(--shadow-soft);
    transition: box-shadow .3s ease, transform .3s ease;
    cursor: pointer;
}
.sidebar-guide-elem:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-4px);
}

.sidebar-guide-elem .elementor-widget-image,
.sidebar-guide-elem .elementor-widget-shortcode {
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
}
.sidebar-guide-elem .elementor-widget-image img,
.sidebar-guide-elem .guide-image-auto {
    width: 100% !important;
    height: 200px !important;
    object-fit: cover !important;
    display: block;
    transition: transform .6s ease;
}
.sidebar-guide-elem:hover .elementor-widget-image img,
.sidebar-guide-elem:hover .guide-image-auto {
    transform: scale(1.06);
}

.sidebar-guide-elem .elementor-widget-heading,
.sidebar-guide-elem .elementor-widget-text-editor,
.sidebar-guide-elem .elementor-widget-button,
.sidebar-guide-elem .elementor-widget-icon-list {
    padding-left: 22px !important;
    padding-right: 22px !important;
}
.sidebar-guide-elem > :nth-child(2) { padding-top: 18px !important; }
.sidebar-guide-elem > :last-child { padding-bottom: 22px !important; }

.sidebar-guide-elem .elementor-heading-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 800 !important;
    font-size: 19px !important;
    color: var(--navy) !important;
    line-height: 1.25 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 0 8px !important;
}
.sidebar-guide-elem .elementor-widget-text-editor p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: var(--gray-text) !important;
    margin: 0 0 14px !important;
}
.sidebar-guide-elem .elementor-button {
    background: transparent !important;
    color: var(--navy) !important;
    padding: 0 0 3px 0 !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    border: none !important;
    border-bottom: 2px solid var(--gold) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    width: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: color .2s ease, letter-spacing .3s ease;
}
.sidebar-guide-elem:hover .elementor-button {
    color: var(--gold) !important;
    letter-spacing: .12em !important;
}
.sidebar-guide-elem .elementor-button-icon { transition: transform .3s ease; }
.sidebar-guide-elem:hover .elementor-button-icon { transform: translateX(4px); }
.sidebar-guide-elem .elementor-button-wrapper { text-align: left !important; }

/* ===========================================================
   CTA ICON BOX · Réserver site officiel (gold)
=========================================================== */
.cta-btn-site {
    border-radius: 12px !important;
    box-shadow: 0 4px 14px rgba(26,39,68,.1);
    transition: transform .2s, box-shadow .2s, filter .2s;
    overflow: hidden;
}
.cta-btn-site:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(26,39,68,.16);
    filter: brightness(1.05);
}
.cta-btn-site .elementor-widget-icon-box {
    background: var(--gold) !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
}
.cta-btn-site .elementor-icon-box-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    text-align: left !important;
}
.cta-btn-site .elementor-icon-box-icon { margin: 0 !important; flex-shrink: 0; }
.cta-btn-site .elementor-icon { color: var(--navy) !important; font-size: 24px !important; }
.cta-btn-site .elementor-icon-box-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    color: var(--navy) !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.2;
}
.cta-btn-site .elementor-icon-box-title a { color: var(--navy) !important; text-decoration: none !important; }
.cta-btn-site .elementor-icon-box-description {
    font-family: 'Barlow', sans-serif !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    color: var(--navy-dark) !important;
    margin: 2px 0 0 !important;
    opacity: 1 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

/* ===========================================================
   CTA ICON BOX · WhatsApp (vert)
=========================================================== */
.cta-btn-whatsapp {
    border-radius: 12px !important;
    box-shadow: 0 4px 14px rgba(26,39,68,.1);
    transition: transform .2s, box-shadow .2s, filter .2s;
    overflow: hidden;
}
.cta-btn-whatsapp:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(26,39,68,.16);
    filter: brightness(1.05);
}
.cta-btn-whatsapp .elementor-widget-icon-box {
    background: var(--green) !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
}
.cta-btn-whatsapp .elementor-icon-box-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    text-align: left !important;
}
.cta-btn-whatsapp .elementor-icon-box-icon { margin: 0 !important; flex-shrink: 0; }
.cta-btn-whatsapp .elementor-icon { color: #fff !important; font-size: 26px !important; }
.cta-btn-whatsapp .elementor-icon-box-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    font-size: 17px !important;
    color: #fff !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.2;
}
.cta-btn-whatsapp .elementor-icon-box-title a { color: #fff !important; text-decoration: none !important; }
.cta-btn-whatsapp .elementor-icon-box-description {
    font-family: 'Barlow', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    color: #fff !important;
    margin: 2px 0 0 !important;
    opacity: .9;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

/* ===========================================================
   CTA ICON BOX · Besoin d'un conseil (outline navy)
=========================================================== */
.cta-btn-contact {
    border-radius: 12px !important;
    transition: transform .2s, box-shadow .2s;
    overflow: hidden;
}
.cta-btn-contact:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(26,39,68,.1);
}
.cta-btn-contact .elementor-widget-icon-box {
    background: #fff !important;
    border: 2px solid var(--navy) !important;
    border-radius: 12px !important;
    padding: 14px 18px !important;
    transition: background .2s;
}
.cta-btn-contact:hover .elementor-widget-icon-box {
    background: var(--gold-light) !important;
}
.cta-btn-contact .elementor-icon-box-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    text-align: left !important;
}
.cta-btn-contact .elementor-icon-box-icon { margin: 0 !important; flex-shrink: 0; }
.cta-btn-contact .elementor-icon { color: var(--navy) !important; font-size: 22px !important; }
.cta-btn-contact .elementor-icon-box-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    color: var(--navy) !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.2;
}
.cta-btn-contact .elementor-icon-box-title a { color: var(--navy) !important; text-decoration: none !important; }
.cta-btn-contact .elementor-icon-box-description {
    font-family: 'Barlow', sans-serif !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    color: var(--navy) !important;
    margin: 2px 0 0 !important;
    opacity: .75;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

/* ===========================================================
   NOTE GOOGLE PILL (shortcode)
=========================================================== */
.google-rating-pill-link {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: #fff !important;
    border: 1px solid var(--border);
    border-radius: 50px;
    font-size: 14px;
    text-decoration: none !important;
    color: var(--gray-text) !important;
    transition: border-color .2s;
    font-family: 'Barlow', sans-serif;
}
.google-rating-pill-link:hover { border-color: var(--gold); }
.google-rating-pill-link .gr-star { color: var(--gold); font-size: 16px; }
.google-rating-pill-link strong { color: var(--navy); font-size: 15px; }
.google-rating-pill-link .gr-count { color: var(--gray-text); }

/* ===========================================================
   TRUST BADGE sans commission
=========================================================== */
.trust-badge-elem .elementor-widget-container {
    background: #e8f5ee !important;
    border: 1px solid #b7e3c6 !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    font-size: 13px !important;
    color: #1a5530 !important;
    line-height: 1.4;
}
.trust-badge-elem p {
    margin: 0 !important;
    color: #1a5530 !important;
}

/* ===========================================================
   ENCART CHAPKA · wrapper + contenu
=========================================================== */
.sidebar-chapka-wrap {
    background: linear-gradient(135deg, #eef5ff 0%, #fff 100%) !important;
    border: 1px solid #d0e2f5 !important;
    border-radius: 16px !important;
    padding: 24px 22px !important;
}
.sidebar-chapka-wrap .chapka-content {
    text-align: center;
}
.sidebar-chapka-wrap .chapka-badge {
    display: inline-block;
    background: var(--ocean);
    color: #fff;
    padding: 5px 12px;
    border-radius: 50px;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.sidebar-chapka-wrap .chapka-icon {
    display: flex;
    justify-content: center;
    margin-bottom: 8px;
    color: var(--ocean);
}
.sidebar-chapka-wrap h3 {
    margin: 0 0 10px !important;
    font-size: 19px !important;
    color: var(--navy) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
    font-family: 'Barlow Condensed', sans-serif !important;
}
.sidebar-chapka-wrap p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: var(--gray-text) !important;
    margin: 0 0 10px !important;
}
.sidebar-chapka-wrap .chapka-price {
    color: var(--navy) !important;
    font-size: 15px !important;
    margin: 12px 0 16px !important;
}
.sidebar-chapka-wrap .chapka-price strong {
    font-size: 22px !important;
    color: var(--ocean) !important;
    font-family: 'Barlow Condensed', sans-serif !important;
}
.sidebar-chapka-wrap .chapka-btn {
    display: block;
    background: var(--ocean) !important;
    color: #fff !important;
    padding: 13px 16px;
    border-radius: 10px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    font-size: 15px;
    text-transform: uppercase;
    letter-spacing: .08em;
    text-decoration: none !important;
    transition: background .2s, transform .2s;
    margin-bottom: 12px;
}
.sidebar-chapka-wrap .chapka-btn:hover {
    background: var(--navy) !important;
    transform: translateY(-2px);
}
.sidebar-chapka-wrap .chapka-partner {
    font-size: 11px !important;
    color: var(--gray-text) !important;
    font-style: italic !important;
    margin: 0 !important;
}

/* ===========================================================
   SECTION RELATED · "Pour préparer ton séjour surf"
=========================================================== */
.related-section {
    background: linear-gradient(135deg, var(--sand) 0%, var(--gold-light) 100%) !important;
    border-radius: 24px !important;
    padding: 44px 44px 48px !important;
    margin-top: 56px !important;
}
.related-section .elementor-heading-title {
    margin: 0 0 28px !important;
    padding-left: 0 !important;
    color: var(--navy) !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    text-transform: uppercase !important;
    font-size: 26px !important;
    letter-spacing: .02em !important;
}
.related-section .elementor-heading-title::before { display: none !important; }

.related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    margin-top: 8px;
}
.related-card {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #fff;
    padding: 20px 22px;
    border-radius: 14px;
    text-decoration: none !important;
    color: var(--navy) !important;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    font-size: 15px;
    line-height: 1.3;
    border: 1px solid transparent;
    box-shadow: 0 2px 8px rgba(26,39,68,.04);
    transition: border-color .25s, transform .25s, box-shadow .25s;
    min-height: 72px;
}
.related-card:hover {
    border-color: var(--gold);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(26,39,68,.08);
    color: var(--gold) !important;
}
.related-card svg { flex-shrink: 0; color: var(--gold); }
.related-card span { flex: 1; }

/* ===========================================================
   TOUCHES FINALES · micro-interactions premium
=========================================================== */

/* H2 main · animation subtile de la barre gold */
.fiche-h2 .elementor-heading-title::before {
    transition: height .3s ease, top .3s ease, bottom .3s ease;
}
.fiche-h2:hover .elementor-heading-title::before {
    top: 0 !important;
    bottom: 0 !important;
}

/* Description longue · typographie uniforme · 15px line-height 1.7 */
.elementor-widget-text-editor:not(.lead):not([class*="avis"]) .elementor-widget-container {
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #2d3748 !important;
    font-family: 'Barlow', sans-serif !important;
}
.elementor-widget-text-editor:not(.lead):not([class*="avis"]) p {
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #2d3748 !important;
    margin: 0 0 16px !important;
    font-family: 'Barlow', sans-serif !important;
}
.elementor-widget-text-editor:not(.lead):not([class*="avis"]) p:last-child {
    margin-bottom: 0 !important;
}

/* H3 à l'intérieur de description longue · style éditorial cohérent */
.elementor-widget-text-editor h3 {
    color: var(--navy) !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
    margin-top: 28px !important;
    margin-bottom: 12px !important;
    font-size: 19px !important;
    line-height: 1.2 !important;
}
.elementor-widget-text-editor h3:first-child { margin-top: 0 !important; }

/* Listes dans les descriptions */
.elementor-widget-text-editor ul,
.elementor-widget-text-editor ol {
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #2d3748 !important;
    padding-left: 22px !important;
    margin: 0 0 16px !important;
}
.elementor-widget-text-editor li {
    margin-bottom: 8px !important;
    font-family: 'Barlow', sans-serif !important;
}

/* Gras et italique dans les descriptions */
.elementor-widget-text-editor strong { color: var(--navy); font-weight: 700; }
.elementor-widget-text-editor em { color: var(--navy); font-style: italic; }

/* Liens dans les descriptions */
.elementor-widget-text-editor a {
    color: var(--navy);
    text-decoration: underline;
    text-decoration-color: var(--gold);
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
    font-weight: 600;
    transition: color .2s;
}
.elementor-widget-text-editor a:hover {
    color: var(--gold);
}

/* Badge Hero · micro-bounce au hover */
.fiche-badge .elementor-widget-container .elementor-heading-title {
    transition: transform .3s ease, box-shadow .3s ease;
    box-shadow: 0 4px 14px rgba(245,166,35,.35);
}
.fiche-badge:hover .elementor-heading-title {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 8px 20px rgba(245,166,35,.45);
}

/* Related cards · flèche qui bouge au hover */
.related-card::after {
    content: '';
    width: 0;
    overflow: hidden;
    transition: width .3s ease, margin-left .3s ease;
}
.related-card:hover svg {
    transform: translateX(4px);
    transition: transform .3s ease;
}
.related-card svg {
    transition: transform .3s ease;
}

/* Scroll smooth sur toute la page */
html { scroll-behavior: smooth; }

/* ===========================================================
   RESPONSIVE · tablette et mobile
=========================================================== */

/* ---------- Tablette paysage / petit desktop (≤ 1024px) --- */
@media (max-width: 1024px) {
    .fiche-hero-title .elementor-heading-title { font-size: 36px !important; }
    .fiche-hero-overlay { padding: 40px 32px !important; min-height: 400px !important; }
    .quick-stats { margin-top: -40px !important; }
    .fiche-h2 .elementor-heading-title { font-size: 22px !important; }
    .avis-block-gold { padding: 36px 30px 28px !important; }
    .related-section { padding: 36px 32px 40px !important; }
}

/* ---------- Tablette portrait (≤ 900px) ------------------- */
@media (max-width: 900px) {
    /* Hero compact */
    .fiche-hero-title .elementor-heading-title { font-size: 30px !important; }
    .fiche-hero-overlay { min-height: 340px !important; padding: 30px 24px !important; }
    .fiche-hero-loc .elementor-heading-title { font-size: 12px !important; margin-top: 10px !important; }
    .fiche-badge .elementor-widget-container .elementor-heading-title { font-size: 11px !important; padding: 6px 14px !important; }

    /* Quick stats : 2 colonnes */
    .quick-stats { margin: -30px 12px 32px !important; }
    .quick-stats-card { padding: 16px 12px !important; border-right: none !important; border-bottom: 1px solid var(--border); }
    .quick-stats-card:nth-last-child(-n+2) { border-bottom: none; }

    /* Infos pratiques : 1 colonne */
    .info-item-card { min-height: auto; padding: 14px 16px !important; }

    /* Bloc avis */
    .avis-block-gold { padding: 28px 22px 24px !important; margin: 28px 0 !important; }
    .avis-block-gold::before { font-size: 110px; top: -10px; left: 16px; }
    .avis-block-gold .elementor-widget-text-editor p { font-size: 15px !important; }

    /* Related section */
    .related-section { padding: 28px 22px 32px !important; margin-top: 36px !important; }
    .related-section .elementor-heading-title { font-size: 20px !important; margin-bottom: 20px !important; }
    .related-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
    .related-card { padding: 16px 18px; min-height: 64px; font-size: 14px; }

    /* Sidebar devient full width */
    .sidebar-guide-elem .elementor-widget-image img,
    .sidebar-guide-elem .guide-image-auto { height: 180px !important; }
}

/* ---------- Mobile (≤ 700px) ------------------------------ */
@media (max-width: 700px) {
    /* Hero très compact */
    .fiche-hero-title .elementor-heading-title { font-size: 26px !important; line-height: 1.1 !important; }
    .fiche-hero-overlay { min-height: 300px !important; padding: 24px 18px !important; border-radius: 14px !important; }
    .fiche-hero-loc .elementor-heading-title { font-size: 11px !important; letter-spacing: .15em !important; }

    /* H2 plus petit */
    .fiche-h2 .elementor-heading-title { font-size: 20px !important; margin-top: 30px !important; padding-left: 14px !important; }
    .fiche-h2 .elementor-heading-title::before { width: 4px; top: 4px; bottom: 4px; }

    /* H3 interne */
    .elementor-widget-text-editor h3 { font-size: 17px !important; margin-top: 24px !important; }

    /* Lead intro compact */
    .lead .elementor-widget-container { padding: 16px 18px 16px 20px !important; font-size: 15px !important; }

    /* Description longue */
    .elementor-widget-text-editor:not(.lead):not([class*="avis"]) p { font-size: 14px !important; line-height: 1.65 !important; margin-bottom: 14px !important; }

    /* Quick stats : 2 colonnes plus serrées */
    .quick-stats { margin: -20px 10px 28px !important; border-radius: 12px !important; }
    .quick-stats-card { padding: 14px 10px !important; }
    .quick-stats-card .elementor-icon-box-title { font-size: 10px !important; letter-spacing: .15em !important; }
    .quick-stats-card .elementor-icon-box-description { font-size: 13px !important; }
    .quick-stats-card .elementor-icon { font-size: 22px !important; }

    /* Infos pratiques · 1 colonne */
    .info-item-card { border-radius: 10px !important; padding: 12px 14px !important; }
    .info-item-card .elementor-icon { width: 36px !important; height: 36px !important; font-size: 16px !important; }
    .info-item-card .elementor-icon-box-title { font-size: 10px !important; }
    .info-item-card .elementor-icon-box-description { font-size: 13px !important; }
    .info-item-card .elementor-icon-box-wrapper { gap: 10px !important; }

    /* CTA Icon Box · pleine largeur et plus compacts */
    .cta-btn-site .elementor-widget-icon-box,
    .cta-btn-whatsapp .elementor-widget-icon-box,
    .cta-btn-contact .elementor-widget-icon-box {
        padding: 14px 16px !important;
    }
    .cta-btn-site .elementor-icon-box-title,
    .cta-btn-whatsapp .elementor-icon-box-title,
    .cta-btn-contact .elementor-icon-box-title { font-size: 14px !important; }
    .cta-btn-site .elementor-icon-box-description,
    .cta-btn-whatsapp .elementor-icon-box-description,
    .cta-btn-contact .elementor-icon-box-description { font-size: 12px !important; }
    .cta-btn-site .elementor-icon { font-size: 20px !important; }
    .cta-btn-whatsapp .elementor-icon { font-size: 22px !important; }
    .cta-btn-contact .elementor-icon { font-size: 18px !important; }

    /* Widget guide sidebar */
    .sidebar-guide-elem .elementor-widget-image img,
    .sidebar-guide-elem .guide-image-auto { height: 160px !important; }
    .sidebar-guide-elem .elementor-heading-title { font-size: 16px !important; }
    .sidebar-guide-elem .elementor-widget-text-editor p { font-size: 13px !important; }

    /* Encart Chapka */
    .sidebar-chapka-wrap { padding: 20px 18px !important; }
    .sidebar-chapka-wrap h3 { font-size: 17px !important; }
    .sidebar-chapka-wrap p { font-size: 13px !important; }
    .sidebar-chapka-wrap .chapka-price strong { font-size: 20px !important; }

    /* Note Google pill */
    .google-rating-pill-link { font-size: 12px !important; padding: 8px 14px !important; }
    .google-rating-pill-link strong { font-size: 13px !important; }

    /* Avis block · compact */
    .avis-block-gold { padding: 24px 18px 20px !important; border-radius: 16px !important; margin: 24px 0 !important; }
    .avis-block-gold::before { font-size: 90px; top: -8px; left: 12px; }
    .avis-block-gold .elementor-widget-text-editor p { font-size: 14px !important; line-height: 1.5 !important; }
    .avis-block-gold .elementor-widget-heading .elementor-heading-title { font-size: 12px !important; }

    /* FAQ */
    .faq details { padding: 12px 14px; }
    .faq summary { font-size: 14px !important; gap: 10px; }
    .faq summary::after { font-size: 20px; }
    .faq details p { font-size: 14px; line-height: 1.55; margin-top: 8px !important; }

    /* Tableau vagues · scroll horizontal sur mobile */
    .table-waves { font-size: 12px; display: block; overflow-x: auto; white-space: nowrap; }
    .table-waves thead, .table-waves tbody, .table-waves tr { display: table; width: 100%; table-layout: fixed; }
    .table-waves th, .table-waves td { padding: 8px 10px; white-space: normal; }
    .table-waves th { font-size: 11px; }

    /* Related section */
    .related-section { padding: 22px 18px 26px !important; border-radius: 16px !important; margin-top: 28px !important; }
    .related-section .elementor-heading-title { font-size: 18px !important; margin-bottom: 16px !important; }
    .related-grid { grid-template-columns: 1fr; gap: 12px; }
    .related-card { padding: 14px 16px; min-height: auto; font-size: 14px; }

    /* Trust badge */
    .trust-badge-elem .elementor-widget-container { padding: 10px 12px !important; font-size: 12px !important; }
}

/* ---------- Petit mobile (≤ 420px) ------------------------ */
@media (max-width: 420px) {
    .fiche-hero-title .elementor-heading-title { font-size: 22px !important; }
    .fiche-h2 .elementor-heading-title { font-size: 18px !important; }
    .quick-stats { margin: -16px 8px 24px !important; }
    .quick-stats-card .elementor-icon-box-description { font-size: 12px !important; }
    .info-item-card .elementor-icon-box-description { font-size: 12px !important; }
    .sidebar-guide-elem .elementor-widget-image img,
    .sidebar-guide-elem .guide-image-auto { height: 140px !important; }
}/* End custom CSS */