:root{
  /* PALETTE OPTION A - Provençal Raffiné */
  --primary-olive:#3D4A2E;
  --secondary-terra:#C17A4A;
  --accent-teal:#6B8E7F;
  --gold:#D4AF7A;
  --cream:#F5F0E8;
  --cream-deep:#E8DFD0;
  --ink:#2A2A2A;
  --ink-soft:#555555;
  
  /* LEGACY (maintained for compatibility) */
  --terracotta:var(--secondary-terra);
  --terracotta-deep:#8f4528;
  --olive:var(--primary-olive);
  --olive-deep:var(--primary-olive);
  --lavande:var(--accent-teal);
  --cream-legacy:var(--cream);
  --cream-deep-legacy:var(--cream-deep);
  
  --display:'Playfair Display',serif;
  --body:'Lora',serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden}
h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.12}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:14px 32px;transition:.4s;background:var(--olive-deep);box-shadow:0 2px 12px rgba(44,38,34,.18)}
nav.scrolled{background:var(--olive-deep);backdrop-filter:blur(10px);box-shadow:0 2px 12px rgba(44,38,34,.25);padding:8px 32px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:54px;width:auto;filter:brightness(0) invert(1);transition:.4s}
nav.scrolled .brand img{filter:brightness(0) invert(1)}
.menu{display:flex;gap:26px;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase}
.menu a{color:#fff;transition:.3s;opacity:.92;padding-bottom:3px;border-bottom:1px solid transparent}
nav.scrolled .menu a{color:#fff}
.menu a:hover,.menu a.active{color:var(--gold);opacity:1;border-color:var(--gold)}
.menu a.cta{background:var(--terracotta);color:#fff!important;padding:9px 18px;border-radius:2px;border:none}
.menu a.cta:hover{background:var(--terracotta-deep)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:101}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}
nav.scrolled .burger span{background:#fff}
.hero{height:100vh;min-height:620px;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;background-size:cover;background-position:center}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(44,38,34,.32),rgba(44,38,34,.6))}
.hero-inner{position:relative;z-index:2;color:#fff;padding:0 24px;animation:rise 1.2s ease both}
.hero .eyebrow{font-size:.8rem;letter-spacing:4px;text-transform:uppercase;opacity:.9;margin-bottom:18px;color:#fff}
.hero h1{font-size:clamp(2.6rem,8vw,5.2rem);font-weight:300;margin-bottom:16px}
.hero h1 em{font-style:italic;color:#f0d9c4}
.hero p{font-size:1.08rem;max-width:560px;margin:0 auto 30px;opacity:.96;font-weight:300}
.btn{display:inline-block;padding:14px 36px;background:var(--terracotta);color:#fff;letter-spacing:2px;text-transform:uppercase;font-size:.76rem;border-radius:2px;transition:.3s;border:none;cursor:pointer}
.btn:hover{background:var(--terracotta-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.6);margin-left:10px}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-olive{background:var(--olive)}.btn-olive:hover{background:var(--olive-deep)}
@keyframes rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.count{margin-top:38px;display:flex;gap:24px;justify-content:center}
.count div{text-align:center}
.count b{font-family:var(--display);font-size:1.9rem;display:block;color:#f0d9c4}
.count small{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;opacity:.8}
section{padding:100px 0}
.page-top{padding:160px 0 70px;text-align:center;background:var(--cream-deep)}
.eyebrow{font-size:.76rem;letter-spacing:3px;text-transform:uppercase;color:var(--terracotta);margin-bottom:14px;display:block}
.sec-title{font-size:clamp(2rem,5vw,3.1rem);margin-bottom:22px;color:var(--ink)}
.sec-title em{font-style:italic;color:var(--olive)}
.lead{font-size:1.05rem;color:var(--ink-soft);max-width:640px;margin:0 auto}
.domaine .grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.domaine p{margin-bottom:16px;color:var(--ink-soft)}
.domaine .imgwrap{position:relative}
.domaine .imgwrap img{border-radius:3px;box-shadow:0 30px 60px rgba(44,38,34,.18)}
.domaine .imgwrap::before{content:'';position:absolute;inset:-16px -16px 16px 16px;border:1px solid var(--olive);border-radius:3px;z-index:-1}
.vues{background:var(--olive-deep);color:#fff}
.vues .sec-title{color:#fff}.vues .eyebrow{color:#d8c9a8}
.vues-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:50px}
.vue-card{text-align:center}
.vue-card .num{font-family:var(--display);font-size:2.8rem;font-style:italic;color:#d8c9a8;opacity:.6}
.vue-card h3{font-size:1.45rem;margin:6px 0 10px}
.vue-card p{font-size:.94rem;opacity:.85}
.heberg{background:var(--cream-deep)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:50px}
.card{background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 14px 40px rgba(44,38,34,.1);transition:.4s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(44,38,34,.18)}
.card .ph{height:220px;background-size:cover;background-position:center;position:relative}
.card .tag{position:absolute;top:14px;left:14px;background:var(--terracotta);color:#fff;font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;padding:6px 12px;border-radius:2px}
.card .body{padding:24px;flex:1;display:flex;flex-direction:column}
.card h3{font-size:1.4rem;color:var(--olive-deep);margin-bottom:8px}
.card p{font-size:.9rem;color:var(--ink-soft);margin-bottom:14px;flex:1}
.card .price{font-family:var(--display);font-size:1.1rem;color:var(--terracotta);margin-bottom:4px}
.card .price small{font-family:var(--body);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft)}
.card .meta{font-size:.74rem;letter-spacing:1px;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:50px}
.gallery .g{position:relative;height:240px;border-radius:4px;overflow:hidden}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery .g:hover img{transform:scale(1.08)}
.gallery .g span{position:absolute;bottom:0;left:0;right:0;padding:18px 14px 12px;background:linear-gradient(transparent,rgba(44,38,34,.82));color:#fff;font-size:.8rem;letter-spacing:.5px}
.gallery .wide{grid-column:span 2}
.region{background:var(--cream)}
.notice{background:var(--lavande);color:#fff;padding:60px 0;text-align:center}
.notice h2{font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:14px;color:#fff}
.notice p{max-width:560px;margin:0 auto 24px;opacity:.95}
.notice .ifield{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.notice input{flex:1;min-width:220px;padding:13px 16px;border:none;border-radius:2px;font-family:var(--body)}
.contact{background:var(--olive-deep);color:#fff}
.contact .sec-title{color:#fff}.contact .eyebrow{color:#d8c9a8}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:36px;align-items:start}
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;opacity:.85}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:12px 15px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:3px;color:#fff;font-family:var(--body);font-size:.95rem}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.5)}
.form-field select option{color:var(--ink)}
.contact-info p{margin-bottom:12px;opacity:.92}
.contact-info .lbl{color:#d8c9a8;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;display:block;margin-top:20px;margin-bottom:4px}
.contact-info a{color:#f0d9c4}
.msg-ok{background:rgba(216,201,168,.2);border:1px solid #d8c9a8;padding:14px;border-radius:3px;margin-top:14px;display:none}
.opt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:50px}
.opt{background:#fff;border-radius:4px;padding:30px;box-shadow:0 12px 34px rgba(44,38,34,.08);border-left:3px solid var(--terracotta)}
.opt h3{font-size:1.3rem;color:var(--olive-deep);margin-bottom:8px}
.opt .p{font-family:var(--display);color:var(--terracotta);font-size:1rem;margin-bottom:10px}
.opt p{color:var(--ink-soft);font-size:.94rem}
.partner{background:var(--cream-deep);text-align:center}
.partner .box{background:#fff;max-width:760px;margin:40px auto 0;border-radius:5px;padding:40px;box-shadow:0 16px 44px rgba(44,38,34,.1);display:grid;grid-template-columns:200px 1fr;gap:34px;align-items:center;text-align:left}
.partner .box img{border-radius:4px}
.partner h3{font-size:1.4rem;color:var(--olive-deep);margin-bottom:10px}
.partner p{color:var(--ink-soft);font-size:.95rem;margin-bottom:8px}
.partner .c{font-size:.85rem;color:var(--terracotta);letter-spacing:.5px}
.legal{max-width:820px;margin:0 auto;color:var(--ink-soft)}
.legal h2{font-family:var(--display);color:var(--olive-deep);font-size:1.5rem;margin:36px 0 12px}
.legal p{margin-bottom:12px}
.tour-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.tour{background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 12px 34px rgba(44,38,34,.08)}
.tour .ph{height:180px;background-size:cover;background-position:center}
.tour .body{padding:22px}
.tour h3{font-size:1.2rem;color:var(--olive-deep);margin-bottom:8px}
.tour p{font-size:.9rem;color:var(--ink-soft)}
.tour .dist{font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--terracotta);margin-top:10px}
footer{background:var(--ink);color:#cbbfb2;padding:50px 0 30px;text-align:center}
footer img{height:64px;margin:0 auto 16px;filter:brightness(0) invert(1);opacity:.9}
footer .flinks{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-bottom:20px;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase}
footer .flinks a:hover{color:var(--terracotta)}
footer .em{margin-bottom:14px;font-size:.9rem}
footer .em a{color:#f0d9c4}
footer small{opacity:.55;font-size:.76rem;display:block;line-height:1.8}
.reveal{opacity:1;transform:none;transition:.9s ease}
.js .reveal{opacity:0;transform:translateY(40px)}
.js .reveal.in{opacity:1;transform:none}
@media(max-width:860px){
  .menu{position:fixed;inset:0;background:#3b4232;flex-direction:column;justify-content:center;align-items:center;gap:30px;transform:translateX(100%);transition:transform .4s,visibility 0s .4s;visibility:hidden;z-index:99}
  .menu.open{transform:none;visibility:visible;transition:transform .4s,visibility 0s 0s}
  .menu a{color:#fff!important;font-size:1.15rem}
  .burger{display:flex}
  .domaine .grid,.contact-grid,.partner .box{grid-template-columns:1fr;gap:34px}
  .vues-grid,.cards,.opt-grid,.tour-grid{grid-template-columns:1fr;gap:22px}
  .gallery{grid-template-columns:1fr 1fr}.gallery .wide{grid-column:span 2}
  section{padding:68px 0}.count{flex-wrap:wrap;gap:16px}
  nav{padding:10px 18px}.brand img{height:44px}
  /* Hero optimisé mobile */
  .hero{height:auto;min-height:0;padding:120px 0 70px}
  .hero-logo{height:96px!important;margin-bottom:14px!important}
  .hero .eyebrow{font-size:.7rem;letter-spacing:2.5px;margin-bottom:14px}
  .hero h1{font-size:clamp(2.4rem,11vw,3.4rem);margin-bottom:14px}
  .hero p{font-size:1rem;margin-bottom:24px;padding:0 6px}
  .hero .btn{display:block;width:100%;max-width:300px;margin:8px auto}
  .count{margin-top:24px}
  .count b{font-size:1.6rem}
}
@media(max-width:480px){.gallery{grid-template-columns:1fr}.gallery .wide{grid-column:span 1}}

/* === PAYMENT FORM - Stripe Integration === */
.payment-section{background:var(--primary-olive);color:var(--cream);padding:100px 0;margin-top:80px}
.payment-content{max-width:1180px;margin:0 auto;padding:0 24px}
.payment-title{font-family:var(--display);font-size:2.4rem;text-align:center;margin-bottom:50px;color:var(--gold)}
.payment-form{background:rgba(255,255,255,.05);border:1px solid var(--gold);padding:40px;border-radius:4px;max-width:600px;margin:0 auto}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;color:var(--gold);font-weight:600}
.form-group input,.form-group select{width:100%;padding:14px 16px;background:rgba(255,255,255,.1);border:1px solid var(--gold);color:var(--cream);font-family:var(--body);font-size:1rem;border-radius:3px;transition:.3s}
.form-group input::placeholder{color:rgba(245,240,232,.5)}
.form-group input:focus,.form-group select:focus{outline:none;background:rgba(255,255,255,.15);box-shadow:0 0 0 2px var(--gold)}
#card-element{padding:14px 16px;background:rgba(255,255,255,.1);border:1px solid var(--gold);border-radius:3px;color:var(--cream)}
.StripeElement{color:var(--cream)}
.StripeElement--focus{box-shadow:0 0 0 2px var(--gold)}
.payment-button{width:100%;padding:16px 40px;background:var(--secondary-terra);color:white;border:none;border-radius:3px;cursor:pointer;font-family:var(--display);font-size:1.1rem;letter-spacing:1px;transition:.3s;margin-top:20px;font-weight:600}
.payment-button:hover{background:#a96739;transform:translateY(-2px)}
.payment-button:disabled{opacity:.6;cursor:not-allowed;transform:none}
.payment-status{margin-top:20px;padding:16px;border-radius:3px;text-align:center;display:none}
.payment-status.success{background:rgba(76,175,80,.2);color:#4CAF50;border:1px solid #4CAF50;display:block}
.payment-status.error{background:rgba(244,67,54,.2);color:#F44336;border:1px solid #F44336;display:block}

/* === INTERACTIVE CALENDAR === */
.calendar-section{padding:60px 0;background:var(--cream-deep)}
.calendar-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;max-width:1180px;margin:0 auto;padding:0 24px;align-items:start}
.calendar-picker{background:white;padding:30px;border-radius:4px;box-shadow:0 10px 30px rgba(44,38,34,.1)}
.calendar-month{font-family:var(--display);font-size:1.4rem;text-align:center;margin-bottom:20px;color:var(--primary-olive)}
.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid #ddd;border-radius:3px;cursor:pointer;font-size:.85rem;transition:.2s}
.calendar-day:hover{background:var(--cream)}
.calendar-day.selected{background:var(--secondary-terra);color:white;border-color:var(--secondary-terra)}
.calendar-day.disabled{opacity:.5;cursor:not-allowed}

.reservation-summary{background:white;padding:30px;border-radius:4px;box-shadow:0 10px 30px rgba(44,38,34,.1)}
.summary-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #eee}
.summary-item:last-child{border-bottom:none}
.summary-item label{font-weight:600;color:var(--primary-olive)}
.summary-total{display:flex;justify-content:space-between;padding:16px 0;font-size:1.2rem;font-family:var(--display);border-top:2px solid var(--secondary-terra);margin-top:20px}
.summary-total strong{color:var(--secondary-terra)}

/* === EMAILJS Integration === */
.contact-status{padding:14px 16px;border-radius:3px;margin-top:14px;display:none;font-size:.9rem}
.contact-status.success{background:rgba(76,175,80,.15);border:1px solid #4CAF50;color:#2e7d32}
.contact-status.error{background:rgba(244,67,54,.15);border:1px solid #F44336;color:#c62828}

/* === Accessibilité === */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
*:focus-visible{outline:2px solid var(--secondary-terra);outline-offset:3px;border-radius:3px}

/* === Animations === */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.payment-section{animation:fadeIn .6s ease-out}
.payment-form{animation:slideUp .8s ease-out .2s both}
.btn:focus-visible,nav.scrolled a:focus-visible{outline-offset:2px}
button{font-family:inherit;cursor:pointer;background:none;border:0;color:inherit}
.localisation .grid{grid-template-columns:1fr 1fr;gap:50px;align-items:center}
@media(max-width:880px){.localisation .grid{grid-template-columns:1fr;gap:30px}}

/* === Responsive desktop nav for mobile burger === */
@media(min-width:881px){.burger{display:none}}

/* === Localisation section adjustments === */
.localisation .eyebrow{color:#c9a96e}
.localisation .sec-title{color:#fff}
.localisation .sec-title em{color:#d8c9a8}

/* === Reservation table mobile === */
@media(max-width:560px){
  table th,table td{padding:9px 7px!important;font-size:.82rem}
}

/* === Bandeau cookies (CNIL) === */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;
  background:#2f3826;border-top:3px solid var(--gold);box-shadow:0 -4px 24px rgba(0,0,0,.25);padding:20px 28px}
.cookie-text{flex:1 1 460px;font-size:.92rem;line-height:1.65;color:#f5f0e8}
.cookie-text strong{color:#fff;font-weight:600}
.cookie-text a{color:var(--gold);text-decoration:underline;font-weight:500;margin-left:4px}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.ck-btn{cursor:pointer;border:none;font-family:var(--body);font-size:.82rem;letter-spacing:1px;text-transform:uppercase;padding:12px 22px;border-radius:3px;transition:.25s}
.ck-refuse{background:transparent;border:1.5px solid #f5f0e8;color:#f5f0e8}
.ck-refuse:hover{background:#f5f0e8;color:var(--olive-deep)}
.ck-accept{background:var(--gold);color:#2f3826;font-weight:600}
.ck-accept:hover{background:#e0bd8a}
.cookie-banner.hidden{display:none}
@media(max-width:640px){.cookie-banner{padding:16px 18px}.cookie-actions{width:100%}.ck-btn{flex:1}}

/* === Email dans le menu === */
.menu a.menu-mail{text-transform:none;letter-spacing:.3px;opacity:.85;font-size:.74rem}
.menu a.menu-mail:hover{color:var(--terracotta);opacity:1}

/* === Section Localisation responsive === */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.loc-cities{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
@media(max-width:860px){
  .loc-grid{grid-template-columns:1fr;gap:36px}
  .loc-cities{grid-template-columns:1fr 1fr;gap:10px}
}
@media(max-width:480px){
  .loc-cities{grid-template-columns:1fr}
}

/* === Anti-débordement horizontal global === */
html,body{max-width:100%;overflow-x:clip}
img,iframe,table{max-width:100%}
