/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-5); font-weight: 600; font-size: 1rem;
  border-radius: var(--radius-pill); text-decoration: none; cursor: pointer;
  border: 2px solid transparent;
  transition: transform var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
.btn--primary { background: var(--color-secondary); color: #1c1402; border-color: var(--color-secondary); }
.btn--primary:hover, .btn--primary:focus-visible {
  background: #b07414; border-color: #b07414; color: #fff;
  transform: translateY(-2px); box-shadow: var(--shadow-md);
}
.btn--ghost {
  background: transparent; color: #fff; border-color: rgba(255, 255, 255, 0.6);
}
.btn--ghost:hover, .btn--ghost:focus-visible {
  background: rgba(255, 255, 255, 0.08); border-color: #fff; color: #fff;
  transform: translateY(-2px);
}
.btn--dark { background: var(--color-primary); color: #fff; }
.btn--dark:hover, .btn--dark:focus-visible {
  background: var(--color-primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-md); color: #fff;
}

/* Card */
.card {
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-6); box-shadow: var(--shadow-sm);
  transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-secondary); }
.card__icon {
  width: 48px; height: 48px; border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(12,107,90,0.12), rgba(196,131,30,0.16));
  display: grid; place-items: center; color: var(--color-primary);
  margin-bottom: var(--space-4);
}
.card__icon svg { width: 24px; height: 24px; }
.card h3 { margin-bottom: var(--space-3); }
.card p { color: var(--color-text-muted); margin: 0; }

/* USP / numéro */
.usp-list { display: grid; gap: var(--space-5); list-style: none; padding: 0; margin: 0; }
.usp-list li { display: flex; gap: var(--space-4); align-items: flex-start; }
.usp-list .num {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%;
  background: var(--color-primary); color: #fff; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700;
}

/* Stats */
.stats { display: grid; gap: var(--space-5); grid-template-columns: repeat(2, 1fr); }
@media (min-width: 720px) { .stats { grid-template-columns: repeat(4, 1fr); } }
.stat { text-align: center; padding: var(--space-5); background: #fff; border-radius: var(--radius-lg); border: 1px solid var(--color-border); }
.stat__value { font-family: var(--font-display); font-size: 2.4rem; color: var(--color-primary); font-weight: 700; line-height: 1; }
.stat__label { color: var(--color-text-muted); font-size: 0.95rem; margin-top: var(--space-2); }

/* Reviews badge */
.reviews-badge {
  display: inline-flex; align-items: center; gap: var(--space-3);
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-pill);
  padding: var(--space-2) var(--space-4); box-shadow: var(--shadow-sm);
}
.reviews-badge .stars { color: var(--color-secondary); letter-spacing: 1px; font-size: 1.1rem; }
.reviews-badge .count { color: var(--color-text-muted); font-size: 0.95rem; }
.reviews-badge strong { color: var(--color-text); font-weight: 700; }

/* FAQ */
.faq details {
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5); margin-bottom: var(--space-3);
  background: #fff; transition: border-color var(--duration-base) var(--ease-out);
}
.faq details[open] { border-color: var(--color-secondary); }
.faq summary {
  cursor: pointer; font-weight: 600; color: var(--color-text);
  list-style: none; display: flex; justify-content: space-between; gap: var(--space-3);
  font-size: 1.05rem;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; color: var(--color-primary); font-size: 1.4rem; line-height: 1;
  transition: transform var(--duration-base) var(--ease-out);
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p { margin-top: var(--space-3); color: var(--color-text-muted); }

/* Tarifs */
.pricing-table {
  width: 100%; border-collapse: collapse; background: #fff;
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm);
}
.pricing-table th, .pricing-table td { padding: var(--space-4); text-align: left; border-bottom: 1px solid var(--color-border); }
.pricing-table th { background: var(--color-primary); color: #fff; font-weight: 600; }
.pricing-table tr:last-child td { border-bottom: 0; }
.pricing-table tr:nth-child(even) td { background: var(--color-surface); }

/* Forms */
.form { display: grid; gap: var(--space-4); max-width: 560px; }
.form label { display: grid; gap: var(--space-2); font-weight: 600; font-size: 0.95rem; }
.form input, .form select, .form textarea {
  font: inherit; padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); background: #fff; color: var(--color-text);
  transition: border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}
.form input:focus, .form select:focus, .form textarea:focus {
  outline: 0; border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(12, 107, 90, 0.2);
}
.form textarea { min-height: 120px; resize: vertical; }
.form__row { display: grid; gap: var(--space-4); }
@media (min-width: 600px) { .form__row { grid-template-columns: 1fr 1fr; } }

/* Map */
.map-frame { border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.map-frame iframe { display: block; width: 100%; height: 360px; border: 0; }

/* Contact channels */
.contact-channels { display: grid; gap: var(--space-4); margin: 0; padding: 0; list-style: none; }
.contact-channels li { display: flex; gap: var(--space-4); align-items: flex-start; padding: var(--space-4); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.contact-channels svg { width: 28px; height: 28px; color: var(--color-primary); flex-shrink: 0; }
.contact-channels a { font-weight: 700; }

/* Disclaimer */
.note {
  font-size: 0.9rem; color: var(--color-text-muted);
  border-left: 3px solid var(--color-secondary); padding: var(--space-2) var(--space-4);
  background: rgba(196, 131, 30, 0.06);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* Decorative pattern */
.motif-decor {
  display: block; width: 100%; height: 32px;
  background:
    radial-gradient(circle at 12px 16px, var(--color-secondary) 3px, transparent 4px),
    radial-gradient(circle at 36px 16px, var(--color-primary) 3px, transparent 4px),
    radial-gradient(circle at 60px 16px, var(--color-accent) 3px, transparent 4px);
  background-size: 72px 32px;
  background-repeat: repeat-x;
  opacity: 0.4;
  margin: var(--space-7) auto;
  max-width: 220px;
}
