/* ============================================================
   Road Rider 221 — Composants catalogue (locations + boutique)
   S'appuie sur les variables de style.css (palette Adrénaline)
   ============================================================ */

.muted { color: var(--c-muted); }
.section-top { padding-top: calc(var(--s-24) + 60px); }
.section-dark { background: var(--c-ink); color: var(--c-sand); }
.section-dark h2, .section-dark .eyebrow { color: var(--c-cream); }
.section-cta-final { background: var(--c-ink); color: var(--c-sand); }
.section-cta-final h2 { color: #fff; }

/* --- Grille de cartes --- */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--s-6);
  margin-top: var(--s-8);
}

.cat-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--s-4); flex-wrap: wrap; margin-top: var(--s-12);
}
.cat-head h2 { margin-bottom: var(--s-2); }

/* --- Carte machine / produit --- */
.machine-card {
  display: flex; flex-direction: column;
  background: var(--c-cream);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.machine-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.machine-card-img {
  aspect-ratio: 4 / 3;
  background-size: cover; background-position: center;
  background-color: var(--c-sand-warm);
}
.machine-card-body { padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-2); }
.machine-card-body h3 { margin: 0; font-size: var(--fs-h4); }
.prix-from {
  margin-top: var(--s-2);
  font-weight: 700; color: var(--c-terra);
  font-family: var(--f-body);
}

/* --- Pastilles zones --- */
.zone-pills { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-8); }
.zone-pill {
  display: inline-block;
  padding: var(--s-3) var(--s-6);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: var(--radius-pill);
  color: var(--c-sand); font-weight: 600;
  transition: background .2s var(--ease), color .2s var(--ease);
}
.zone-pill:hover { background: var(--c-terra); border-color: var(--c-terra); color: #fff; }

/* --- Fiche détail --- */
.fiche-grid {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: var(--s-12); align-items: start;
}
.fiche-galerie { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: var(--s-3); margin-bottom: var(--s-8); }
.fiche-img { width: 100%; border-radius: var(--radius-md); box-shadow: var(--shadow-md); }
.fiche-desc { font-size: var(--fs-lead); line-height: 1.7; }
.fiche-zones { margin-top: var(--s-6); color: var(--c-ink-soft); }

.fiche-aside { position: sticky; top: 100px; }
.pack-prix-big { font-size: var(--fs-h3); font-weight: 800; color: var(--c-terra); font-family: var(--f-body); margin: var(--s-3) 0; }
.pack-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-4); padding: var(--s-4) 0; border-bottom: 1px solid var(--c-line);
}
.pack-prix { font-weight: 800; color: var(--c-terra); white-space: nowrap; }

/* --- FAQ --- */
.faq-item { padding: var(--s-6) 0; border-bottom: 1px solid var(--c-line); }
.faq-item h3 { font-size: var(--fs-h4); margin-bottom: var(--s-2); }
.faq-item p { margin: 0; color: var(--c-ink-soft); }

/* --- Page hero overlay (pages internes) --- */
.page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,20,38,.55), rgba(11,20,38,.78)); z-index: 1; }
.page-hero-inner { position: relative; z-index: 2; color: var(--c-sand); }
.page-hero-inner h1, .page-hero-inner .eyebrow { color: #fff; }

@media (max-width: 860px) {
  .fiche-grid { grid-template-columns: 1fr; }
  .fiche-aside { position: static; }
}

/* --- Spots ville/quartier (page pôle) --- */
.spot-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); padding: var(--s-6); }
.spot-card h3 { color: var(--c-cream); margin-bottom: var(--s-2); font-size: var(--fs-h4); }
.spot-card p { color: rgba(248,244,236,.8); margin: 0; }

/* --- Liens croisés (maillage) --- */
.cross-links { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: var(--s-6); }
.cross-link {
  display: flex; flex-direction: column; gap: var(--s-2);
  padding: var(--s-6) var(--s-8); border: 2px solid var(--c-terra);
  border-radius: var(--radius-lg); transition: background .2s var(--ease), color .2s var(--ease);
}
.cross-link strong { color: var(--c-terra); font-size: var(--fs-h4); font-family: var(--f-display); }
.cross-link span { color: var(--c-ink-soft); }
.cross-link:hover { background: var(--c-terra); }
.cross-link:hover strong, .cross-link:hover span { color: #fff; }

/* --- Section alternée --- */
.section-alt { background: var(--c-sand-warm); }

/* --- Étapes (réserver) --- */
.step-card { background: var(--c-cream); border: 1px solid var(--c-line); border-radius: var(--radius-lg); padding: var(--s-8); position: relative; }
.step-num { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: var(--c-terra); color: #fff; font-weight: 800; font-size: 1.1rem; margin-bottom: var(--s-3); }
.step-card h3 { font-size: var(--fs-h4); margin-bottom: var(--s-2); }
.step-card p { margin: 0; color: var(--c-ink-soft); }

/* --- Pourquoi --- */
.why-card { background: var(--c-cream); border: 1px solid var(--c-line); border-radius: var(--radius-lg); padding: var(--s-6); }
.why-card h3 { font-size: var(--fs-h4); margin-bottom: var(--s-2); color: var(--c-terra); }
.why-card p { margin: 0; color: var(--c-ink-soft); }

/* --- Liste à puces check --- */
.check-list { list-style: none; padding: 0; margin: var(--s-6) 0 0; }
.check-list li { position: relative; padding-left: var(--s-8); margin-bottom: var(--s-4); color: var(--c-ink-soft); }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--c-terra); font-weight: 800; }

/* --- Menu déroulant (Locations > enfants) --- */
.nav-parent { position: relative; display: inline-flex; align-items: center; }
.nav-caret { font-size: .7em; opacity: .7; }
.nav-dropdown {
  position: absolute; top: 100%; left: 0; min-width: 220px;
  background: var(--c-cream); border: 1px solid var(--c-line);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md);
  padding: var(--s-2); display: none; flex-direction: column; z-index: 200;
}
.nav-parent:hover .nav-dropdown { display: flex; }
.nav-dropdown a { padding: var(--s-2) var(--s-4); border-radius: var(--radius-sm); white-space: nowrap; }
.nav-dropdown a:hover { background: var(--c-sand-warm); color: var(--c-terra); }

@media (max-width: 900px) {
  .nav-parent { display: block; width: 100%; }
  .nav-dropdown { position: static; display: flex; box-shadow: none; border: none; background: transparent; padding-left: var(--s-6); }
}

/* Libellé parent de menu non cliquable */
.nav-parent-label { cursor: default; display: inline-flex; align-items: center; gap: 4px; }
