/* ===================== TOKENS ===================== */
:root{
  --cream:#f7f1e8;
  --sand:#ede2d1;
  --sand-deep:#e3d4be;
  --terracotta:#b86b4b;
  --terracotta-dark:#9e5739;
  --clay:#a9603f;
  --olive:#6e7257;
  --ink:#332d27;
  --ink-soft:#5f564c;
  --muted:#8a7f72;
  --white:#fffdf9;
  --shadow:0 18px 50px -22px rgba(51,45,39,.45);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',system-ui,-apple-system,Segoe UI,sans-serif;
  --maxw:1160px;
}

/* ===================== RESET ===================== */
*,*::before,*::after{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-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:.01em}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,3rem)}
.section{padding-block:clamp(4rem,9vw,7.5rem)}
.visually-hidden,.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* language toggle */
[data-lang="fr"] .en{display:none}
[data-lang="en"] .fr{display:none}

.section-label{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  color:var(--terracotta);
  margin-bottom:1rem;
  font-weight:400;
}
.section-label.light{color:var(--sand)}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-block;
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:1rem 1.9rem;
  border-radius:2rem;
  transition:.3s ease;
  cursor:pointer;
  border:1px solid transparent;
}
.btn-solid{background:var(--terracotta);color:var(--white)}
.btn-solid:hover{background:var(--terracotta-dark);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,253,249,.6);color:var(--white)}
.btn-ghost:hover{background:rgba(255,253,249,.14)}

/* ===================== HEADER ===================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:.35s ease;
}
.site-header.scrolled{
  background:rgba(247,241,232,.92);
  backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(51,45,39,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding-block:1.1rem}
.brand{
  font-family:var(--serif);font-size:1.55rem;font-weight:600;
  color:var(--white);letter-spacing:.02em;transition:color .35s;
}
.site-header.scrolled .brand{color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:2rem;margin-left:auto}
.nav-actions{display:flex;align-items:center;gap:1.25rem;margin-left:2rem;position:relative;z-index:60}
.nav-links a{
  font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--white);transition:color .35s,opacity .3s;opacity:.92;
}
.nav-links a:hover{opacity:1}
.site-header.scrolled .nav-links a{color:var(--ink-soft)}
.nav-cta{
  border:1px solid rgba(255,253,249,.6);
  padding:.55rem 1.1rem;border-radius:2rem;
}
.site-header.scrolled .nav-cta{border-color:var(--terracotta);color:var(--terracotta)!important;opacity:1}
.lang-switch{
  display:inline-flex;align-items:center;gap:.2rem;cursor:pointer;
  font-family:var(--sans);font-size:.8rem;letter-spacing:.06em;
  /* dark translucent pill so the white text stays readable over bright hero areas */
  background:rgba(33,27,22,.32);color:var(--white);
  border:1px solid rgba(255,253,249,.65);border-radius:2rem;
  padding:.4rem .85rem;transition:.3s ease;
}
.lang-switch:hover{background:rgba(33,27,22,.45)}
.site-header.scrolled .lang-switch,
.site-header.menu-open .lang-switch{
  background:rgba(184,107,75,.08);border-color:rgba(184,107,75,.4);color:var(--ink);
}
.lang-switch .sep{opacity:.4}
/* active language = bold; inactive = dimmed */
.lang-switch .lang-fr-btn,.lang-switch .lang-en-btn{opacity:.7;font-weight:400}
[data-lang="fr"] .lang-fr-btn,[data-lang="en"] .lang-en-btn{opacity:1;font-weight:500}
/* once scrolled/menu open, the active language picks up the brand terracotta */
[data-lang="fr"] .site-header.scrolled .lang-fr-btn,
[data-lang="en"] .site-header.scrolled .lang-en-btn,
[data-lang="fr"] .site-header.menu-open .lang-fr-btn,
[data-lang="en"] .site-header.menu-open .lang-en-btn{color:var(--terracotta)}

.nav-toggle{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:.4rem;position:relative;z-index:61}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--white);transition:transform .3s ease,opacity .2s ease,background .35s}
.site-header.scrolled .nav-toggle span,
.site-header.menu-open .nav-toggle span{background:var(--ink)}
.site-header.menu-open .lang-switch{color:var(--ink)}
/* burger -> X */
.nav-toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===================== HERO ===================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-img{
  position:absolute;inset:0;background-size:cover;background-position:center 30%;
  animation:slowzoom 18s ease-out forwards;
}
@keyframes slowzoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(51,45,39,.62) 0%,rgba(51,45,39,.28) 55%,rgba(51,45,39,.1) 100%);
}
.hero-content{position:relative;color:var(--white);max-width:760px;padding-top:5rem}
.eyebrow{
  text-transform:uppercase;letter-spacing:.34em;font-size:.74rem;
  margin-bottom:1.4rem;opacity:.92;
}
.hero h1{
  font-size:clamp(2.7rem,6.4vw,4.9rem);
  font-weight:500;margin-bottom:1.4rem;text-shadow:0 2px 30px rgba(0,0,0,.25);
}
.hero-sub{
  font-size:clamp(1.05rem,2vw,1.32rem);
  max-width:33em;margin-bottom:2.3rem;font-weight:300;line-height:1.6;opacity:.96;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.scroll-cue{
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);
  color:var(--white);font-size:1.4rem;opacity:.8;animation:bob 2.2s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ===================== STORY ===================== */
.story{background:var(--cream)}
.story-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.story-media img{border-radius:6px;box-shadow:var(--shadow);object-fit:cover;width:100%;aspect-ratio:4/5}
.story-text h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin-bottom:1.6rem;color:var(--ink)}
.story-text p{margin-bottom:1.1rem;color:var(--ink-soft);max-width:38em}
.story-text p:last-child{margin-bottom:0}

/* ===================== QUOTE ===================== */
.quote{position:relative;display:flex;align-items:center;min-height:62vh;text-align:center}
.quote-img{position:absolute;inset:0;background-size:cover;background-position:center 35%}
.quote-overlay{position:absolute;inset:0;background:linear-gradient(rgba(40,33,28,.6),rgba(40,33,28,.6))}
.quote blockquote{position:relative;color:var(--white);max-width:880px}
.quote blockquote p{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.6rem,3.6vw,2.7rem);line-height:1.3;margin-bottom:1.4rem;
}
.quote cite{
  font-family:var(--sans);font-style:normal;letter-spacing:.28em;
  text-transform:uppercase;font-size:.78rem;opacity:.85;
}

/* ===================== SERVICES ===================== */
.services{background:var(--sand)}
.section-head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-head h2{font-size:clamp(2rem,4vw,3rem);color:var(--ink)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.card{
  background:var(--white);border-radius:8px;overflow:hidden;
  box-shadow:0 14px 40px -26px rgba(51,45,39,.5);
  transition:transform .35s ease,box-shadow .35s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 54px -28px rgba(51,45,39,.55)}
.card-img{height:240px;background-size:cover;background-position:center}
.card-body{padding:1.8rem 1.7rem 2rem}
.card-body h3{font-size:1.55rem;margin-bottom:.7rem;color:var(--ink)}
.card-body p{color:var(--ink-soft);font-size:.97rem}

/* ===================== RETREATS BANNER ===================== */
.retreats{position:relative;display:flex;align-items:center;min-height:64vh;overflow:hidden}
.retreats-img{position:absolute;inset:0;background-size:cover;background-position:50% 16%}
.retreats-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(51,45,39,.66),rgba(51,45,39,.25))}
.retreats-content{position:relative;color:var(--white);max-width:620px;padding-block:4rem}
.retreats-content h2{font-size:clamp(1.9rem,3.8vw,2.9rem);margin-bottom:1.1rem}
.retreats-content p{margin-bottom:1.8rem;opacity:.95;font-size:1.08rem}
/* taller banner on desktop so the group photo isn't cropped so tightly */
@media(min-width:881px){.retreats{min-height:80vh}}

/* ===================== NEWSLETTER ===================== */
.newsletter{background:linear-gradient(180deg,var(--cream),var(--sand-deep))}
.newsletter-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.newsletter-media img{border-radius:6px;box-shadow:var(--shadow);object-fit:cover;width:100%;aspect-ratio:3/4}
.newsletter-text h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:1.4rem;color:var(--ink)}
.newsletter-text>p{color:var(--ink-soft);margin-bottom:1.1rem;max-width:40em}
.signup{margin-top:2rem}
.field-row{display:flex;flex-wrap:wrap;gap:.7rem}
.signup input[type=email]{
  flex:1 1 240px;min-width:0;
  padding:1rem 1.2rem;border:1px solid var(--sand-deep);border-radius:2rem;
  background:var(--white);font-family:var(--sans);font-size:1rem;color:var(--ink);
}
.signup input[type=email]:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(184,107,75,.16)}
.signup .btn{flex:0 0 auto;cursor:pointer;border:none}
.consent{font-size:.82rem;color:var(--muted);margin-top:1rem;max-width:42em;line-height:1.5}
.form-message{margin-top:1rem;font-size:.95rem;min-height:1.2em;font-weight:400}
.form-message.ok{color:var(--olive)}
.form-message.err{color:var(--terracotta-dark)}

/* ===================== GALLERY ===================== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.g-item{aspect-ratio:3/4;background-size:cover;background-position:center;transition:transform .6s ease,filter .4s}
.g-item:hover{transform:scale(1.04);filter:saturate(1.08)}

/* ===================== FOOTER ===================== */
.site-footer{background:var(--ink);color:var(--cream);text-align:center;padding-block:clamp(3rem,6vw,4.5rem)}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:.9rem}
.footer-brand{font-family:var(--serif);font-size:1.9rem;font-weight:600}
.footer-tag{font-style:italic;font-family:var(--serif);font-size:1.2rem;opacity:.82;max-width:24em}
.footer-ig{display:inline-flex;align-items:center;gap:.5rem;color:var(--cream);opacity:.9;letter-spacing:.05em;transition:opacity .3s;margin-top:.4rem}
.footer-ig:hover{opacity:1;color:var(--terracotta)}
.footer-copy{font-size:.78rem;opacity:.55;letter-spacing:.06em;margin-top:.6rem}

/* ===================== RESPONSIVE ===================== */
@media(max-width:880px){
  .nav-toggle{display:flex}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,330px);z-index:40;
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.8rem;
    margin-left:0;
    background:var(--cream);padding:5.5rem 2.4rem 3rem;
    transform:translateX(100%);transition:transform .4s ease;box-shadow:var(--shadow);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a,.site-header .nav-links a{color:var(--ink-soft)}
  .nav-cta{color:var(--terracotta)!important;border-color:var(--terracotta)}
  /* lang pill keeps its hero/scrolled colours (white over hero, ink once scrolled) */
  .story-grid,.newsletter-grid{grid-template-columns:1fr}
  .story-media{order:-1;max-width:440px;margin-inline:auto}
  .newsletter-media{max-width:380px;margin-inline:auto}
  .cards{grid-template-columns:1fr;max-width:430px;margin-inline:auto}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  /* hero: darker scrim + text shadow so copy stays legible over the photo */
  .hero-overlay{
    background:linear-gradient(rgba(33,27,22,.42),rgba(33,27,22,.42)),
               linear-gradient(0deg,rgba(33,27,22,.62) 0%,rgba(33,27,22,0) 55%);
  }
  .hero-content{padding-top:6rem}
  .hero h1{text-shadow:0 2px 16px rgba(0,0,0,.5)}
  .hero-sub{text-shadow:0 1px 12px rgba(0,0,0,.55)}
  .eyebrow{text-shadow:0 1px 10px rgba(0,0,0,.55)}
}
@media(max-width:520px){
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:100%;text-align:center}
  .field-row{flex-direction:column;gap:.6rem}
  /* reset flex so the column layout doesn't read 240px as the input HEIGHT */
  .signup input[type=email]{flex:0 0 auto;width:100%;padding:.9rem 1.2rem;font-size:1rem}
  .signup .btn{width:100%;padding:.95rem 1.4rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
}
