:root{
  --font-display: "la-parisienne-script-regular", "Parisienne", cursive;
  --font-body: "source-sans-3", "Source Sans 3", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --ink:#52304f;
  --muted:#7f6f6a;
  --bg:#fffaf7;
  --section:#f6eae3;
  --stroke:#e5e0dc;
  --accent:#b06969;
}

*{box-sizing:border-box}
body{
  margin:0; color:var(--ink); background:var(--bg);
  font:16px/1.75 var(--font-body);
}
.wop-container{ max-width:980px; margin:auto; padding:0 20px; }

h1,h2,h3,.wop-display{ font-family: var(--font-display); letter-spacing:.2px; font-weight:400; }
h1{ font-size: clamp(40px, 5vw, 74px); line-height:1.02; margin:0 0 10px; }
h2{ font-size: clamp(30px, 3.6vw, 44px); line-height:1.15; margin:0 0 18px; }
h3{ font-size: clamp(20px, 2.2vw, 26px); line-height:1.25; margin:0 0 10px; font-family: var(--font-body); font-weight:600; }
p.lead{ font-size: clamp(16px, 1.7vw, 18px); color:var(--muted); margin:0 0 24px; }

.wop-header{ position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid var(--stroke); }
.wop-header .wop-container{ display:flex; align-items:center; justify-content:space-between; height:68px; position:relative; }
.wop-brand{ font-weight:400; text-decoration:none; color:var(--ink); font-family: var(--font-display); font-size:22px; }
.wop-nav ul{ display:flex; gap:16px; list-style:none; margin:0; padding:0; }
.wop-nav a{ display:block; padding:12px 10px; color:var(--ink); text-decoration:none; font-weight:600; font-family: var(--font-body); }
.wop-nav a.active{ border-bottom:2px solid var(--ink); }
.wop-burger{
  display:none; border:0; background:transparent; padding:8px; cursor:pointer;
}
.wop-burger span{
  display:block; width:22px; height:2px; background:var(--ink); margin:4px 0;
}
.wop-nav-close{
  display:none; border:0; background:transparent; font-size:26px; line-height:1; cursor:pointer;
}

.wop-main{ scroll-behavior:smooth; }
.wop-section{ padding:88px 0; }
.wop-section.alt{ background:var(--section); }
.wop-hero{ padding:0; }

.hero-image{
  position:relative;
  min-height: 85vh;
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
}
.hero-overlay{
  position:absolute; inset:0;
  background: rgba(255,255,255,0.35);
}
.hero-content{
  position:relative;
  text-align:center;
}
.hero-title{ font-size: clamp(52px, 7vw, 104px); }
.hero-sub{ opacity:.95; margin:0 0 22px; font-family: var(--font-body); font-weight:400; font-size:20px; }
.hero-cta{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

.wop-btn{
  display:inline-block; padding:12px 18px; border-radius:999px; border:1px solid var(--ink);
  text-decoration:none; font-family: var(--font-body); font-weight:600;
  transition:transform .2s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease;
}
.wop-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(82,48,79,.18); }
.wop-btn:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }
.wop-btn--accent{ background:var(--accent); color:#fff; border-color:var(--accent); }
.wop-btn--accent:hover{ background:#9f5e5e; border-color:#9f5e5e; }
.wop-btn--ghost{ background:transparent; border-color:var(--ink); color:var(--ink); }
.wop-btn--ghost:hover{ background:var(--section); border-color:var(--accent); color:var(--ink); }

.wop-icon{
  width:18px;
  height:18px;
  stroke:var(--accent);
  stroke-width:1;
  fill:none;
  flex:0 0 auto;
}
.wop-icon-title{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.wop-alert{ margin:18px 0 0; background:#e8f8f0; border-left:4px solid #2da771; padding:10px; border-radius:6px; font-family: var(--font-body); }
.wop-alert--error{ background:#fdeaea; border-left-color:#e53e3e; }

.wop-form{ display:grid; gap:18px; }
.wop-form .group{ display:grid; gap:8px; }
.wop-form label{ font-weight:600; font-family: var(--font-body); font-size:16px; }
.wop-form small{ color:var(--muted); }
.wop-form input, .wop-form textarea{
  width:100%; padding:12px 14px; border:1px solid #ddd; border-radius:10px; background:#fff;
  font-family: var(--font-body); font-size:16px;
}
.wop-form input[type="radio"]{
  width:auto;
  padding:0;
}
.wop-form textarea{ min-height:110px; }
.wop-form .inline{ display:flex; gap:16px; flex-wrap:wrap; }
.wop-form .inline .choice{
  display:flex; align-items:center; gap:8px; padding:10px 14px;
  border:1px solid #ddd; border-radius:999px; cursor:pointer; background:#fff;
  font-family: var(--font-body); font-weight:600; font-size:16px; justify-content: flex-start;
}
.wop-form input[type="radio"]{ accent-color:var(--ink); }

.agenda{ display:grid; gap:16px; margin:0; padding:0; }
.agenda .ev{
  display:grid; grid-template-columns:92px 1fr; gap:16px;
  border:1px solid var(--stroke); border-radius:14px; padding:16px; background:#fff;
}
@media (max-width:640px){ .agenda .ev{ grid-template-columns:1fr; } }

details{
  border:1px solid var(--stroke);
  border-radius:12px;
  padding:12px 16px;
  background:#fff;
  margin:0 0 12px;
}
details summary{
  cursor:pointer;
  font-weight:600;
  list-style:none;
}
details summary::-webkit-details-marker{ display:none; }
details > p{
  margin:10px 0 0;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transform:translateY(-6px);
  transition:max-height .3s ease, opacity .3s ease, transform .3s ease;
}
details[open] > p{
  max-height:220px;
  opacity:1;
  transform:translateY(0);
}

.badge{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  border:1px solid var(--stroke); border-radius:12px; padding:10px 12px; min-width:72px; min-height:72px;
  background:linear-gradient(180deg,#fff, #f9f9f9);
  font-family: var(--font-body);
}
.badge .mois{ font-weight:800; letter-spacing:1px; font-size:12px; }
.badge .jour{ font-size:22px; line-height:1; }

.cards{ display:grid; gap:16px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.card{ border:1px solid var(--stroke); border-radius:12px; padding:16px; background:#fff; }
.grid{ display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.grid img{ width:100%; height:auto; border-radius:12px; display:block; }

.wop-footer{ border-top:1px solid var(--stroke); padding:28px 0; color:var(--muted); font-size:14px; font-family: var(--font-body); }

@media (max-width:960px){ .wop-section{ padding:72px 0; } }
@media (max-width:768px){
  .wop-header .wop-container{ height:60px; }
  .wop-header .wop-container{ justify-content:center; }
  .wop-brand{ margin:0 auto; }
  .wop-burger{ display:block; position:absolute; left:20px; }
  .wop-nav{
    position:fixed; top:0; left:0; height:100%; width:78%; max-width:320px;
    background:#fff; transform:translateX(-100%); transition:transform .3s ease;
    box-shadow:8px 0 24px rgba(0,0,0,.12); padding:70px 20px 20px; z-index:60;
  }
  .wop-nav.open{ transform:translateX(0); }
  .wop-nav ul{ flex-direction:column; gap:10px; }
  .wop-nav a{ padding:10px 0; }
  .wop-nav-close{ display:block; position:absolute; top:14px; right:16px; }
  .wop-form .inline{ flex-direction:column; align-items:stretch; }
  .wop-form .inline .choice{ width:100%; justify-content:flex-start; }
  .hero-image{ min-height: 72vh; }
}
