/* ===== La Nonnerie — feuille de style ===== */
:root{
  --cream:#faf6ef; --cream-2:#f1e9dc; --ink:#2e2a24; --ink-soft:#574f44;
  --stone:#a9967a; --terracotta:#b5654a; --terracotta-dark:#9c5239;
  --green:#6f7d5a; --green-dark:#566145; --rose:#bd4f73; --white:#fff;
  --shadow:0 18px 40px -18px rgba(46,42,36,.45); --radius:14px; --maxw:1180px;
  --serif:"Cormorant Garamond",Georgia,serif; --sans:"Mulish","Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--ink)}
h2{font-size:clamp(2rem,4.5vw,3.1rem);margin-bottom:.4em}
h3{font-size:1.5rem;margin-bottom:.3em}
.section{padding:clamp(3.5rem,8vw,6.5rem) 1.25rem}
.wrap{max-width:var(--maxw);margin:0 auto}
.eyebrow{font-family:var(--sans);font-weight:800;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;color:var(--terracotta);margin-bottom:1rem;display:block}
.lead{font-size:1.18rem;color:var(--ink-soft);max-width:60ch}
.center{text-align:center;margin-left:auto;margin-right:auto}
.btn{display:inline-block;padding:.9rem 1.8rem;border-radius:999px;font-weight:800;font-size:.95rem;letter-spacing:.02em;cursor:pointer;border:2px solid transparent;transition:.25s;text-align:center}
.btn-primary{background:var(--terracotta);color:#fff}
.btn-primary:hover{background:var(--terracotta-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:#fff;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.9rem clamp(1rem,4vw,2.5rem);transition:.3s}
.nav.scrolled{background:rgba(250,246,239,.96);box-shadow:0 6px 24px -16px rgba(0,0,0,.5);backdrop-filter:blur(8px)}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:#fff;transition:.3s;letter-spacing:.02em}
.nav.scrolled .brand{color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none}
.nav-links a{font-weight:700;font-size:.92rem;color:#fff;transition:.3s;opacity:.95}
.nav.scrolled .nav-links a{color:var(--ink-soft)}
.nav-links a:hover{color:var(--terracotta)}
.lang-toggle{display:flex;border:1.5px solid rgba(255,255,255,.6);border-radius:999px;overflow:hidden}
.nav.scrolled .lang-toggle{border-color:var(--stone)}
.lang-toggle button{background:transparent;border:none;cursor:pointer;padding:.3rem .7rem;font-weight:800;font-size:.78rem;color:#fff;font-family:var(--sans);transition:.2s}
.nav.scrolled .lang-toggle button{color:var(--ink-soft)}
.lang-toggle button.active{background:var(--terracotta);color:#fff!important}
.nav-cta{padding:.55rem 1.1rem;font-size:.85rem}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:26px;height:2.5px;background:#fff;transition:.3s;border-radius:2px}
.nav.scrolled .burger span{background:var(--ink)}
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;padding:6rem 1.5rem 4rem;background:linear-gradient(180deg,rgba(30,26,20,.45),rgba(30,26,20,.25) 40%,rgba(30,26,20,.55)),url("../images/exterieur--devanture-1.webp") center/cover no-repeat}
.hero-inner{max-width:760px}
.hero .place{font-family:var(--sans);font-weight:800;letter-spacing:.32em;text-transform:uppercase;font-size:.8rem;opacity:.9}
.hero h1{color:#fff;font-size:clamp(3rem,9vw,6rem);margin:.15em 0 .25em;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero p{font-size:1.25rem;max-width:38ch;margin:0 auto 2rem;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85;animation:bob 2.2s infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
.intro{background:var(--cream)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:4/3}
.facts{display:flex;gap:1.8rem;flex-wrap:wrap;margin-top:1.6rem}
.fact{display:flex;flex-direction:column}
.fact b{font-family:var(--serif);font-size:2rem;color:var(--terracotta);line-height:1}
.fact span{font-size:.85rem;color:var(--ink-soft);font-weight:600}
.features{background:var(--cream-2)}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.4rem;margin-top:2.5rem}
.feature{background:var(--white);border-radius:var(--radius);padding:1.8rem 1.6rem;box-shadow:0 12px 30px -22px rgba(0,0,0,.4)}
.feature .ico{font-size:1.6rem;margin-bottom:.6rem}
.feature h3{font-size:1.2rem}
.feature p{color:var(--ink-soft);font-size:.96rem}
.amenities{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.6rem 2rem;margin-top:2rem;list-style:none}
.amenities li{padding:.5rem 0;border-bottom:1px solid var(--cream-2);font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:.6rem}
.amenities li::before{content:"\2726";color:var(--green);font-size:.8rem}
.gallery{background:var(--cream)}
.filters{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin:1.5rem 0 2.2rem}
.filters button{background:transparent;border:1.5px solid var(--stone);color:var(--ink-soft);padding:.45rem 1.1rem;border-radius:999px;cursor:pointer;font-weight:700;font-size:.85rem;font-family:var(--sans);transition:.2s}
.filters button.active,.filters button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.grid{columns:3;column-gap:14px}
.grid figure{break-inside:avoid;margin:0 0 14px;border-radius:12px;overflow:hidden;cursor:pointer;position:relative;box-shadow:0 10px 26px -20px rgba(0,0,0,.5)}
.grid img{width:100%;transition:.5s;display:block}
.grid figure:hover img{transform:scale(1.06)}
.grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .7rem;color:#fff;font-weight:700;font-size:.9rem;background:linear-gradient(transparent,rgba(0,0,0,.6));opacity:0;transition:.3s}
.grid figure:hover figcaption{opacity:1}
.region{background:var(--green-dark);color:#fff}
.region .eyebrow{color:#dfe6cf}
.region h2{color:#fff}
.region .lead{color:rgba(255,255,255,.85)}
.region-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.2rem;margin-top:2.5rem}
.region-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:1.4rem}
.region-card b{font-family:var(--serif);font-size:1.3rem;display:block}
.region-card .km{color:#dfe6cf;font-weight:800;font-size:.8rem;letter-spacing:.05em}
.region-card p{font-size:.9rem;color:rgba(255,255,255,.8);margin-top:.3rem}
.booking{background:var(--cream-2)}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start;margin-top:2.5rem}
.contact-info p{margin-bottom:.9rem;color:var(--ink-soft)}
.contact-info .label{font-weight:800;color:var(--ink);text-transform:uppercase;font-size:.72rem;letter-spacing:.12em;display:block;margin-bottom:.1rem}
.contact-info a{color:var(--terracotta);font-weight:700}
.booking-note{background:#fff7ef;border-left:4px solid var(--terracotta);padding:1rem 1.2rem;border-radius:8px;font-size:.92rem;color:var(--ink-soft);margin-top:1.2rem}
form{background:var(--white);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:700;font-size:.85rem;margin-bottom:.35rem}
.field input,.field textarea,.field select{width:100%;padding:.8rem .9rem;border:1.5px solid var(--cream-2);border-radius:8px;font-family:var(--sans);font-size:1rem;background:var(--cream);transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--terracotta);background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
form button{width:100%;margin-top:.4rem}
.form-msg{margin-top:1rem;font-weight:700;text-align:center;display:none}
.ph{background:#fff3cd;color:#7a5b00;padding:0 .25em;border-radius:3px;font-style:italic}
footer{background:var(--ink);color:#cfc6b8;padding:3rem 1.25rem 2rem;text-align:center}
footer .brand{color:#fff;display:block;margin-bottom:.4rem}
footer a{color:#e6b9a7}
footer .fcols{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;margin:1.2rem 0}
footer small{display:block;margin-top:1.4rem;opacity:.6;font-size:.78rem}
.lightbox{position:fixed;inset:0;background:rgba(20,16,12,.94);z-index:200;display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:82vh;border-radius:8px;box-shadow:0 30px 60px -20px rgba(0,0,0,.8)}
.lb-cap{position:absolute;bottom:1.4rem;left:0;right:0;text-align:center;color:#fff;font-weight:700;letter-spacing:.02em}
.lb-btn{position:absolute;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:2rem;cursor:pointer;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:2vw;top:50%;transform:translateY(-50%)}
.lb-next{right:2vw;top:50%;transform:translateY(-50%)}
.lb-close{top:1.4rem;right:1.6rem;width:46px;height:46px;font-size:1.5rem}
.reveal{opacity:0;transform:translateY(28px);transition:.7s ease}
.reveal.in{opacity:1;transform:none}
@media(max-width:900px){.grid{columns:2}.split,.booking-grid{grid-template-columns:1fr}.split.reverse .split-media{order:0}}
@media(max-width:680px){
.nav-links{position:fixed;top:0;right:0;height:100vh;width:75%;max-width:320px;background:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;gap:1.6rem;padding:2.5rem;transform:translateX(100%);transition:.35s;box-shadow:-20px 0 60px rgba(0,0,0,.4)}
.nav-links.open{transform:translateX(0)}
.nav-links a{color:#fff!important;font-size:1.1rem}
.burger{display:flex}.grid{columns:1}.field-row{grid-template-columns:1fr}.hero h1{font-size:3.2rem}}

/* ===== v2 : composants ajoutés ===== */
/* Page hero (page gîte) */
.page-hero{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;padding:7rem 1.5rem 3rem;background:linear-gradient(180deg,rgba(30,26,20,.5),rgba(30,26,20,.45)),url("../images/exterieur--devanture-1.webp") center/cover no-repeat}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4rem);text-shadow:0 2px 24px rgba(0,0,0,.4)}
.page-hero p{font-size:1.15rem;max-width:46ch;margin:.6rem auto 0;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.backlink{display:inline-block;margin-bottom:.4rem;font-weight:700;font-size:.85rem;letter-spacing:.04em;color:#fff;opacity:.9}
.backlink:hover{opacity:1}

/* Bandeau de chiffres-clés */
.statband{background:var(--ink);color:#fff}
.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:2.2rem 3rem;padding:2.2rem 1rem}
.stat{text-align:center;min-width:90px}
.stat b{display:block;font-family:var(--serif);font-size:2.4rem;line-height:1;color:#fff}
.stat span{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:#cdbfa9;font-weight:700}

/* Carte gîte (accueil) */
.gite-card{display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-top:2.5rem}
.gite-card .gc-media{min-height:320px;background-size:cover;background-position:center}
.gite-card .gc-body{padding:clamp(1.6rem,3vw,2.6rem)}
.gite-card h3{font-size:1.9rem}
.gite-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.2rem}
.chip{background:var(--cream-2);color:var(--ink-soft);font-weight:700;font-size:.82rem;padding:.35rem .8rem;border-radius:999px}
.gite-card p{color:var(--ink-soft);margin-bottom:1.4rem}

/* Mise en évidence (highlight) */
.feature.highlight{border:2px solid var(--terracotta);position:relative}
.feature.highlight .ico{color:var(--terracotta)}
.tag-star{position:absolute;top:-12px;right:14px;background:var(--terracotta);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .7rem;border-radius:999px}

/* Bandeau social / Superhôte */
.social{background:var(--cream-2);text-align:center}
.social .stars{font-size:1.6rem;color:#e0a32e;letter-spacing:.1em}
.social .score{font-family:var(--serif);font-size:2.6rem;color:var(--ink);line-height:1}
.social .src{font-size:.85rem;color:var(--ink-soft);font-weight:600}
.social .badge{display:inline-block;margin-top:.6rem;background:var(--ink);color:#fff;font-weight:700;font-size:.8rem;padding:.35rem .9rem;border-radius:999px;letter-spacing:.03em}

/* Avis / commentaires */
.reviews{background:var(--cream)}
.disqus-note{background:#fff7ef;border-left:4px solid var(--terracotta);padding:1rem 1.2rem;border-radius:8px;font-size:.9rem;color:var(--ink-soft);max-width:720px;margin:1.4rem auto 0}
#disqus_thread{max-width:820px;margin:2rem auto 0}

/* Bandeau séjour 50 m² (image + texte) */
.showcase{background:var(--green-dark);color:#fff}
.showcase .split-media img{aspect-ratio:16/10}
.showcase h2,.showcase .eyebrow{color:#fff}
.showcase .eyebrow{color:#dfe6cf}
.showcase .lead{color:rgba(255,255,255,.88)}
.showcase .big{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);color:#fff;line-height:1;margin:.4rem 0}

@media(max-width:780px){
  .gite-card{grid-template-columns:1fr}
  .gite-card .gc-media{min-height:220px}
  .stats{gap:1.4rem 2rem}
  .stat b{font-size:2rem}
}
