/* ============================================================
   PPC VITRINE — Pages intérieures CSS
   Contact, formulaires, aide, presse, etc.
   ============================================================ */

/* ── PAGE CONTACT ───────────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 60px;
  padding: 64px 0 80px;
  align-items: start;
}
.contact-infos { display: flex; flex-direction: column; gap: 16px; }
.contact-infos__title {
  font-size: 1.4rem; color: var(--blanc); margin-bottom: 8px;
}
.contact-infos__desc {
  font-size: 0.9rem; color: var(--texte-dim); line-height: 1.75;
  margin-bottom: 24px; font-weight: 300;
}
.contact-card {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 20px; border-radius: var(--radius-sm);
  background: var(--surface); border: 1px solid var(--bordure);
  transition: border-color 0.3s;
}
.contact-card:hover { border-color: rgba(201,150,90,0.25); }
.contact-card__icon {
  width: 42px; height: 42px; border-radius: 12px;
  background: rgba(201,150,90,0.08); border: 1px solid rgba(201,150,90,0.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; flex-shrink: 0;
}
.contact-card__title { font-size: 0.85rem; font-weight: 600; margin-bottom: 4px; }
.contact-card__val {
  font-size: 0.82rem; color: var(--texte-dim);
}
.contact-card__val a { color: var(--or-light); }

/* Formulaire contact */
.contact-form-wrap {
  background: var(--surface);
  border: 1px solid var(--bordure);
  border-radius: var(--radius);
  padding: 36px;
}
.contact-form-wrap h2 { font-size: 1.5rem; margin-bottom: 6px; }
.contact-form-wrap > p { font-size: 0.875rem; color: var(--texte-dim); margin-bottom: 28px; }

/* ── PAGE SIGNALEMENT ───────────────────────────────────────── */
.signal-warning {
  background: rgba(239,68,68,0.07);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: var(--radius-sm);
  padding: 18px 20px; margin-bottom: 28px;
  display: flex; gap: 14px; align-items: flex-start;
}
.signal-warning__icon { font-size: 1.5rem; flex-shrink: 0; }
.signal-warning p { font-size: 0.875rem; color: #FCA5A5; line-height: 1.65; margin: 0; }
.signal-warning strong { color: #FCA5A5; }

/* ── PAGE AIDE ──────────────────────────────────────────────── */
.aide-search-wrap {
  max-width: 560px; margin: 0 auto 60px; position: relative;
}
.aide-search {
  width: 100%; padding: 16px 20px 16px 52px;
  background: var(--surface); border: 1px solid var(--bordure2);
  border-radius: 50px; color: var(--texte);
  font-family: var(--font-body); font-size: 0.95rem; outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.aide-search:focus {
  border-color: rgba(201,150,90,0.5);
  box-shadow: 0 0 0 3px rgba(201,150,90,0.1);
}
.aide-search::placeholder { color: var(--texte-mute); }
.aide-search-icon {
  position: absolute; left: 18px; top: 50%; transform: translateY(-50%);
  font-size: 1.1rem; pointer-events: none;
}

.aide-categories {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-bottom: 60px;
}
.aide-cat {
  display: flex; flex-direction: column; gap: 10px;
  padding: 24px 22px; border-radius: var(--radius);
  background: var(--surface); border: 1px solid var(--bordure);
  text-decoration: none; color: inherit;
  transition: all 0.3s;
}
.aide-cat:hover { border-color: rgba(201,150,90,0.25); transform: translateY(-3px); }
.aide-cat__icon { font-size: 2rem; }
.aide-cat__title { font-size: 1rem; font-weight: 600; color: var(--texte); }
.aide-cat__count { font-size: 0.78rem; color: var(--texte-mute); }

.aide-faq-section { margin-bottom: 48px; }
.aide-faq-section h2 {
  font-size: 1.5rem; color: var(--blanc);
  margin-bottom: 20px; padding-bottom: 12px;
  border-bottom: 1px solid var(--bordure);
}
.aide-faq { display: flex; flex-direction: column; gap: 2px; }
.aide-faq-item {
  background: var(--surface); border: 1px solid var(--bordure);
  border-radius: var(--radius-sm); overflow: hidden;
  transition: border-color 0.3s;
}
.aide-faq-item:hover { border-color: rgba(201,150,90,0.2); }
.aide-faq-item summary {
  padding: 18px 22px; cursor: pointer; font-weight: 500; font-size: 0.9rem;
  list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.aide-faq-item summary::-webkit-details-marker { display: none; }
.aide-faq-item summary::after {
  content: '+'; font-size: 1.3rem; color: var(--or); flex-shrink: 0;
  transition: transform 0.3s;
}
.aide-faq-item[open] summary::after  { transform: rotate(45deg); }
.aide-faq-item[open] summary { color: var(--or-light); }
.aide-faq-item .faq-body {
  padding: 0 22px 18px;
  font-size: 0.875rem; color: var(--texte-dim); line-height: 1.75;
}
.aide-faq-item .faq-body p { margin-bottom: 10px; }
.aide-faq-item .faq-body p:last-child { margin-bottom: 0; }
.aide-faq-item .faq-body a { color: var(--or-light); }

/* ── PAGE PRESSE ─────────────────────────────────────────────── */
.presse-kits {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
  margin-bottom: 48px;
}
.presse-kit {
  padding: 28px; border-radius: var(--radius);
  background: var(--surface); border: 1px solid var(--bordure);
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color 0.3s;
}
.presse-kit:hover { border-color: rgba(201,150,90,0.25); }
.presse-kit__icon { font-size: 2rem; }
.presse-kit h3 { font-size: 1rem; font-weight: 600; color: var(--texte); }
.presse-kit p  { font-size: 0.85rem; color: var(--texte-dim); line-height: 1.65; }

.presse-chiffres {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px;
  border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--bordure); margin-bottom: 48px;
}
.presse-chiffre {
  padding: 28px 24px; background: var(--surface);
  text-align: center; border-right: 1px solid var(--bordure);
}
.presse-chiffre:last-child { border-right: none; }
.presse-chiffre__val {
  font-family: var(--font-display);
  font-size: 2.4rem; font-weight: 700; color: var(--or-light); line-height: 1;
}
.presse-chiffre__lbl {
  font-size: 0.78rem; color: var(--texte-mute); margin-top: 8px;
}

/* ── PAGE 404 ────────────────────────────────────────────────── */
.page-404 {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  text-align: center; padding: 40px 20px; position: relative;
}
.page-404__bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 40%, rgba(201,150,90,0.07), transparent 70%);
}
.page-404__content { position: relative; z-index: 1; max-width: 520px; }
.page-404__num {
  font-family: var(--font-display);
  font-size: clamp(6rem, 15vw, 12rem); font-weight: 700; line-height: 1;
  background: var(--grad-or); background-size: 200% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; animation: shimmer 4s linear infinite;
}
.page-404__title {
  font-size: clamp(1.6rem, 3vw, 2.4rem); color: var(--blanc); margin-bottom: 16px;
}
.page-404__desc {
  font-size: 1rem; color: var(--texte-dim); margin-bottom: 36px;
  line-height: 1.75; font-weight: 300;
}
.page-404__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.page-404__links {
  margin-top: 40px; display: flex; gap: 20px; justify-content: center; flex-wrap: wrap;
}
.page-404__links a {
  font-size: 0.85rem; color: var(--texte-mute); transition: color 0.2s;
}
.page-404__links a:hover { color: var(--or-light); }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .contact-layout    { grid-template-columns: 1fr; gap: 40px; }
  .aide-categories   { grid-template-columns: repeat(2, 1fr); }
  .presse-kits       { grid-template-columns: 1fr; }
  .presse-chiffres   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .aide-categories   { grid-template-columns: 1fr; }
  .presse-chiffres   { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: 24px; }
}
