:root{
  --or:#E8A820;--orcl:#F5C84A;--orpal:#FDF3D8;
  --marine:#1A2744;--mmd:#243560;--bleu:#4A90C4;
  --blanc:#FAFAF7;--perle:#F0EDE8;--gris:#9A9690;
  --shadow:0 8px 32px rgba(26,39,68,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--blanc);color:var(--marine);line-height:1.7}
a{text-decoration:none;color:inherit}

/* =========================
   NAVIGATION COMMUNE
========================= */
nav{
  position:sticky;top:0;z-index:999;
  height:68px;padding:0 40px;display:flex;align-items:center;justify-content:space-between;
  background:rgba(26,39,68,.97);backdrop-filter:blur(14px)
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:44px;height:44px;object-fit:cover;border-radius:50%}
.brand .s{font-family:'Dancing Script',cursive;font-size:26px;color:#fff}
.nav-links{display:flex;gap:22px;flex-wrap:wrap}
.nav-links a{font-size:13px;color:rgba(255,255,255,.75)}
.nav-links a:hover{color:var(--or)}

/* =========================
   COMPOSANTS RÉUTILISABLES
========================= */
.container{max-width:1160px;margin:0 auto;padding:0 20px}
.page{padding:78px 0}
.tag{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--or);font-weight:600}
h1,h2{font-family:'Playfair Display',serif;line-height:1.2}
h1{font-size:clamp(32px,5vw,56px)}
h2{font-size:clamp(24px,4vw,38px);margin-bottom:10px}
p.lead{font-family:'Cormorant Garamond',serif;font-size:21px;font-style:italic;color:var(--gris)}
p.txt{font-size:14px;color:#64605a}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:999px;border:0;cursor:pointer;font-size:14px}
.btn-or{background:var(--or);color:var(--marine)}
.btn-or:hover{background:var(--orcl)}
.btn-outline{background:transparent;border:2px solid var(--marine);color:var(--marine)}

/* =========================
   HERO / INDEX
========================= */
.hero{
  min-height:84vh;background:linear-gradient(150deg,#091523 0%,#1A2744 50%,#1e3d5f 100%);
  display:grid;place-items:center;padding:40px 0;
}
.hero-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero-title{font-family:'Dancing Script',cursive;font-size:clamp(64px,9vw,114px);line-height:.9;color:#fff}
.hero-title span{color:var(--or)}
.hero-sub{font-family:'Playfair Display',serif;color:rgba(255,255,255,.55);font-style:italic;margin:10px 0 16px}
.hero-desc{color:rgba(255,255,255,.68);max-width:520px}
.hero-box{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:12px}
.hero-box img{width:100%;border-radius:14px;display:block}
.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* =========================
   GRILLES DE CARTES
========================= */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.card{background:#fff;border:1px solid var(--perle);border-radius:12px;padding:24px}
.card h3{font-family:'Playfair Display',serif;margin-bottom:8px}
.price{font-family:'Dancing Script',cursive;color:var(--or);font-size:25px}
.dark{background:var(--marine);color:#fff}
.dark .txt,.dark .lead{color:rgba(255,255,255,.7)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--perle)}
.faq-q{padding:18px 0;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;gap:10px}
.faq-a{display:none;padding:0 0 16px;color:var(--gris)}
.faq-item.open .faq-a{display:block}

/* FOOTER */
footer{background:var(--marine);color:rgba(255,255,255,.72);padding:40px 0;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}
.foot-title{color:var(--or);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px}
.foot-col a{display:block;margin-bottom:6px;font-size:13px}

@media (max-width:960px){
  .hero-wrap,.grid-3,.foot-grid{grid-template-columns:1fr}
  nav{padding:12px 16px;height:auto;flex-direction:column;gap:8px}
}
