/* FLUENTIS — Base CSS Reset + Composants */

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

html {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
  scroll-padding-top: var(--space-16);
}

body {
  min-height: 100dvh;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: 1.65;
}

/* ── Typographie ── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  line-height: 1.2;
}
h1 { font-size: var(--text-hero); font-weight: 600; }
h2 { font-size: var(--text-2xl);  font-weight: 500; }
h3 { font-size: var(--text-xl);   font-weight: 500; }
h4 { font-size: var(--text-lg);   font-weight: 500; font-family: var(--font-body); }
p  { font-size: var(--text-base); max-width: 68ch; }
a  { color: var(--color-primary); text-decoration: none;
     transition: color var(--transition); }
a:hover { color: var(--color-primary-hover); }

/* ── Boutons ── */
.btn-fluentis {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2); padding: var(--space-3) var(--space-6);
  font-family: var(--font-body); font-size: var(--text-sm);
  font-weight: 500; border-radius: var(--radius-md);
  cursor: pointer; border: none; text-decoration: none;
  white-space: nowrap;
  transition: background var(--transition), color var(--transition),
              box-shadow var(--transition), transform var(--transition);
}
.btn-fluentis:active { transform: translateY(1px); }

.btn-fluentis-primary {
  background: var(--color-primary);
  color: var(--color-text-inverse);
}
.btn-fluentis-primary:hover {
  background: var(--color-primary-hover);
  box-shadow: var(--shadow-md);
  color: var(--color-text-inverse);
}

.btn-fluentis-accent {
  background: var(--color-accent);
  color: var(--color-text);
}
.btn-fluentis-accent:hover {
  background: var(--color-accent-hover);
  box-shadow: var(--shadow-md);
}

.btn-fluentis-outline {
  background: transparent;
  border: 1.5px solid var(--color-primary);
  color: var(--color-primary);
}
.btn-fluentis-outline:hover { background: var(--color-primary-highlight); }

/* ── Cartes ── */
.card-fluentis {
  background: var(--color-surface);
  border: 1px solid rgba(28, 26, 20, 0.08);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), transform var(--transition);
}
.card-fluentis:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* ── Layout ── */
.section-fluentis {
  padding-block: clamp(var(--space-12), 8vw, var(--space-24));
  padding-inline: var(--space-4);
}
.container-fluentis {
  max-width: var(--content-default);
  margin-inline: auto;
  padding-inline: var(--space-4);
}
.container-fluentis-wide {
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: var(--space-4);
}

/* ── Badges CECR ── */
.badge-fluentis {
  display: inline-flex; align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.05em; border-radius: var(--radius-full);
  background: var(--color-primary-highlight);
  color: var(--color-primary);
}
.badge-fluentis-gold {
  background: var(--color-accent-highlight);
  color: var(--color-gold-dark);
}
.badge-fluentis-sage {
  background: var(--color-success-highlight);
  color: var(--color-sage-dark);
}

/* ── Focus accessibilité ── */
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
