/* ============================================================
   Si DiVin — Design system
   « Au nom de notre agriculture et viticulture »
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500&family=Source+Sans+3:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ---- Tokens ---- */
:root{
  /* brand */
  --navy:#2C3E46;
  --navy-deep:#22323a;
  --green:#7AB648;
  --green-deep:#5C9233;
  --green-soft:#eef4e6;
  --white:#FFFFFF;
  --cream:#F7F8F3;
  --cream-deep:#eef0e7;
  --ink:#3A4A52;
  --muted:#6B7780;
  --line:#e4e7e0;

  /* circuit code couleur */
  --c-chenin:#7AB648;
  --c-muses:#E8762B;
  --c-tuffeau:#6E2C8F;
  --c-indispo:#1A1A1A;
  --c-surprise:#B08A2E;

  /* type */
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Source Sans 3', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* spacing / radius */
  --r-sm:8px;
  --r-md:14px;
  --r-lg:22px;
  --r-pill:999px;
  --shadow-sm:0 2px 10px rgba(44,62,70,.06);
  --shadow-md:0 14px 40px rgba(44,62,70,.10);
  --shadow-lg:0 28px 70px rgba(44,62,70,.16);
  --wrap:1200px;
  --wrap-narrow:780px;
  --header-h:80px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overscroll-behavior:none;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overscroll-behavior:none;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{margin:0;line-height:1.08;color:var(--navy);font-weight:600;}
p{margin:0 0 1.1em;text-wrap:pretty;}
ul{margin:0;padding:0;}
:focus-visible{outline:3px solid var(--green-deep);outline-offset:3px;border-radius:4px;}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}
.wrap--wide{max-width:1480px;margin:0 auto;padding:0 28px;}
.narrow{max-width:var(--wrap-narrow);margin:0 auto;padding:0 28px;}
.section{padding:clamp(56px,8vw,110px) 0;}
.section--cream{background:var(--cream);}
.section--navy{background:var(--navy);color:#dfe6e4;}
.section--tight{padding:clamp(40px,5vw,64px) 0;}
.center{text-align:center;}
.eyebrow{
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;color:var(--green-deep);margin:0 0 18px;
}
.section--navy .eyebrow{color:var(--green);}

/* ---- Type ---- */
.display{
  font-family:var(--serif);font-weight:600;color:var(--navy);
  font-size:clamp(2.6rem,6vw,5rem);line-height:1.02;letter-spacing:.01em;
}
.h-xl{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,4.4vw,3.4rem);letter-spacing:.01em;}
.h-lg{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3vw,2.5rem);}
.h-md{font-family:var(--sans);font-weight:600;font-size:clamp(1.2rem,1.8vw,1.5rem);color:var(--navy);}
.lede{
  font-family:var(--sans);font-style:italic;font-weight:400;
  font-size:clamp(1.05rem,1.6vw,1.32rem);color:var(--muted);line-height:1.55;
}
.accent{color:var(--green-deep);}
.accent-i{font-style:italic;color:var(--green-deep);}
.serif-i{font-family:var(--serif);font-style:italic;}
.muted{color:var(--muted);}
.section--navy .muted{color:#9fb0ad;}
.spaced{letter-spacing:.04em;}

/* big editorial section heading with spaced words */
.editorial{
  font-family:var(--serif);font-weight:600;color:var(--navy);
  font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.06;letter-spacing:.02em;
}
.editorial .accent{font-style:italic;}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:1rem;letter-spacing:.01em;
  padding:.85em 1.7em;border-radius:var(--r-pill);border:2px solid transparent;
  transition:transform .18s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  line-height:1;white-space:nowrap;
}
.btn svg{width:1.1em;height:1.1em;flex:none;}
.btn--primary{background:var(--green);color:#fff;border-color:var(--green);}
.btn--primary:hover{background:var(--green-deep);border-color:var(--green-deep);transform:translateY(-2px);box-shadow:0 10px 24px rgba(92,146,51,.32);}
.btn--secondary{background:transparent;color:var(--green-deep);border-color:var(--green);}
.btn--secondary:hover{background:var(--green-soft);transform:translateY(-2px);}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn--ghost-light:hover{background:#fff;color:var(--navy);border-color:#fff;}
.btn--light{background:#fff;color:var(--navy);border-color:#fff;}
.btn--light:hover{background:var(--green);color:#fff;border-color:var(--green);transform:translateY(-2px);}
.btn--lg{font-size:1.08rem;padding:1em 2.1em;}
.link-more{
  display:inline-flex;align-items:center;gap:.45em;font-weight:600;color:var(--green-deep);
  border-bottom:2px solid transparent;padding-bottom:2px;transition:gap .2s,border-color .2s;
}
.link-more:hover{gap:.8em;border-color:var(--green);}
.link-more svg{width:1.05em;height:1.05em;}

/* ============================================================
   HEADER
   ============================================================ */
/* fixed header; non-hero pages get top padding so content clears it */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:#fff;border-bottom:1px solid transparent;
  transition:background .3s ease, box-shadow .3s ease, border-color .3s ease, height .3s ease;
}
body:not(.has-hero){padding-top:var(--header-h);}
[id]{scroll-margin-top:calc(var(--header-h) + 18px);}
.site-header.is-stuck{box-shadow:0 6px 30px rgba(44,62,70,.10);border-color:var(--line);}
.header-inner{
  max-width:var(--wrap);margin:0 auto;padding:0 34px;height:var(--header-h);
  display:flex;align-items:center;gap:clamp(18px,2.6vw,40px);transition:height .3s ease;
}
.site-header.is-stuck .header-inner{height:66px;}

/* brand with circular white badge (reads on photo + on white) */
.brand{display:flex;align-items:center;gap:13px;flex:none;}
.brand-badge{
  width:50px;height:50px;border-radius:50%;background:#fff;flex:none;
  display:grid;place-items:center;overflow:hidden;
  box-shadow:0 2px 10px rgba(44,62,70,.14);transition:width .3s,height .3s,box-shadow .3s;
}
.brand-badge img{width:44px;height:44px;object-fit:contain;border-radius:50%;}
.site-header.is-stuck .brand-badge{width:44px;height:44px;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-text b{font-family:var(--serif);font-weight:600;font-size:1.5rem;color:var(--navy);letter-spacing:.01em;}
.brand-text span{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:4px;}

/* primary nav — auto margins on both sides give the menu symmetric breathing room,
   visually detaching it from the logo (left) and the secondary actions (right) */
.main-nav{margin:0 auto;}
.main-nav > ul{display:flex;align-items:center;gap:8px;list-style:none;}
.main-nav .nav-link{
  display:inline-flex;align-items:center;gap:.4em;
  font-size:.9rem;font-weight:600;color:var(--navy);position:relative;
  padding:9px 10px;border-radius:var(--r-pill);background:none;border:none;cursor:pointer;
  font-family:var(--sans);transition:background .2s;white-space:nowrap;
}
.main-nav .nav-link::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;border-radius:2px;
  background:var(--green);transform:scaleX(0);transform-origin:center;transition:transform .25s ease;
}
.main-nav .nav-link:hover{color:var(--green-deep);}
.main-nav .nav-link:hover::after{transform:scaleX(1);}
.main-nav .nav-link.is-active{color:var(--green-deep);}
.main-nav .nav-link.is-active::after{transform:scaleX(1);}
.main-nav .nav-link .chev{width:1em;height:1em;transition:transform .25s ease;opacity:.7;}

/* mega menu */
.has-mega{position:relative;}
.mega{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(10px);
  width:660px;max-width:88vw;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:16px;
  opacity:0;visibility:hidden;transition:opacity .22s ease, transform .22s ease;z-index:130;
}
.has-mega::after{content:"";position:absolute;top:100%;left:0;right:0;height:18px;}
.has-mega:hover .mega,.has-mega.open .mega,.has-mega:focus-within .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.has-mega:hover .nav-link .chev,.has-mega.open .nav-link .chev{transform:rotate(180deg);}
.mega-grid{display:grid;grid-template-columns:1fr 232px;gap:14px;}
.mega-label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:6px 12px 10px;}
.mega-list{display:flex;flex-direction:column;gap:2px;}
.mega-item{display:flex;align-items:flex-start;gap:13px;padding:11px 12px;border-radius:var(--r-md);transition:background .18s;}
.mega-item:hover{background:var(--cream);}
.mega-item .dot{width:13px;height:13px;border-radius:50%;flex:none;margin-top:4px;box-shadow:0 0 0 4px rgba(0,0,0,.04);}
.mega-item b{display:block;font-size:.98rem;color:var(--navy);font-weight:600;line-height:1.2;}
.mega-item small{display:block;color:var(--muted);font-size:.83rem;margin-top:2px;}
.mega-promo{
  position:relative;overflow:hidden;border-radius:var(--r-md);padding:22px;color:#fff;
  display:flex;flex-direction:column;justify-content:flex-end;min-height:200px;
  background:linear-gradient(150deg,#6f9e3f,#4c7e2a);
}
.mega-promo .promo-ico{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.18);display:grid;place-items:center;margin-bottom:auto;}
.mega-promo .promo-ico svg{width:22px;height:22px;color:#fff;}
.mega-promo b{font-family:var(--serif);font-size:1.4rem;font-weight:600;margin-top:14px;line-height:1.1;}
.mega-promo small{color:rgba(255,255,255,.85);font-size:.86rem;margin-top:4px;}
.mega-promo .promo-go{display:inline-flex;align-items:center;gap:.4em;font-weight:600;font-size:.9rem;margin-top:14px;}
.mega-promo .promo-go svg{width:1em;height:1em;transition:transform .2s;}
.mega-promo:hover .promo-go svg{transform:translateX(4px);}

/* actions — separated from the nav by a hairline divider + padding, so the
   secondary cluster (lang + CTA) reads as its own region */
.header-actions{
  display:flex;align-items:center;gap:clamp(12px,1.4vw,20px);flex:none;
  padding-left:clamp(14px,1.6vw,26px);border-left:1px solid var(--line);
}
/* lang as a discrete bordered pill — distinct block, clearly not the green CTA */
.lang-switch{
  display:flex;align-items:center;gap:2px;font-weight:600;font-size:.82rem;
  padding:3px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--cream);
}
.lang-switch button{background:none;border:none;color:var(--muted);padding:5px 7px;border-radius:7px;font-weight:600;letter-spacing:.05em;transition:color .2s,background .2s;}
.lang-switch button.is-active{color:var(--navy);background:var(--cream-deep);}
.lang-switch .sep{color:var(--line);}
.btn-reserve{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.92rem;
  padding:.62em 1.35em;border-radius:var(--r-pill);background:var(--green);color:#fff;border:2px solid var(--green);
  transition:background .2s,border-color .2s,transform .18s,box-shadow .2s;
}
.btn-reserve svg{width:1.05em;height:1.05em;}
.btn-reserve:hover{background:var(--green-deep);border-color:var(--green-deep);transform:translateY(-2px);box-shadow:0 10px 24px rgba(92,146,51,.32);}

/* ---- transparent-over-hero mode ---- */
.site-header.at-top{background:linear-gradient(180deg,rgba(26,38,44,.55) 0%,rgba(26,38,44,.12) 70%,rgba(26,38,44,0) 100%);border-color:transparent;box-shadow:none;}
.site-header.at-top .brand-text b{color:#fff;}
.site-header.at-top .brand-text span{color:rgba(255,255,255,.82);}
.site-header.at-top .nav-link{color:#fff;}
.site-header.at-top .nav-link:hover{color:#fff;}
.site-header.at-top .header-actions{border-left-color:rgba(255,255,255,.28);}
.site-header.at-top .lang-switch{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.08);}
.site-header.at-top .lang-switch button{color:rgba(255,255,255,.78);}
.site-header.at-top .lang-switch button.is-active{color:#fff;background:rgba(255,255,255,.2);}
.site-header.at-top .lang-switch .sep{color:rgba(255,255,255,.4);}
.site-header.at-top .burger span{background:#fff;}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;margin-left:auto;}
.burger span{width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:.25s;}
body.menu-open .burger span{background:var(--navy)!important;}
body.menu-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
body.menu-open .burger span:nth-child(2){opacity:0;}
body.menu-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* mobile panel */
.mobile-panel{
  position:fixed;inset:0;background:var(--cream);z-index:95;
  transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;padding:26px 26px 36px;
  display:flex;flex-direction:column;
}
body.menu-open{overflow:hidden;}
body.menu-open .mobile-panel{transform:translateX(0);}
.mobile-panel .m-link{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--navy);padding:15px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;}
.mobile-panel .m-section-label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:22px 0 6px;}
.mobile-panel .m-sub{font-family:var(--sans);font-size:1.06rem;font-weight:600;color:var(--navy);padding:12px 0;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line);}
.mobile-panel .m-sub .dot{width:12px;height:12px;border-radius:50%;flex:none;}
.mobile-panel .m-sub small{color:var(--muted);font-weight:400;font-size:.84rem;margin-left:auto;}
.mobile-panel-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.mobile-close{background:none;border:none;font-size:1.8rem;line-height:1;color:var(--navy);cursor:pointer;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-pill);transition:background .2s;}
.mobile-close:hover{background:var(--line);}
.mobile-foot{margin-top:28px;display:flex;flex-direction:column;gap:16px;}
.mobile-foot .contact-line{display:flex;align-items:center;justify-content:center;gap:11px;color:var(--ink);font-weight:600;}
.mobile-foot .contact-line svg{width:19px;height:19px;color:var(--green-deep);}
/* staggered entrance */
body.menu-open .mobile-panel > *{animation:mIn .45s cubic-bezier(.2,.7,.3,1) both;}
body.menu-open .mobile-panel > *:nth-child(1){animation-delay:.06s;}
body.menu-open .mobile-panel > *:nth-child(2){animation-delay:.10s;}
body.menu-open .mobile-panel > *:nth-child(3){animation-delay:.14s;}
body.menu-open .mobile-panel > *:nth-child(4){animation-delay:.18s;}
body.menu-open .mobile-panel > *:nth-child(5){animation-delay:.22s;}
body.menu-open .mobile-panel > *:nth-child(6){animation-delay:.26s;}
body.menu-open .mobile-panel > *:nth-child(7){animation-delay:.30s;}
body.menu-open .mobile-panel > *:nth-child(n+8){animation-delay:.34s;}
@keyframes mIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){body.menu-open .mobile-panel > *{animation:none;}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy);color:#c5d1ce;font-size:.95rem;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:42px;padding:70px 0 50px;}
.footer-brand b{font-family:var(--serif);font-size:1.9rem;color:#fff;font-weight:600;display:block;}
.footer-brand .slogan{font-style:italic;color:#9fb0ad;margin:8px 0 18px;font-family:var(--serif);font-size:1.15rem;}
.footer-brand p{font-size:.92rem;color:#9fb0ad;max-width:34ch;}
.footer-col h4{color:#fff;font-family:var(--sans);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;font-weight:600;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-col a:hover{color:var(--green);}
.footer-contact a{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.footer-contact svg{width:18px;height:18px;color:var(--green);flex:none;}
.socials{display:flex;gap:12px;margin-top:18px;}
.socials a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;transition:.2s;}
.socials a:hover{background:var(--green);border-color:var(--green);color:#fff;}
.socials svg{width:18px;height:18px;}
.alcohol{
  text-align:center;font-size:.82rem;color:#9fb0ad;border-top:1px solid rgba(255,255,255,.12);
  padding:20px;letter-spacing:.02em;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;
  justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;font-size:.85rem;color:#8a9b98;
}
.footer-bottom nav{display:flex;gap:20px;flex-wrap:wrap;}
.footer-bottom a:hover{color:var(--green);}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:clamp(540px,86vh,820px);display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.hero--short{min-height:clamp(380px,52vh,520px);}
.hero img.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,50,58,.15) 0%,rgba(34,50,58,.2) 45%,rgba(34,50,58,.78) 100%);}
.hero-inner{position:relative;z-index:2;max-width:var(--wrap);margin:0 auto;width:100%;padding:0 28px clamp(48px,7vw,90px);}
.hero h1{color:#fff;font-family:var(--serif);font-weight:600;font-size:clamp(3rem,8vw,6.5rem);line-height:.98;letter-spacing:.01em;text-shadow:0 2px 30px rgba(0,0,0,.25);}
.hero .lede{color:#eef2ee;font-size:clamp(1.1rem,2vw,1.5rem);max-width:46ch;margin-top:18px;}
.hero .quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2vw,1.6rem);color:#fff;max-width:34ch;margin:0 0 8px;opacity:.95;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;}
.hero-mini-meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:26px;font-size:.95rem;color:#eef2ee;}
.hero-mini-meta span{display:flex;align-items:center;gap:8px;}
.hero-mini-meta svg{width:18px;height:18px;color:var(--green);}

/* page intro (short hero alt for legal/simple pages) */
.page-head{background:var(--cream);padding:clamp(64px,8vw,120px) 0 clamp(40px,5vw,64px);text-align:center;border-bottom:1px solid var(--line);}
.page-head .breadcrumb{justify-content:center;}

/* breadcrumb */
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.85rem;color:var(--muted);margin-bottom:18px;flex-wrap:wrap;}
.breadcrumb a:hover{color:var(--green-deep);}
.breadcrumb span.sep{opacity:.5;}

/* ============================================================
   CARDS / GRID
   ============================================================ */
.grid{display:grid;gap:28px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

.card{
  background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .25s ease, box-shadow .25s ease;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.card-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-deep);}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-media img{transform:scale(1.05);}
.card-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.card-body h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;margin-bottom:6px;}
.card-body p{font-size:.97rem;color:var(--ink);margin-bottom:16px;}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.card-price{font-weight:600;color:var(--navy);font-size:.95rem;}
.card-price small{display:block;color:var(--muted);font-weight:400;font-size:.82rem;}

/* circuit pastille / badge */
.pastille{
  position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.94);padding:6px 12px 6px 9px;border-radius:var(--r-pill);
  font-size:.78rem;font-weight:600;color:var(--navy);box-shadow:var(--shadow-sm);letter-spacing:.01em;
}
.pastille .dot{width:11px;height:11px;border-radius:50%;flex:none;}
.dot{display:inline-block;width:12px;height:12px;border-radius:50%;}
.dot-chenin{background:var(--c-chenin);}
.dot-muses{background:var(--c-muses);}
.dot-tuffeau{background:var(--c-tuffeau);}
.dot-surprise{background:var(--c-surprise);}
.dot-indispo{background:var(--c-indispo);}

/* two big "portes d'entrée" blocks */
.portes{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.porte{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:440px;display:flex;align-items:flex-end;color:#fff;}
.porte img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.porte::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,50,58,0) 30%,rgba(34,50,58,.85) 100%);}
.porte:hover img{transform:scale(1.05);}
.porte-body{position:relative;z-index:2;padding:38px;}
.porte-body h3{color:#fff;font-family:var(--serif);font-size:clamp(1.8rem,2.6vw,2.4rem);font-weight:600;margin-bottom:8px;}
.porte-body p{color:#eef2ee;margin-bottom:16px;max-width:34ch;}
.porte-body .link-more{color:#fff;}
.porte-body .link-more:hover{border-color:#fff;}

/* split text+image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:center;}
.split--narrow-img{grid-template-columns:1.15fr .85fr;}
.split img.framed{border-radius:var(--r-lg);box-shadow:var(--shadow-md);width:100%;aspect-ratio:4/5;object-fit:cover;}
.split .body p:last-child{margin-bottom:0;}

/* feature cards w/ icon */
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.feature .ico{width:54px;height:54px;border-radius:14px;background:var(--green-soft);display:grid;place-items:center;margin-bottom:18px;color:var(--green-deep);}
.feature .ico svg{width:26px;height:26px;}
.feature h3{font-family:var(--sans);font-size:1.2rem;font-weight:600;margin-bottom:8px;}
.feature p{font-size:.95rem;margin-bottom:0;}

/* values chips */
.values{display:flex;flex-wrap:wrap;gap:12px;}
.value-chip{display:inline-flex;align-items:center;gap:9px;background:var(--cream);border:1px solid var(--line);border-radius:var(--r-pill);padding:10px 18px;font-weight:600;color:var(--navy);font-size:.96rem;}
.value-chip .dot{width:9px;height:9px;background:var(--green);}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.masonry-3{columns:3;column-gap:28px;}
.masonry-3 > *{break-inside:avoid;margin-bottom:28px;}
.testimonial{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:36px 40px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;}
.stars{display:flex;gap:3px;margin-bottom:16px;color:var(--green);}
.stars svg{width:19px;height:19px;}
.testimonial blockquote{margin:0 0 20px;font-family:var(--serif);font-style:italic;font-size:1.2rem;line-height:1.5;color:var(--navy);}
.testimonial .who b{color:var(--navy);font-size:1rem;}
.testimonial .who .ctx{display:block;color:var(--green-deep);font-weight:600;font-size:.86rem;margin-top:3px;}

/* ============================================================
   TARIF BLOCK
   ============================================================ */
.tarif{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-sm);}
.tarif .price{font-family:var(--serif);font-size:3rem;font-weight:600;color:var(--navy);line-height:1;}
.tarif .price small{font-family:var(--sans);font-size:1rem;font-weight:400;color:var(--muted);}
.tarif ul{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:14px;}
.tarif li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;}
.tarif li svg{width:20px;height:20px;color:var(--green-deep);flex:none;margin-top:2px;}
.tarif .note{font-size:.82rem;color:var(--muted);margin-top:18px;font-style:italic;}

/* itinerary steps */
.steps{list-style:none;display:flex;flex-direction:column;gap:0;position:relative;}
.steps li{display:grid;grid-template-columns:auto 1fr;gap:22px;padding-bottom:30px;position:relative;}
.steps li:not(:last-child)::before{content:"";position:absolute;left:21px;top:44px;bottom:-4px;width:2px;background:var(--line);}
.step-num{width:44px;height:44px;border-radius:50%;background:var(--white);border:2px solid currentColor;display:grid;place-items:center;font-weight:700;font-family:var(--serif);font-size:1.2rem;z-index:1;}
.steps h4{font-family:var(--sans);font-size:1.12rem;font-weight:600;margin-bottom:4px;color:var(--navy);}
.steps p{font-size:.95rem;margin-bottom:0;color:var(--ink);}

/* ============================================================
   CALENDAR
   ============================================================ */
.cal{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:26px;}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:14px;}
.cal-head h3{font-family:var(--serif);font-size:1.6rem;text-transform:capitalize;}
.cal-nav{display:flex;gap:8px;}
.cal-nav button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;display:grid;place-items:center;color:var(--navy);transition:.2s;}
.cal-nav button:hover{background:var(--cream);border-color:var(--green);color:var(--green-deep);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-dow{text-align:center;font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:6px 0;}
.cal-cell{aspect-ratio:1;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.95rem;position:relative;border:1px solid transparent;background:var(--cream);color:var(--ink);}
.cal-cell.empty{background:transparent;}
.cal-cell.has-event{cursor:pointer;font-weight:600;color:#fff;border:none;transition:transform .15s, box-shadow .15s;}
.cal-cell.has-event:hover{transform:scale(1.06);box-shadow:var(--shadow-sm);z-index:2;}
.cal-cell .ev-init{font-size:.62rem;font-weight:700;letter-spacing:.04em;opacity:.92;margin-top:1px;}
.cal-cell.ev-chenin{background:var(--c-chenin);}
.cal-cell.ev-muses{background:var(--c-muses);}
.cal-cell.ev-tuffeau{background:var(--c-tuffeau);}
.cal-cell.ev-indispo{background:var(--c-indispo);}
.cal-cell.dimmed{opacity:.22;}
.cal-legend{display:flex;flex-wrap:wrap;gap:18px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line);}
.cal-legend button{display:inline-flex;align-items:center;gap:9px;background:none;border:none;font-size:.92rem;font-weight:600;color:var(--navy);padding:4px 6px;border-radius:8px;transition:.2s;}
.cal-legend button:hover{background:var(--cream);}
.cal-legend button.off{opacity:.4;}
.cal-legend .dot{width:14px;height:14px;}
/* tooltip */
.cal-tip{position:fixed;z-index:200;background:var(--navy);color:#fff;border-radius:14px;padding:16px 18px;box-shadow:0 12px 40px rgba(0,0,0,.32);width:260px;font-size:.88rem;pointer-events:none;opacity:0;transform:translateY(8px) scale(.97);transition:opacity .18s,transform .18s;border-left:3px solid var(--green);}
.cal-tip.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
.cal-tip.tip-chenin{border-left-color:var(--c-chenin);}
.cal-tip.tip-muses{border-left-color:var(--c-muses);}
.cal-tip.tip-tuffeau{border-left-color:var(--c-tuffeau);}
.cal-tip.tip-surprise{border-left-color:var(--c-surprise);}
.cal-tip b{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.97rem;line-height:1.35;height:2.62rem;margin-bottom:11px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08);}
.cal-tip .meta{color:#9fb0ad;font-size:.82rem;display:flex;align-items:center;gap:8px;margin-top:8px;}
.cal-tip svg{width:14px;height:14px;flex-shrink:0;opacity:.7;}
.cal-tip a{display:flex;align-items:center;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08);color:var(--green);font-weight:600;font-size:.83rem;text-decoration:none;}
.cal-tip a:hover{color:#fff;}
/* mobile list of dates */
.cal-list{display:none;flex-direction:column;gap:10px;}
.cal-list a{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow-sm);}
.cal-list .when{font-weight:700;color:var(--navy);min-width:74px;font-size:.9rem;}
.cal-list .what b{display:block;color:var(--navy);font-size:.98rem;}
.cal-list .what span{font-size:.82rem;color:var(--muted);}
.cal-list .bar{width:6px;align-self:stretch;border-radius:6px;}

/* ============================================================
   FORMS
   ============================================================ */
.form-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,4vw,40px);box-shadow:var(--shadow-sm);}
.field{margin-bottom:20px;}
.field label{display:block;font-weight:600;color:var(--navy);font-size:.92rem;margin-bottom:7px;}
.field .req{color:var(--c-muses);}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(122,182,72,.18);}
.field textarea{resize:vertical;min-height:140px;}
.field .err{display:none;color:#c0392b;font-size:.84rem;margin-top:6px;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#c0392b;}
.field.invalid .err{display:block;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:.86rem;color:var(--muted);margin-bottom:22px;}
.consent input{width:18px;height:18px;margin-top:2px;flex:none;accent-color:var(--green-deep);}
.consent a{color:var(--green-deep);text-decoration:underline;}
.form-success{display:none;background:var(--green-soft);border:1px solid var(--green);border-radius:var(--r-md);padding:20px 22px;color:var(--navy);font-weight:600;align-items:center;gap:12px;}
.form-success.show{display:flex;}
.form-success svg{width:26px;height:26px;color:var(--green-deep);flex:none;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}

/* contact info card */
.contact-card{background:var(--cream);border:1.5px solid var(--green);border-radius:var(--r-lg);padding:clamp(26px,4vw,40px);height:100%;}
.contact-card .ico{width:58px;height:58px;border-radius:50%;background:var(--green);display:grid;place-items:center;color:#fff;margin-bottom:20px;}
.contact-card .ico svg{width:27px;height:27px;}
.contact-card h3{font-family:var(--serif);font-size:1.7rem;margin-bottom:10px;}
.contact-card .phone{font-family:var(--serif);font-size:2rem;font-weight:600;color:var(--green-deep);display:inline-block;margin:4px 0 8px;}

/* ============================================================
   BLOG
   ============================================================ */
.post-meta{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--muted);margin-bottom:10px;font-weight:600;letter-spacing:.02em;}
.post-tag{color:var(--green-deep);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;}
.article-body{max-width:720px;margin:0 auto;font-size:1.12rem;line-height:1.8;}
.article-body h2{font-family:var(--serif);font-size:1.9rem;margin:1.6em 0 .5em;}
.article-body h3{font-size:1.3rem;margin:1.4em 0 .4em;}
.article-body p{margin-bottom:1.2em;}
.article-body blockquote{border-left:4px solid var(--green);background:var(--cream);padding:18px 24px;margin:1.6em 0;border-radius:0 var(--r-md) var(--r-md) 0;font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--navy);}
.article-body img{border-radius:var(--r-md);margin:1.6em 0;width:100%;}
.article-body figcaption{font-size:.85rem;color:var(--muted);text-align:center;margin-top:-1em;margin-bottom:1.6em;}

/* ============================================================
   LEGAL / DOC
   ============================================================ */
.doc-layout{display:grid;grid-template-columns:260px 1fr;gap:50px;align-items:start;}
.doc-toc{position:sticky;top:calc(var(--header-h) + 24px);background:var(--cream);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;}
.doc-toc h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.doc-toc ol{list-style:none;counter-reset:toc;display:flex;flex-direction:column;gap:9px;}
.doc-toc li{counter-increment:toc;}
.doc-toc a{font-size:.9rem;color:var(--ink);display:flex;gap:8px;line-height:1.35;}
.doc-toc a::before{content:counter(toc)".";color:var(--green-deep);font-weight:700;}
.doc-toc a:hover{color:var(--green-deep);}
.doc-content h2{font-family:var(--serif);font-size:1.7rem;margin:1.8em 0 .5em;scroll-margin-top:100px;}
.doc-content h2:first-child{margin-top:0;}
.doc-content h3{font-size:1.15rem;margin:1.4em 0 .4em;}
.doc-content p,.doc-content li{font-size:1rem;line-height:1.75;}
.doc-content ul,.doc-content ol{padding-left:1.3em;margin-bottom:1.2em;}
.doc-content li{margin-bottom:.5em;}
.placeholder-field{background:#fff4e0;border:1px dashed var(--c-muses);border-radius:5px;padding:1px 7px;font-weight:600;color:#a85a1a;font-size:.92em;white-space:nowrap;}
.callout{background:var(--green-soft);border:1px solid var(--green);border-radius:var(--r-md);padding:18px 22px;margin:1.5em 0;font-size:.96rem;}
.callout b{color:var(--green-deep);}
.checklist{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-md);padding:22px 26px;margin:1.5em 0;}
.checklist li{list-style:none;display:flex;gap:11px;align-items:flex-start;margin-bottom:10px;}
.checklist li::before{content:"";width:18px;height:18px;border:2px solid var(--green);border-radius:5px;flex:none;margin-top:3px;}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:clamp(44px,6vw,80px);text-align:center;color:#fff;}
.cta-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cta-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(34,50,58,.86),rgba(44,62,70,.74));}
.cta-banner > *{position:relative;z-index:2;}
.cta-banner h2{color:#fff;font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:600;margin-bottom:14px;}
.cta-banner p{color:#eef2ee;max-width:46ch;margin:0 auto 28px;font-size:1.1rem;}

/* misc */
.divider-quote{text-align:center;max-width:760px;margin:0 auto;}
.divider-quote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3vw,2.1rem);color:var(--navy);line-height:1.4;}
.divider-quote cite{display:block;margin-top:16px;font-style:normal;font-family:var(--sans);font-weight:600;color:var(--green-deep);font-size:.95rem;letter-spacing:.04em;}
.placeholder-img{background:repeating-linear-gradient(45deg,var(--cream-deep),var(--cream-deep) 12px,var(--cream) 12px,var(--cream) 24px);display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:ui-monospace,monospace;font-size:.8rem;text-align:center;padding:20px;}
.mb-0{margin-bottom:0;}
.mt-s{margin-top:18px;}
.mt-m{margin-top:32px;}
.maxw-prose{max-width:62ch;}

/* fade-in on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* tight desktop (nav still visible): collapse the CTA to an icon-only circle
   so the green button never spills past the header edge */
@media(min-width:1025px) and (max-width:1240px){
  .btn-reserve-label{display:none;}
  .btn-reserve{width:42px;height:42px;padding:0;gap:0;justify-content:center;border-radius:50%;}
  .btn-reserve-ico{display:grid;place-items:center;line-height:0;}
  .btn-reserve svg{display:block;width:1.25em;height:1.25em;}
  .site-header.is-stuck .btn-reserve{width:40px;height:40px;}
}
@media(max-width:1024px){
  .main-nav,.header-actions{display:none;}
  .burger{display:flex;}
  .mega{display:none;}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px;}
}
@media(max-width:880px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}
  .masonry-3{columns:2;}
  .portes{grid-template-columns:1fr;}
  .porte-body{padding:26px;}
  .split,.doc-layout{grid-template-columns:1fr;gap:34px;}
  .doc-toc{position:static;}
  .split img.framed{aspect-ratio:16/10;max-height:420px;}
  /* annule le sticky inline dès que .split passe en 1 colonne */
  .split > [style*="sticky"]{position:static!important;top:auto!important;}
}
@media(max-width:640px){
  body{font-size:16px;}
  .wrap,.wrap--wide,.narrow,.header-inner,.hero-inner{padding-left:20px;padding-right:20px;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .masonry-3{columns:1;}
  .field-row{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:30px;padding:50px 0 36px;text-align:center;}
  .footer-brand p{max-width:none;}
  .socials{justify-content:center;}
  .footer-col ul{align-items:center;}
  .footer-contact a{justify-content:center;}
  .footer-bottom{flex-direction:column;align-items:center;text-align:center;}
  .footer-bottom nav{justify-content:center;}
  .cal{padding:16px;}
  .cal-grid{display:none;}
  .cal-list{display:flex;}
  .cal-legend{gap:12px;}
  .brand-text span{display:none;}
  .hero-cta .btn{flex:1;justify-content:center;}
  /* touch targets ≥ 44px */
  .btn{min-height:44px;}
  .link-more{min-height:44px;}
  .burger{padding:12px 10px;}
  .cal-nav button{width:44px;height:44px;}
  .mobile-panel .m-sub{padding:14px 0;}
  .cal-legend button{padding:8px 10px;}
  /* component padding */
  .testimonial{padding:24px 20px;}
  .feature{padding:24px 20px;}
  .tarif{padding:22px 20px;}
  .porte-body{padding:22px;}
  .contact-card{height:auto;}
  /* hero */
  .hero-mini-meta{gap:12px;font-size:.88rem;}
  /* cta banner */
  .cta-banner{padding:clamp(36px,10vw,60px) 20px;}
}
