/* ================================================================
   Ô VIEUX MOULIN — FEUILLE DE STYLE PRINCIPALE
   ================================================================
   
   📝 POUR MODIFIER LE SITE :
   - Couleurs : changez les valeurs dans la section :root ci-dessous
   - Polices  : modifiez --font-display et --font-body
   - Ce fichier est partagé par TOUTES les pages
   
================================================================ */

:root {
  /* === COULEURS (modifiez ici pour tout le site) === */
  --cream: #F5EDE3;
  --cream-light: #FAF6F1;
  --cream-dark: #E8DDD1;
  --rose: #C4A08A;
  --rose-light: #D4B8A6;
  --rose-dark: #A88470;
  --charcoal: #333333;
  --charcoal-light: #555555;
  --teal: #4BAFA4;
  --teal-dark: #3D9990;
  --teal-light: #6BC4BB;
  --black: #1A1A1A;
  --white: #FFFFFF;
  --off-white: #FDFBF8;
  --grey-mid: #999999;
  /* === POLICES === */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Lato', 'Helvetica Neue', Arial, sans-serif;
  --section-pad: clamp(4rem, 8vw, 7rem);
  --radius: 12px;
  --radius-lg: 20px;
}

/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);color:var(--charcoal);background:var(--off-white);line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.25;color:var(--charcoal)}
.container{max-width:1200px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem)}

/* ================================================================
   BARRE SUPÉRIEURE
================================================================ */
.top-bar{background:var(--charcoal);color:var(--white);font-size:.82rem;padding:.45rem 2.5rem;display:flex;justify-content:space-between;align-items:center}
.top-bar a{color:var(--white);transition:opacity .3s}
.top-bar a:hover{opacity:.8}
.top-bar-right{display:flex;gap:1rem}
.top-bar-right a{opacity:.7}

/* ================================================================
   NAVIGATION
================================================================ */
.nav-main{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.06);transition:box-shadow .4s}
.nav-main.shadow{box-shadow:0 2px 30px rgba(0,0,0,.06)}
.nav-inner{display:flex;justify-content:space-between;align-items:center;padding:.6rem 2.5rem;max-width:1400px;margin:0 auto}
.nav-logo{display:flex;align-items:center;gap:.8rem}
.nav-logo-icon{width:48px;height:48px}
.nav-logo-icon img{width:100%;height:100%;object-fit:contain}
.nav-logo-name{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--charcoal);line-height:1.2;letter-spacing:.02em}
.nav-logo-sub{font-size:.68rem;color:var(--grey-mid);letter-spacing:.06em;text-transform:uppercase}
.nav-links{display:flex;align-items:center}
.nav-links a{padding:.5rem 1rem;font-size:.85rem;font-weight:700;color:var(--charcoal);transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:0;left:1rem;right:1rem;height:2px;background:var(--teal);transform:scaleX(0);transition:transform .3s}
.nav-links a:hover{color:var(--teal)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a.active{color:var(--teal)}
.nav-links a.active::after{transform:scaleX(1)}
.nav-cta-btn{margin-left:.8rem;background:var(--teal)!important;color:var(--white)!important;padding:.55rem 1.4rem!important;border-radius:50px;font-weight:700!important;font-size:.82rem!important;transition:all .3s!important}
.nav-cta-btn:hover{background:var(--teal-dark)!important;transform:translateY(-1px)}
.nav-cta-btn::after{display:none!important}

/* Mobile */
.mobile-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.mobile-toggle span{width:22px;height:2px;background:var(--charcoal);border-radius:2px;transition:all .3s}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--white);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-display);font-size:1.4rem;color:var(--charcoal);padding:.5rem 1rem}
.mobile-menu-close{position:absolute;top:1.5rem;right:1.5rem;font-size:1.8rem;cursor:pointer;color:var(--charcoal);background:none;border:none}

/* ================================================================
   BOUTONS
================================================================ */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;border-radius:50px;font-family:var(--font-body);font-size:.88rem;font-weight:700;cursor:pointer;border:none;transition:all .35s cubic-bezier(.16,1,.3,1);letter-spacing:.02em}
.btn-teal{background:var(--teal);color:var(--white)}
.btn-teal:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(75,175,164,.25)}
.btn-dark{background:var(--charcoal);color:var(--white)}
.btn-dark:hover{background:var(--black);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--charcoal);border:2px solid var(--charcoal)}
.btn-outline:hover{background:var(--charcoal);color:var(--white)}
.btn-white{background:var(--white);color:var(--charcoal);padding:.9rem 2rem;border-radius:50px;font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.15)}
.btn-black{background:var(--charcoal);color:var(--white);padding:.9rem 2rem;border-radius:50px;font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s}
.btn-black:hover{background:var(--black);transform:translateY(-2px)}

/* ================================================================
   ÉLÉMENTS COMMUNS
================================================================ */
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:1rem}
.section-label::before{content:'';width:28px;height:2px;background:var(--teal);border-radius:2px}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.6rem;letter-spacing:-.02em}
.section-header p{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--charcoal-light);max-width:500px;margin:0 auto}

/* ================================================================
   HERO (page d'accueil)
================================================================ */
.hero{position:relative;height:92vh;min-height:600px;max-height:900px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 60%}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.55) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;color:var(--white);max-width:850px;padding:0 2rem}
.hero h1{font-size:clamp(2.5rem,5.5vw,4rem);font-weight:500;color:var(--white);margin-bottom:.3rem;letter-spacing:-.02em;text-shadow:0 2px 30px rgba(0,0,0,.2)}
.hero h2{font-family:var(--font-display);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:400;font-style:italic;color:var(--white);opacity:.92;margin-bottom:2rem}
.hero-tagline{font-size:1.05rem;font-weight:300;opacity:.88;margin-bottom:2.5rem;max-width:550px;margin-left:auto;margin-right:auto;line-height:1.6}
.hero-no-photo{background:linear-gradient(135deg,#5a7a50 0%,#6d8e5a 30%,#7a9b68 60%,#5f8050 100%)}

/* Booking bar */
.booking-bar{display:flex;align-items:center;background:rgba(255,255,255,.97);backdrop-filter:blur(15px);border-radius:var(--radius);overflow:hidden;box-shadow:0 15px 50px rgba(0,0,0,.15);max-width:750px;margin:0 auto}
.booking-field{flex:1;padding:1rem 1.3rem;border-right:1px solid var(--cream-dark)}
.booking-field-label{display:block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--grey-mid);margin-bottom:.3rem}
.booking-field-value{font-size:.95rem;color:var(--charcoal)}
.booking-field-small{flex:0 0 80px;text-align:center}
.booking-btn{background:var(--teal);color:var(--white);border:none;padding:1.2rem 2rem;font-family:var(--font-body);font-size:.9rem;font-weight:700;cursor:pointer;transition:background .3s;white-space:nowrap}
.booking-btn:hover{background:var(--teal-dark)}

/* ================================================================
   SECTION INTRO (Bienvenue)
================================================================ */
.intro{padding:var(--section-pad) 0;background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.intro-img-wrap{position:relative}
.intro-img{width:100%;border-radius:var(--radius-lg);display:block}
.intro-badge{position:absolute;bottom:-16px;right:20px;background:var(--white);border-radius:var(--radius);padding:1rem 1.3rem;box-shadow:0 10px 40px rgba(0,0,0,.08);display:flex;align-items:center;gap:.8rem}
.intro-badge-icon{width:44px;height:44px;background:var(--teal);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--white)}
.intro-badge-text strong{display:block;font-size:.88rem}
.intro-badge-text span{font-size:.78rem;color:var(--grey-mid)}
.intro-text h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:1.2rem}
.intro-text h2 em{font-style:italic;color:var(--rose-dark)}
.intro-text p{font-size:1rem;color:var(--charcoal-light);margin-bottom:1rem;max-width:500px}
.intro-features{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:2rem}
.intro-feat{display:flex;gap:.7rem;align-items:flex-start;padding:.9rem;background:rgba(255,255,255,.6);border-radius:10px;transition:all .3s}
.intro-feat:hover{background:var(--white);box-shadow:0 3px 15px rgba(0,0,0,.04)}
.intro-feat-icon{font-size:1.3rem;flex-shrink:0;margin-top:1px}
.intro-feat h4{font-family:var(--font-body);font-size:.88rem;font-weight:700;margin-bottom:.15rem}
.intro-feat p{font-size:.78rem;color:var(--grey-mid);margin:0;line-height:1.4}

/* ================================================================
   CARTES CHAMBRES (page accueil)
================================================================ */
.chambres{padding:var(--section-pad) 0;background:var(--off-white)}
.chambres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.chambre-card{background:var(--cream);border-radius:var(--radius-lg);overflow:hidden;transition:all .45s cubic-bezier(.16,1,.3,1)}
.chambre-card:hover{transform:translateY(-6px);box-shadow:0 18px 50px rgba(0,0,0,.1)}
.chambre-card-img{aspect-ratio:3/2;overflow:hidden;position:relative}
.chambre-card-img img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .5s}
.chambre-card:hover .chambre-card-img img{transform:scale(1.05)}
.chambre-tag{position:absolute;top:.9rem;left:.9rem;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);padding:.3rem .7rem;border-radius:50px;font-size:.7rem;font-weight:700;color:var(--charcoal)}
.chambre-card-info{padding:1.6rem}
.chambre-card-info h3{font-size:1.35rem;margin-bottom:.4rem}
.chambre-card-desc{font-family:var(--font-display);font-style:italic;font-size:.95rem;color:var(--charcoal-light);margin-bottom:1rem}
.chambre-equip{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.3rem}
.chambre-equip span{display:inline-flex;align-items:center;gap:.3rem;background:rgba(255,255,255,.65);padding:.3rem .6rem;border-radius:50px;font-size:.72rem;color:var(--charcoal-light)}
.chambre-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--cream-dark)}
.chambre-price{font-family:var(--font-display);font-size:1.35rem;font-weight:600;color:var(--rose-dark)}
.chambre-price span{font-size:.78rem;font-weight:400;color:var(--grey-mid)}
.chambre-link{font-size:.82rem;font-weight:700;color:var(--teal);display:inline-flex;align-items:center;gap:.3rem;transition:gap .3s}
.chambre-link:hover{gap:.6rem}

/* ================================================================
   CHAMBRES DÉTAIL (page chambres)
================================================================ */
.page-hero{background:var(--charcoal);padding:clamp(3rem,6vw,5rem) 0;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(75,175,164,.1) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(196,160,138,.08) 0%,transparent 50%)}
.page-hero>*{position:relative;z-index:1}
.breadcrumb{font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:1rem}
.breadcrumb a{color:rgba(255,255,255,.5)}
.breadcrumb a:hover{color:var(--white)}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);color:var(--white);margin-bottom:.5rem}
.page-hero>p,.page-hero .page-hero-sub{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:rgba(255,255,255,.7);max-width:550px;margin:0 auto}

.maison-intro{padding:var(--section-pad) 0;background:var(--cream)}
.maison-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.maison-intro-img{width:100%;border-radius:var(--radius-lg);overflow:hidden;object-fit:cover}
.maison-infos{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.maison-info-card{background:var(--white);border-radius:var(--radius);padding:1.2rem;text-align:center;transition:all .3s}
.maison-info-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.05)}
.maison-info-icon{font-size:1.5rem;margin-bottom:.4rem}
.maison-info-card h4{font-family:var(--font-body);font-size:.85rem;font-weight:700;margin-bottom:.15rem}
.maison-info-card p{font-size:.78rem;color:var(--grey-mid);margin:0}

.chambre-section{padding:var(--section-pad) 0;scroll-margin-top:80px}
.chambre-section:nth-child(odd){background:var(--off-white)}
.chambre-section:nth-child(even){background:var(--cream)}
.chambre-detail-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.chambre-section.reverse .chambre-detail-grid{grid-template-columns:1fr 1.15fr}
.chambre-gallery-main{width:100%;border-radius:var(--radius-lg);overflow:hidden}
.chambre-gallery-main img{width:100%;display:block}
.chambre-gallery-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.5rem}
.chambre-gallery-thumbs img{border-radius:8px;object-fit:cover;cursor:pointer;transition:all .3s;width:100%;display:block}
.chambre-gallery-thumbs img:hover{opacity:.85;transform:scale(1.03)}
/* Lightbox */
.lightbox-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);align-items:center;justify-content:center;cursor:zoom-out}
.lightbox-overlay.active{display:flex}
.lightbox-overlay img{max-width:90vw;max-height:90vh;border-radius:12px;object-fit:contain;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-close{position:absolute;top:1.5rem;right:2rem;color:white;font-size:2rem;cursor:pointer;background:none;border:none;z-index:10000}
.chambre-tag-pill{display:inline-block;background:var(--teal);color:var(--white);font-size:.68rem;font-weight:700;padding:.25rem .7rem;border-radius:50px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.8rem}
.chambre-detail-info h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.5rem}
.chambre-tagline{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--charcoal-light);margin-bottom:1.5rem}
.chambre-detail-info>p{font-size:.95rem;color:var(--charcoal-light);margin-bottom:1rem;line-height:1.7}
.equip-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin:1.5rem 0}
.equip-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;padding:.6rem .8rem;background:rgba(245,237,227,.5);border-radius:8px}
.equip-icon{font-size:1.1rem;flex-shrink:0}
.chambre-cta-row{display:flex;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--cream-dark);flex-wrap:wrap}
.chambre-prix{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--rose-dark)}
.chambre-prix span{font-size:.85rem;font-weight:400;color:var(--grey-mid)}
.chambre-prix-note{font-size:.78rem;color:var(--teal);font-weight:700}

/* ================================================================
   ESPACES PARTAGÉS (fond sombre)
================================================================ */
.espaces{padding:var(--section-pad) 0;background:var(--charcoal);color:var(--white);position:relative;overflow:hidden}
.espaces::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 40%,rgba(75,175,164,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(196,160,138,.06) 0%,transparent 50%)}
.espaces>*{position:relative;z-index:1}
.espaces .section-header h2{color:var(--white)}
.espaces .section-header p{color:rgba(255,255,255,.55)}
.espaces .section-label{color:var(--teal-light)}
.espaces .section-label::before{background:var(--teal-light)}
.espaces-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.espace-card{display:flex;gap:1.3rem;padding:1.8rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);transition:all .35s}
.espace-card:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);transform:translateY(-3px)}
.espace-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;background:rgba(75,175,164,.12)}
.espace-card h3{font-size:1.1rem;color:var(--cream);margin-bottom:.4rem}
.espace-card p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.55}

.espaces-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}
.espace-photo{border-radius:var(--radius);overflow:hidden;position:relative}
.espace-photo img{width:100%;height:250px;object-fit:cover;display:block}
.espace-photo-label{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.55));color:var(--white);font-size:.85rem;font-weight:700}
.espaces-features{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.espace-feat{text-align:center;padding:1.5rem 1rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);transition:all .3s}
.espace-feat:hover{background:rgba(255,255,255,.08)}
.espace-feat-icon{font-size:1.8rem;margin-bottom:.5rem}
.espace-feat h4{font-size:.92rem;color:var(--cream);margin-bottom:.2rem}
.espace-feat p{font-size:.78rem;color:rgba(255,255,255,.5)}

/* ================================================================
   GALERIE
================================================================ */
.galerie{padding:var(--section-pad) 0;background:var(--cream)}
.galerie-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.galerie-item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;transition:transform .4s}
.galerie-item img{width:100%;height:260px;object-fit:cover;display:block;border-radius:var(--radius)}
.galerie-item:hover{transform:scale(1.02)}
.galerie-item:hover img{opacity:.92}
.galerie-label{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(transparent,rgba(0,0,0,.5));color:var(--white);font-size:.85rem;font-weight:700}

/* ================================================================
   PETIT-DÉJEUNER
================================================================ */
.petitdej{padding:var(--section-pad) 0;background:var(--off-white)}
.petitdej-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.petitdej-img{width:100%;border-radius:var(--radius-lg);overflow:hidden;position:relative}
.petitdej-img img{width:100%;display:block;border-radius:var(--radius-lg)}
.petitdej-badge{position:absolute;top:-12px;right:-12px;width:90px;height:90px;background:var(--teal);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--white);box-shadow:0 8px 25px rgba(75,175,164,.3);animation:float 3s ease-in-out infinite}
.petitdej-badge .top,.petitdej-badge .bot{font-size:.55rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.petitdej-badge .mid{font-size:1.2rem;margin:.1rem 0}
.petitdej-content h2{font-size:clamp(1.8rem,3vw,2.3rem);margin-bottom:1rem}
.petitdej-content>p{font-size:1rem;color:var(--charcoal-light);margin-bottom:.8rem}
.petitdej-options{margin-top:1.8rem}
.petitdej-option{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem;background:var(--cream);border-radius:var(--radius);margin-bottom:.8rem;transition:all .3s}
.petitdej-option:hover{background:var(--cream-light);box-shadow:0 4px 15px rgba(0,0,0,.04)}
.petitdej-option-icon{font-size:1.5rem;flex-shrink:0}
.petitdej-option h4{font-family:var(--font-body);font-weight:700;font-size:.92rem;margin-bottom:.15rem}
.petitdej-option .price{color:var(--teal);font-weight:700;font-size:.85rem}
.petitdej-option p{font-size:.85rem;color:var(--charcoal-light);margin:0;line-height:1.5}

/* ================================================================
   AVIS
================================================================ */
.avis{padding:var(--section-pad) 0;background:var(--cream)}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.avis-card{background:var(--white);border-radius:var(--radius-lg);padding:2rem}
.avis-stars{color:#F5A623;font-size:.85rem;letter-spacing:2px;margin-bottom:.8rem}
.avis-text{font-family:var(--font-display);font-style:italic;font-size:1.05rem;color:var(--charcoal);line-height:1.6;margin-bottom:1.3rem}
.avis-author{display:flex;align-items:center;gap:.7rem}
.avis-avatar{width:40px;height:40px;border-radius:50%;background:var(--rose);display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:.82rem}
.avis-name{font-weight:700;font-size:.88rem}
.avis-source{font-size:.78rem;color:var(--grey-mid)}

/* ================================================================
   ACTIVITÉS
================================================================ */
.activites{padding:var(--section-pad) 0;background:var(--off-white)}
.activites-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.activite-card{display:flex;gap:1.3rem;padding:1.5rem;background:var(--cream);border-radius:var(--radius-lg);transition:all .35s}
.activite-card:hover{transform:translateY(-4px);box-shadow:0 10px 35px rgba(0,0,0,.06)}
.activite-icon{width:60px;height:60px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.activite-content h3{font-size:1.05rem;margin-bottom:.35rem}
.activite-content p{font-size:.88rem;color:var(--charcoal-light);line-height:1.5}
.activite-distance{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;color:var(--teal);margin-top:.4rem}

/* ================================================================
   TARIFS
================================================================ */
.tarifs{padding:var(--section-pad) 0;background:var(--cream)}
.tarifs-table{max-width:950px;margin:2.5rem auto 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 30px rgba(0,0,0,.06)}
.tarifs-row{display:grid;grid-template-columns:2fr 1fr 1.2fr 1fr;align-items:center;background:var(--white)}
.tarifs-row+.tarifs-row{border-top:1px solid var(--cream)}
.tarifs-header{background:var(--charcoal);color:var(--white);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.tarifs-cell{padding:1rem 1.3rem;font-size:.92rem}
.tarifs-cell:not(:first-child){text-align:center}
.tarifs-room{font-family:var(--font-display);font-size:1.05rem;font-weight:500;display:flex;align-items:center;gap:.6rem}
.tarifs-thumb{width:50px;height:38px;border-radius:6px;object-fit:cover;flex-shrink:0}
.tarifs-price{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--rose-dark)}
.tarifs-check{color:var(--teal);font-weight:700}
.tarifs-extras{max-width:950px;margin:1.5rem auto 0;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.tarif-extra{display:flex;align-items:center;gap:.8rem;background:var(--white);padding:1rem 1.3rem;border-radius:var(--radius)}
.tarif-extra-icon{font-size:1.3rem;flex-shrink:0}
.tarif-extra h4{font-family:var(--font-body);font-size:.88rem;font-weight:700;margin-bottom:.1rem}
.tarif-extra p{font-size:.78rem;color:var(--grey-mid);margin:0}
.tarif-extra .prix{color:var(--teal);font-weight:700}

/* ================================================================
   INFOS PRATIQUES
================================================================ */
.infos-pratiques{padding:var(--section-pad) 0;background:var(--off-white)}
.infos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:2rem auto 0}
.info-card{display:flex;gap:1rem;padding:1.3rem;background:var(--cream);border-radius:var(--radius);align-items:flex-start}
.info-card-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.info-card h4{font-family:var(--font-body);font-size:.92rem;font-weight:700;margin-bottom:.2rem}
.info-card p{font-size:.85rem;color:var(--charcoal-light);margin:0;line-height:1.5}

/* ================================================================
   CTA RÉSERVATION
================================================================ */
.cta-resa{padding:5rem 0;background:var(--rose);text-align:center;position:relative;overflow:hidden}
.cta-resa::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(0,0,0,.05) 0%,transparent 40%)}
.cta-resa>*{position:relative;z-index:1}
.cta-resa h2{font-size:clamp(1.8rem,3.5vw,2.5rem);color:var(--white);margin-bottom:.6rem}
.cta-resa p{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:rgba(255,255,255,.88);margin-bottom:2rem;max-width:450px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta-resa-sub{margin-top:1.5rem;font-size:.88rem;color:rgba(255,255,255,.75)}

/* ================================================================
   FOOTER
================================================================ */
footer{background:var(--black);color:rgba(255,255,255,.55);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand h3{font-family:var(--font-display);font-size:1.3rem;color:var(--white);margin-bottom:.8rem}
.footer-brand p{font-size:.88rem;line-height:1.7}
.footer-labels{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.footer-label{display:inline-flex;align-items:center;gap:.3rem;background:rgba(255,255,255,.07);padding:.3rem .6rem;border-radius:6px;font-size:.7rem;color:rgba(255,255,255,.6)}
.footer-col h4{font-family:var(--font-body);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-light);margin-bottom:1rem}
.footer-col li{margin-bottom:.5rem}
.footer-col a{font-size:.85rem;color:rgba(255,255,255,.55);transition:color .3s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;display:flex;justify-content:space-between;font-size:.75rem}
.footer-bottom a{color:rgba(255,255,255,.35)}

/* ================================================================
   ANIMATIONS
================================================================ */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.reveal{opacity:0;transform:translateY(30px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   RESPONSIVE
================================================================ */
@media(max-width:1024px){
  .intro-grid,.petitdej-grid,.maison-intro-grid,.chambre-detail-grid,.chambre-section.reverse .chambre-detail-grid{grid-template-columns:1fr}
  .chambres-grid{grid-template-columns:repeat(2,1fr)}
  .espaces-features{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .tarifs-extras{grid-template-columns:1fr}
  .booking-bar{flex-wrap:wrap}
}
@media(max-width:768px){
  .top-bar{padding:.4rem 1.2rem}
  .top-bar-right{display:none}
  .nav-inner{padding:.5rem 1.2rem}
  .nav-links{display:none}
  .mobile-toggle{display:flex}
  .chambres-grid{grid-template-columns:1fr;max-width:450px;margin-left:auto;margin-right:auto}
  .espaces-grid,.espaces-gallery{grid-template-columns:1fr}
  .espaces-features{grid-template-columns:1fr 1fr}
  .galerie-grid{grid-template-columns:repeat(2,1fr)}
  .avis-grid{grid-template-columns:1fr;max-width:450px;margin-left:auto;margin-right:auto}
  .activites-grid,.infos-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.8rem;text-align:center}
  .cta-btns{flex-direction:column;align-items:center}
  .booking-bar{flex-direction:column;max-width:350px}
  .booking-field{width:100%;border-right:none;border-bottom:1px solid var(--cream-dark)}
  .booking-btn{width:100%;text-align:center;justify-content:center}
  .hero{height:95vh}
  .intro-features,.maison-infos{grid-template-columns:1fr}
  .equip-grid{grid-template-columns:1fr}
  .chambre-cta-row{flex-direction:column;align-items:flex-start}
}
