/* ─────────────────────────────────────────────
   moniakhellache.com — Style principal
   Palette : Sable · Sauge · Terre cuite
───────────────────────────────────────────── */

:root {
  --sable:      #EDE4D8;
  --sable-clair:#F7F3EE;
  --sauge:      #6B8F71;
  --sauge-dark: #4E6B53;
  --terre:      #C4866A;
  --terre-dark: #A96D53;
  --texte:      #2D3B35;
  --texte-med:  #5A6B62;
  --blanc:      #FDFCFA;
  --border:     #DDD5C8;
}

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

html { scroll-behavior: smooth; }

body {
  font-family: 'Lato', sans-serif;
  background: var(--blanc);
  color: var(--texte);
  font-size: 16px;
  line-height: 1.7;
}

/* ── Typographie ── */
h1, h2, h3 {
  font-family: 'Cormorant Garamond', 'Playfair Display', serif;
  color: var(--texte);
  line-height: 1.25;
}
h1 { font-size: clamp(2rem, 5vw, 3rem); font-weight: 600; }
h2 { font-size: clamp(1.4rem, 3vw, 1.9rem); font-weight: 600; }
h3 { font-size: 1.2rem; font-weight: 600; }
p  { color: var(--texte-med); line-height: 1.85; }
a  { color: var(--sauge); text-decoration: none; }
a:hover { color: var(--sauge-dark); }

.container { max-width: 960px; margin: 0 auto; padding: 0 1.5rem; }

/* ── Header ── */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(253, 252, 250, 0.96);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(8px);
  transition: box-shadow 0.3s;
}
.header--scrolled { box-shadow: 0 2px 16px rgba(0,0,0,0.07); }
.header__inner {
  display: flex; align-items: center;
  justify-content: space-between;
  height: 64px;
}
.header__logo { display: flex; align-items: center; }
.header__logo img { height: 44px; width: auto; }

.nav { display: flex; gap: 2rem; align-items: center; }
.nav__link {
  font-size: 0.9rem; font-weight: 600; color: var(--texte-med);
  letter-spacing: 0.03em; text-transform: uppercase;
  transition: color 0.2s;
}
.nav__link:hover, .nav__link--active { color: var(--sauge); }
.nav__link--cta {
  background: var(--terre); color: white !important;
  padding: 8px 18px; border-radius: 6px;
  transition: background 0.2s;
}
.nav__link--cta:hover { background: var(--terre-dark); }

.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--texte); border-radius: 2px; transition: 0.3s; }

/* ── Hero ── */
.hero {
  padding: 140px 0 80px;
  background: linear-gradient(160deg, var(--sable-clair) 0%, var(--sable) 60%, #E2D8CC 100%);
  position: relative; overflow: hidden;
}
.hero::after {
  content: '';
  position: absolute; bottom: -1px; left: 0; right: 0;
  height: 60px;
  background: var(--blanc);
  clip-path: ellipse(55% 100% at 50% 100%);
}
.hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.hero__tag {
  display: inline-block;
  background: var(--sauge); color: white;
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 5px 14px; border-radius: 20px;
  margin-bottom: 1.2rem;
}
.hero__title { margin-bottom: 1.2rem; }
.hero__title em { font-style: normal; color: var(--sauge); }
.hero__sub { font-size: 1.05rem; color: var(--texte-med); margin-bottom: 2rem; max-width: 480px; }
.hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

.btn {
  display: inline-block; padding: 13px 28px; border-radius: 8px;
  font-weight: 700; font-size: 0.95rem; transition: 0.2s; cursor: pointer;
}
.btn--primary { background: var(--terre); color: white; }
.btn--primary:hover { background: var(--terre-dark); color: white; }
.btn--outline { border: 2px solid var(--sauge); color: var(--sauge); background: transparent; }
.btn--outline:hover { background: var(--sauge); color: white; }

.hero__visual {
  display: flex; justify-content: center; align-items: center;
}
.hero__card {
  background: white; border-radius: 16px;
  padding: 2rem; box-shadow: 0 8px 40px rgba(0,0,0,0.1);
  max-width: 320px; width: 100%;
}
.hero__card-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem; font-weight: 700; color: var(--texte);
  margin-bottom: 0.3rem;
}
.hero__card-title { font-size: 0.88rem; color: var(--sauge); font-weight: 600; margin-bottom: 1.2rem; }
.hero__card-stats { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero__stat { text-align: center; }
.hero__stat-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.8rem; font-weight: 700; color: var(--terre); display: block;
}
.hero__stat-label { font-size: 0.78rem; color: var(--texte-med); }

/* ── Section générique ── */
.section { padding: 80px 0; }
.section--bg { background: var(--sable-clair); }
.section__header { text-align: center; margin-bottom: 3.5rem; }
.section__tag {
  display: inline-block; font-size: 0.78rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--sauge);
  margin-bottom: 0.6rem;
}
.section__title { margin-bottom: 0.75rem; }
.section__intro { max-width: 620px; margin: 0 auto; color: var(--texte-med); font-size: 1rem; }

/* ── Cartes interventions ── */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }
.card {
  background: var(--blanc); border: 1px solid var(--border);
  border-radius: 14px; padding: 2rem;
  transition: transform 0.2s, box-shadow 0.2s;
}
.card:hover { transform: translateY(-4px); box-shadow: 0 10px 30px rgba(0,0,0,0.08); }
a.card { text-decoration: none; color: inherit; display: block; }
.card__icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--sable); display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; margin-bottom: 1.2rem;
}
.card__title { font-size: 1.1rem; margin-bottom: 0.6rem; }
.card__desc { font-size: 0.93rem; color: var(--texte-med); margin-bottom: 1rem; }
.card ul { padding-left: 1.1rem; }
.card ul li { font-size: 0.9rem; color: var(--texte-med); margin-bottom: 0.3rem; }

/* ── Publics ── */
.publics { display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center; }
.public-tag {
  background: var(--blanc); border: 1px solid var(--border);
  padding: 8px 18px; border-radius: 30px;
  font-size: 0.9rem; color: var(--texte-med); font-weight: 600;
}

/* ── Infos pratiques ── */
.infos { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; }
.info-item { display: flex; gap: 1rem; align-items: flex-start; }
.info-item__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--sauge); margin-top: 6px; flex-shrink: 0;
}
.info-item strong { display: block; font-size: 0.9rem; color: var(--texte); margin-bottom: 0.2rem; }
.info-item span { font-size: 0.88rem; color: var(--texte-med); }

/* ── CTA bande ── */
.cta-band {
  background: linear-gradient(135deg, var(--sauge-dark), var(--sauge));
  padding: 60px 0; text-align: center;
}
.cta-band h2 { color: white; margin-bottom: 0.75rem; }
.cta-band p { color: rgba(255,255,255,0.82); max-width: 520px; margin: 0 auto 1.8rem; }

/* ── Qui suis-je ── */
.page-hero {
  padding: 120px 0 60px;
  background: linear-gradient(160deg, var(--sable-clair), var(--sable));
}
.page-hero h1 { margin-bottom: 0.5rem; }
.page-hero p { font-size: 1.05rem; max-width: 580px; }

.parcours { display: flex; flex-direction: column; gap: 0; }
.parcours-item {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 1.5rem; padding: 1.5rem 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
}
.parcours-item:last-child { border-bottom: none; }
.parcours-item__year {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; font-weight: 700; color: var(--sauge);
  padding-top: 3px;
}
.parcours-item__title { font-size: 1rem; font-weight: 700; color: var(--texte); margin-bottom: 0.2rem; }
.parcours-item__sub { font-size: 0.9rem; color: var(--texte-med); }

.diplomes { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.diplome-card { flex: 1 1 160px; min-width: 0; }
.diplome-card {
  background: var(--sable-clair); border: 1px solid var(--border);
  border-radius: 10px; padding: 1.2rem 1.5rem;
  border-left: 3px solid var(--sauge);
}
.diplome-card__year { font-size: 0.8rem; color: var(--sauge); font-weight: 700; margin-bottom: 0.3rem; }
.diplome-card__name { font-size: 0.93rem; font-weight: 700; color: var(--texte); margin-bottom: 0.2rem; }
.diplome-card__lieu { font-size: 0.85rem; color: var(--texte-med); }

.formations-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 0.5rem;
}
.formations-list li {
  font-size: 0.95rem; color: var(--texte-med);
  padding: 0.6rem 1rem 0.6rem 1.5rem;
  position: relative;
}
.formations-list li::before {
  content: "—"; position: absolute; left: 0;
  color: var(--sauge); font-weight: 700;
}

/* ── Contact ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 4rem; align-items: start; }
.contact-info h3 { margin-bottom: 1.5rem; }
.contact-info-item { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 1.2rem; }
.contact-info-item__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--terre); margin-top: 6px; flex-shrink: 0; }
.contact-info-item strong { display: block; font-size: 0.9rem; color: var(--texte); }
.contact-info-item span, .contact-info-item a { font-size: 0.9rem; color: var(--texte-med); }

.form { background: var(--sable-clair); border-radius: 16px; padding: 2.5rem; }
.form-group { margin-bottom: 1.2rem; }
.form-group label { display: block; font-size: 0.88rem; font-weight: 700; color: var(--texte); margin-bottom: 0.4rem; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; padding: 11px 14px;
  border: 1px solid var(--border); border-radius: 8px;
  background: white; font-family: 'Lato', sans-serif; font-size: 0.95rem;
  color: var(--texte); transition: border-color 0.2s;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  outline: none; border-color: var(--sauge);
  box-shadow: 0 0 0 3px rgba(107,143,113,0.12);
}
.form-group textarea { resize: vertical; min-height: 130px; }

/* ── Footer ── */
.footer {
  background: var(--texte); padding: 40px 0;
  text-align: center;
}
.footer p { color: rgba(255,255,255,0.5); font-size: 0.85rem; margin-bottom: 0.4rem; }
.footer a { color: rgba(255,255,255,0.6); }
.footer a:hover { color: white; }

/* ── Mentions légales ── */
.legal-content { padding: 120px 0 80px; max-width: 720px; }
.legal-content h1 { margin-bottom: 2rem; }
.legal-content h2 { font-size: 1.2rem; margin: 2rem 0 0.5rem; color: var(--sauge); }
.legal-content p { margin-bottom: 0.75rem; font-size: 0.93rem; }

/* ── Hero V2 — centré ── */
.hero-v2 {
  padding: 150px 0 80px;
  background: linear-gradient(160deg, var(--sable-clair) 0%, var(--sable) 60%, #E2D8CC 100%);
  text-align: center;
  position: relative;
}
.hero-v2::after {
  content: '';
  position: absolute; bottom: -1px; left: 0; right: 0;
  height: 50px; background: var(--blanc);
  clip-path: ellipse(55% 100% at 50% 100%);
}
.hero-v2__inner { max-width: 780px; margin: 0 auto; }
.hero-v2__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.9rem, 4.5vw, 2.8rem);
  font-weight: 700; line-height: 1.2;
  margin: 1rem 0 1.4rem;
}
.hero-v2__title em { font-style: normal; color: var(--sauge); }
.hero-v2__sub {
  font-size: 1.05rem; color: var(--texte-med);
  line-height: 1.8; margin-bottom: 2.2rem;
}
.hero-v2__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ── Barre stats ── */
.stats-bar {
  background: var(--texte);
  padding: 24px 0;
}
.stats-bar__inner {
  display: flex; align-items: center; justify-content: center;
  gap: 0; flex-wrap: wrap;
}
.stat-item { text-align: center; padding: 0 2.5rem; }
.stat-item__num {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.9rem; font-weight: 700; color: var(--terre);
  line-height: 1;
}
.stat-item__label { font-size: 0.78rem; color: rgba(255,255,255,0.55); letter-spacing: 0.04em; }
.stat-sep { width: 1px; height: 36px; background: rgba(255,255,255,0.1); }

/* ── Services grid ── */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.service-card {
  display: block; text-decoration: none;
  background: var(--blanc); border: 1px solid var(--border);
  border-radius: 14px; padding: 2rem;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  border-color: var(--sauge);
}
.service-card__icon { font-size: 1.8rem; margin-bottom: 1rem; display: block; }
.service-card__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; color: var(--texte); margin-bottom: 0.6rem;
}
.service-card__desc { font-size: 0.9rem; color: var(--texte-med); line-height: 1.7; margin-bottom: 1.2rem; }
.service-card__link { font-size: 0.85rem; font-weight: 700; color: var(--sauge); }

/* ── Pourquoi moi ── */
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.why-item { }
.why-item__icon { color: var(--terre); font-size: 0.8rem; margin-bottom: 0.8rem; }
.why-item__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem; color: var(--texte); margin-bottom: 0.6rem;
}
.why-item p { font-size: 0.93rem; }

/* ── Citation ── */
.citation-section {
  padding: 60px 0;
  background: var(--sable);
}
.citation {
  max-width: 620px; margin: 0 auto;
  text-align: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem; font-style: italic;
  color: var(--texte); line-height: 1.6;
  border: none; padding: 0;
}
.citation cite {
  display: block; margin-top: 1rem;
  font-size: 0.9rem; font-style: normal;
  color: var(--texte-med); letter-spacing: 0.04em;
}

/* ── Témoignages ── */
.temoignages { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.temo-card {
  background: var(--blanc); border: 1px solid var(--border);
  border-radius: 14px; padding: 2rem;
  border-top: 3px solid var(--terre);
  position: relative;
}
.temo-card__quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem; font-style: italic;
  color: var(--texte); line-height: 1.75;
  margin-bottom: 1.2rem;
}
.temo-card__quote::before { content: "«\00a0"; color: var(--terre); font-weight: 700; }
.temo-card__quote::after  { content: "\00a0»"; color: var(--terre); font-weight: 700; }
.temo-card__author { font-size: 0.85rem; font-weight: 700; color: var(--sauge); }

/* ── FAQ ── */
.faq { display: flex; flex-direction: column; gap: 0; max-width: 720px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--border);
  padding: 1.4rem 0;
}
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-item__q {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; font-weight: 700; color: var(--texte);
  margin-bottom: 0.5rem;
  display: flex; align-items: flex-start; gap: 0.75rem;
}
.faq-item__q::before { content: "Q."; color: var(--terre); font-weight: 700; flex-shrink: 0; }
.faq-item__a { font-size: 0.93rem; color: var(--texte-med); line-height: 1.8; padding-left: 1.8rem; }

/* ── Responsive ── */
@media (max-width: 768px) {
  .nav { display: none; flex-direction: column; position: fixed; top: 64px; left: 0; right: 0; bottom: 0; background: var(--blanc); padding: 2rem; gap: 1.5rem; }
  .nav.open { display: flex; }
  .hamburger { display: flex; }
  .hero__inner { grid-template-columns: 1fr; }
  .hero__visual { display: none; }
  .contact-grid { grid-template-columns: 1fr; }
  .hero { padding: 110px 0 60px; }
  .services-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; }
  .stat-sep { display: none; }
  .stat-item { padding: 0.5rem 1.5rem; }
}
