/* ============================================================
   PAGE PARTICULIER — Variables héritées de style.css
   particulier.css
============================================================ */

/* Variables locales spécifiques à cette page */
:root {
  --p-bg-card: #f8faf9; /* Légèrement teintée vert, pas dans style.css */
}

body {
  font-family: var(--font-family);
  background: var(--color-white);
  color: var(--color-text);
}

/* ── Page Wrapper ── */
.p-page {
  padding: 0 20px;
  box-sizing: border-box;
}

/* ── Infographic Card ── */
.info-card {
  width: 100%;
  padding: 48px 52px 0;
  position: relative;
}

/* ── Top Row ── */
.info-top {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  margin-bottom: var(--spacing-sm);
}

/* ── Left Col ── */
.info-left {
  width: 280px;
  flex-shrink: 0;
}

.p-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  background: var(--color-primary-pale);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  padding: 6px 14px;
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
}

.p-title {
  font-size: 2.5rem;
  font-weight: 900;
  color: var(--color-dark);
  line-height: 1.08;
  margin-bottom: 14px;
}

.p-subtitle {
  font-size: var(--font-size-sm);
  color: var(--color-gray);
  line-height: 1.55;
  margin-bottom: 28px;
}

.p-eyebrow {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--color-dark);
  line-height: 1.4;
  margin-bottom: 28px;
}

.p-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-btn);
  padding: 16px 28px;
  font-size: var(--font-size-base);
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--transition-base);
  margin-bottom: 10px;
}
.p-cta:hover { background: var(--color-primary-dark); color: var(--color-white); }

.p-cta-note {
  font-size: var(--font-size-xs);
  color: var(--color-gray);
  margin-top: 6px;
  margin-left: 2px;
}

/* ── Steps ── */
.info-steps {
  flex: 1;
  min-width: 0; /* Crucial: Autoriser le conteneur flex à être plus petit que son contenu déroulant */
}

/* ── Global Scroll Wrapper ── */
.steps-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 24px;
}

.steps-scroll::-webkit-scrollbar { height: 6px; }
.steps-scroll::-webkit-scrollbar-track { background: transparent; }
.steps-scroll::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: var(--radius-full); }

.steps-track {
  display: flex;
  align-items: flex-start;
  position: relative;
  width: max-content; /* Force le container à englober les enfants et pousser le scroll */
  min-width: 100%;
}

.step {
  flex: 1;
  text-align: center;
  position: relative;
  padding: 0 8px;
  min-width: 280px; /* NEW: Empêche l'écrasement sur tablettes/laptops avant de forcer le scroll */
  width: 280px; /* Base size pour alignement parfait */
}

.step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 18px;
  right: -18px;
  width: 36px;
  height: 2px;
  background: var(--color-border);
}

.step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 800;
  margin-bottom: 14px;
}

.step__icon {
  font-size: 1.6rem;
  color: var(--color-primary);
  margin-bottom: 8px;
  display: block;
}

.step__title {
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--color-primary);
  margin-bottom: 4px;
}

.step__badge {
  display: inline-block;
  background: var(--color-secondary);
  color: var(--color-white);
  border-radius: var(--radius-sm);
  font-size: 0.55rem;
  font-weight: 800;
  padding: 2px 6px;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.step__desc {
  font-size: var(--font-size-xs);
  color: var(--color-gray);
  line-height: 1.4;
}

/* ── Steps Cards Row (1:1 under each step) ── */
.steps-cards {
  display: flex;
  gap: 14px;
  margin-top: 20px;
  align-items: flex-start;
  width: max-content; /* Permet au conteneur de dépasser pour activer le scroll */
  min-width: 100%;
}

.steps-cards .mk {
  flex: 1;
  min-width: 280px; /* Même largeur minimale que .step pour un alignement parfait */
  width: 280px;
}

.steps-cards .mk-search,
.steps-cards .mk-filters,
.steps-cards .mk-pros,
.steps-cards .mk-trust,
.steps-cards .mk-chat {
  flex: 1;
  min-width: 280px; /* Overrides les largeurs précédentes */
  width: 280px; 
}

/* ── Shared card base ── */
.mk {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  flex-shrink: 0;
}

/* ── Card 1 : Search + Gallery ── */
/* On laisse .mk-search libre de prendre l'espace via flex: 1 */

.mk-search__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--font-size-xs);
  color: var(--color-text);
}
.mk-search__bar i { color: var(--color-gray-light); }

.mk-search__loc {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--color-primary);
  font-weight: 600;
  font-size: var(--font-size-xs);
}

.mk-search__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  padding: 8px;
}

.mk-img-wrap {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  height: 90px;
}
.mk-img-wrap img { width: 100%; height: 100%; object-fit: cover; }

.mk-tag {
  position: absolute;
  top: 6px;
  left: 6px;
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--color-white);
}
.mk-tag--avant { background: rgba(0,0,0,0.5); }
.mk-tag--apres { background: var(--color-primary); }

.mk-search__footer {
  text-align: center;
  padding: 8px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-gray);
  border-top: 1px solid var(--color-border);
}

/* ── Card 2 : Filters ── */
.mk-filters { padding: 14px; }

.mk-filters__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.mk-filters__topbar span { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-white); }
.mk-filters__count {
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  font-size: 0.7rem;
  font-weight: 700;
}

.mk-filter-group { margin-bottom: 12px; }
.mk-filter-group__label {
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--color-dark);
  margin-bottom: 5px;
  display: block;
}
.mk-filter-group__val {
  display: flex;
  align-items: center;
  gap: 5px;
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 6px 10px;
  font-size: 0.7rem;
  color: var(--color-text);
  font-weight: 500;
}
.mk-filter-group__val i { color: var(--color-primary); }
.mk-filter-group__val .bi-x { margin-left: auto; color: var(--color-gray-light); cursor: pointer; }

.mk-filter-group__select {
  display: flex;
  align-items: center;
  gap: 5px;
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 6px 10px;
  font-size: 0.7rem;
  color: var(--color-text);
  font-weight: 500;
  justify-content: space-between;
}

.mk-filters__btn {
  width: 100%;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  padding: 10px;
  font-size: var(--font-size-sm);
  font-weight: 700;
  cursor: pointer;
  margin-top: 6px;
  transition: background var(--transition-fast);
}
.mk-filters__btn:hover { background: var(--color-primary-dark); }

.mk-filters__tagline {
  font-size: 0.6rem;
  color: var(--color-gray-light);
  text-align: center;
  margin-top: 5px;
  font-style: italic;
}

/* ── Card 3 : Pros ── */
.mk-pros { padding: 14px; }
.steps-cards .mk-pros { padding: 12px; }

.mk-pros__recom {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 4px 10px;
  font-size: 0.65rem;
  font-weight: 700;
  margin-bottom: 12px;
}

.mk-pros__grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mk-pro {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.mk-pro__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}
.mk-pro__header img {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  object-fit: cover;
  flex-shrink: 0;
}
.mk-pro__name { font-size: var(--font-size-sm); font-weight: 700; margin: 0; }
.mk-pro__job { font-size: 0.72rem; color: var(--color-gray); margin: 0; }
.mk-pro__loc { font-size: 0.68rem; color: var(--color-gray); display: flex; align-items: center; gap: 3px; margin-top: 2px; }

.mk-pro__imgs {
  height: 70px;
  display: none;
}
.info-mockups .mk-pro__imgs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}
.mk-pro__imgs img { width: 100%; height: 100%; object-fit: cover; }

.mk-pro__footer {
  padding: 10px 12px;
  background: var(--color-bg-light);
}
.mk-pro__style { font-size: 0.68rem; color: var(--color-gray); margin-bottom: 5px; }
.mk-pro__stats { display: flex; align-items: center; gap: 6px; font-size: 0.7rem; color: var(--color-text); margin-bottom: 5px; }
.mk-pro__stats .stars { color: var(--color-secondary); }
.mk-pro__verified { display: flex; align-items: center; gap: 4px; color: var(--color-primary); font-size: 0.7rem; font-weight: 700; margin-bottom: 8px; }
.mk-pro__btn {
  width: 100%;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  padding: 8px 0;
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition-fast);
}
.mk-pro__btn:hover { background: var(--color-primary-dark); }

/* ── Card 4 : Trust ── */
.mk-trust { padding: 14px; }

.mk-trust__header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
}
.mk-trust__header i { font-size: 1.3rem; color: var(--color-primary); flex-shrink: 0; }
.mk-trust__header span { font-size: 0.72rem; font-weight: 700; color: var(--color-dark); line-height: 1.3; }

.mk-trust__li {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 10px;
}
.mk-trust__li i { color: var(--color-primary); font-size: var(--font-size-sm); }

/* ── Card 5 : Chat ── */
.mk-chat { padding: 14px; }

.mk-chat__header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border);
}
.mk-chat__header img {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-full);
  object-fit: cover;
}
.mk-chat__header span { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-dark); }

.mk-chat__msg {
  font-size: 0.7rem;
  color: var(--color-gray);
  line-height: 1.5;
  background: var(--color-bg-light);
  border-radius: var(--radius-md);
  padding: 10px;
  margin-bottom: 12px;
}

.mk-chat__btn {
  width: 100%;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  padding: 10px;
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: background var(--transition-fast);
}
.mk-chat__btn:hover { background: var(--color-primary-dark); }

/* ── Info Footer ── */
.info-footer {
  text-align: center;
  padding: var(--spacing-section);
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--color-primary);
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .info-top { flex-direction: column; }
  .info-left { width: 100%; }
  .info-steps { width: 100%; min-width: 0; } /* Force la limite de largeur au passage en colonne */
  .info-card { padding: 32px 24px; overflow: hidden; } /* Bloque tout débordement à la base */
  .p-title { font-size: 2rem; }
}

/* Mobile : scroll horizontal du stepper */
@media (max-width: 768px) {
  .info-card { padding: 24px 16px; }
  .p-page { padding: 0 12px; }
  .p-title { font-size: 1.7rem; }

  /* Le conteneur scroll (nouveau wrapper) */
  .steps-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 24px;
    margin-right: -16px;
    padding-right: 16px;
  }

  .steps-scroll::-webkit-scrollbar { height: 6px; }
  .steps-scroll::-webkit-scrollbar-track { background: transparent; }
  .steps-scroll::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: var(--radius-full); }

  /* Mettre le même gap sur les 2 lignes pour un alignement parfait au scroll */
  .steps-track {
    display: flex;
    flex-wrap: nowrap;
    width: max-content;
    gap: 16px;
  }

  .step {
    flex: 0 0 250px !important; /* Empêche formellement de rétrécir */
    min-width: 250px;
    max-width: 250px;
    padding: 0;
  }

  .step:not(:last-child)::after {
    display: block;
    right: -24px; /* Ajuster la flèche proportionnellement au gap */
    width: 32px;
  }

  .steps-cards {
    display: flex;
    flex-wrap: nowrap;
    width: max-content;
    gap: 16px;
    margin-top: 20px;
  }

  .steps-cards .mk,
  .steps-cards .mk-search,
  .steps-cards .mk-filters,
  .steps-cards .mk-pros,
  .steps-cards .mk-trust,
  .steps-cards .mk-chat {
    flex: 0 0 250px !important; /* Empêche formellement de rétrécir */
    width: 250px !important;
    min-width: 250px !important;
    max-width: 250px !important;
  }
}

