/* ============================================================
   Site d'Amélie Daumas — Psychologue
   Design fidèle à la version Wix : fonds lavande et bleu-gris,
   cartes blanches arrondies, titres violets centrés.
   Pour changer une couleur : modifiez-la ici, tout suit.
   ============================================================ */

:root {
  --lavande: #d2c9e9;          /* fond principal lavande */
  --lavande-clair: #e3def2;    /* sections plus claires */
  --bleu-gris: #d6d4da;        /* sections gris clair */
  --bleu-gris-carte: #aeabb6;  /* cartes gris-mauve (étapes EMDR) */
  --violet-titre: #32175a;     /* titres */
  --violet-texte: #46306e;     /* texte courant */
  --bouton: #5d3c8b;           /* boutons en violet foncé */
  --bande-violette: #4a2d73;   /* bandeau identification */
  --blanc: #ffffff;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: "Poppins", system-ui, sans-serif;
  background: var(--lavande);
  color: var(--violet-texte);
  line-height: 1.7;
  font-size: 1.02rem;
}

h1, h2, h3 {
  color: var(--violet-titre);
  font-weight: 700;
  line-height: 1.25;
}

h1 { font-size: clamp(2.1rem, 5vw, 3.2rem); text-align: center; }
h2 { font-size: clamp(1.7rem, 4vw, 2.5rem); text-align: center; margin-bottom: 1.2rem; }
h3 { font-size: 1.25rem; margin-bottom: .6rem; }

p + p { margin-top: 1rem; }

a { color: var(--violet-titre); }

img { max-width: 100%; display: block; }

/* ---------- En-tête / navigation ---------- */
header {
  background: #e8e7ec;          /* gris perle */
  border-bottom: 1px solid #d3d1d9;
  position: sticky;
  top: 0;
  z-index: 50;
}

.nav-wrap {
  max-width: 1180px;
  margin: 0 auto;
  padding: .9rem 1.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.brand {
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
}

.brand img { height: 105px; width: auto; }

.brand span {
  font-weight: 600;
  font-size: 1rem;
  color: var(--violet-titre);
  line-height: 1.25;
}

nav {
  flex: 1;
  display: flex;
  justify-content: center;   /* menu centré entre logo et bouton */
}

nav ul {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  list-style: none;
}

nav a {
  text-decoration: none;
  color: var(--violet-texte);
  font-weight: 500;
  font-size: .94rem;
  padding: .3rem 0;
  border-bottom: 2px solid transparent;
}

nav a:hover, nav a.actif {
  color: var(--violet-titre);
  border-bottom-color: var(--violet-titre);
}

.btn-rdv {
  text-decoration: none;
  background: var(--bouton);
  color: var(--blanc) !important;
  padding: .55rem 1.2rem !important;
  border-radius: 999px;
  border-bottom: none !important;
  font-weight: 600;
}

.btn-rdv:hover { background: var(--violet-titre); }

.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.8rem;
  color: var(--violet-titre);
  cursor: pointer;
}

/* ---------- Sections pleine largeur colorées ---------- */
.s-lavande { background: var(--lavande); }
.s-clair   { background: var(--lavande-clair); }
.s-bleu    { background: var(--bleu-gris); }
.s-bande   { background: var(--bande-violette); color: var(--blanc); }

.s-bleu, .s-bleu p { color: var(--violet-titre); }

.conteneur {
  max-width: 1180px;
  margin: 0 auto;
  padding: 4rem 1.4rem;
}

/* ---------- Héros : texte + image arrondie ---------- */
.duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.duo .texte { text-align: center; }

.duo-asym { grid-template-columns: 1.6fr 1fr; }

.image-reduite {
  max-width: 67%;
  margin-left: auto;
  margin-right: auto;
}
.duo .texte h1 { margin-bottom: 1.4rem; }

.image-arrondie {
  border-radius: 22px;
  width: 100%;
  object-fit: cover;
}

/* ---------- Cartes blanches ---------- */
.cartes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  gap: 1.6rem;
  margin-top: 2.2rem;
}

.carte {
  background: var(--blanc);
  border: 1px solid rgba(68, 57, 138, .28);
  border-radius: 24px;
  padding: 1.8rem;
}

.carte h3 { color: var(--violet-titre); }

/* Carte centrée avec petit trait au-dessus du titre (accueil) */
.carte-centree { text-align: center; padding: 2.6rem 2rem; }

.carte-centree::before {
  content: "";
  display: block;
  width: 48px;
  height: 3px;
  background: var(--violet-titre);
  margin: 0 auto 1.6rem;
}

/* Cartes teintées sur fond bleu-gris (étapes EMDR) */
.carte-bleue {
  background: var(--bleu-gris-carte);
  border: none;
  border-radius: 24px;
  padding: 1.8rem;
}

.carte-bleue h3, .carte-bleue p { color: var(--violet-titre); }

/* Carte lavande (localisation, accès) */
.carte-lavande {
  background: var(--lavande);
  border: 1px solid rgba(68, 57, 138, .3);
  border-radius: 14px;
  padding: 2.2rem;
}

.etape {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--violet-texte);
  margin-bottom: .5rem;
}

/* ---------- Listes à puces ---------- */
.liste-points {
  list-style: disc;
  padding-left: 1.4rem;
  margin-top: 1rem;
}

.liste-points li { margin-bottom: .55rem; }

.liste-centree {
  display: table;
  margin: 1.2rem auto 0;
  text-align: left;
}

/* ---------- Boutons ---------- */
.bouton {
  display: inline-block;
  background: var(--bouton);
  color: var(--blanc);
  font-weight: 600;
  text-decoration: none;
  padding: .85rem 2.2rem;
  border-radius: 999px;
  border: none;
  font-size: 1rem;
  font-family: inherit;
  cursor: pointer;
}

.bouton:hover { background: var(--violet-titre); }

.centre { text-align: center; }

/* ---------- Bandeau identification (violet foncé) ---------- */
.encadre-blanc {
  border: 1px solid rgba(255, 255, 255, .55);
  border-radius: 10px;
  padding: 2.2rem;
  text-align: center;
  max-width: 880px;
  margin: 0 auto;
}

.s-bande h2, .s-bande p, .s-bande h3 { color: var(--blanc); }

/* ---------- Bannière pinceaux (EMDR) ---------- */
.banniere img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
}

/* ---------- Formulaire ---------- */
.panneau-form {
  background: var(--lavande-clair);
  border: 1px solid rgba(68, 57, 138, .25);
  border-radius: 28px;
  padding: 2.4rem;
}

form .champ { margin-bottom: 1.2rem; }

form label {
  display: block;
  font-weight: 500;
  font-size: .92rem;
  margin-bottom: .35rem;
  color: var(--violet-texte);
}

form input, form textarea {
  width: 100%;
  padding: .8rem 1rem;
  border: 1px solid rgba(68, 57, 138, .35);
  border-radius: 10px;
  font-family: inherit;
  font-size: 1rem;
  background: #d5cef2;
  color: var(--violet-titre);
}

form input::placeholder, form textarea::placeholder { color: #7a6fb0; }

form input:focus, form textarea:focus {
  outline: 2px solid var(--violet-titre);
  background: var(--blanc);
}

/* ---------- Coordonnées contact ---------- */
.coordonnees {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  text-align: center;
  margin-top: 2rem;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.coordonnees .libelle {
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: .95rem;
  color: var(--violet-texte);
}

/* ---------- Pied de page ---------- */
footer {
  background: var(--lavande-clair);
  text-align: center;
  padding: 3rem 1.2rem 2.2rem;
}

footer img { height: 110px; margin: 0 auto 1.2rem; }

footer p { font-size: .9rem; color: var(--violet-texte); }

footer a { color: var(--violet-texte); }

/* ---------- Responsive ---------- */
@media (max-width: 840px) {
  .duo { grid-template-columns: 1fr; gap: 2rem; }

  .coordonnees { grid-template-columns: 1fr; gap: 1.4rem; }

  .menu-toggle { display: block; }

  .duo-asym { grid-template-columns: 1fr; }

  nav {
    flex: none;
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--blanc);
    border-bottom: 1px solid #e3def5;
    padding: 1rem 1.2rem;
  }

  nav.ouvert { display: block; }

  nav ul { flex-direction: column; align-items: flex-start; gap: .9rem; }

  .brand span { font-size: .9rem; }

  .conteneur { padding: 2.8rem 1.2rem; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}
