/* =========================================================
   SiliVal - style global
   ========================================================= */

/* ---------- Variables "brand" ---------- */

:root {
  --sv-primary: #212529;   /* couleur principale : proche du bg-dark */
  --sv-primary-soft: #343a40;
  --sv-accent: #198754;    /* vert Bootstrap (check / succès) */
  --sv-border-soft: #dee2e6;
  --sv-bg-soft: #f8f9fa;
}

/* ---------- Base ---------- */

html,
body {
  scroll-behavior: smooth;
}

/* on laisse Bootstrap gérer la couleur du texte ;
   pas de "color: ..." global pour ne pas casser les sections bg-dark */

/* main : juste pour éviter une page trop courte */
main {
  min-height: 60vh;
}

/* Liens généraux : même couleur que le texte, surlignés seulement au survol/focus */
a {
  color: inherit;
  text-decoration: none;
}

a:hover,
a:focus {
  color: inherit;
  text-decoration: underline;
}


/* ---------- Navbar ---------- */

.navbar-brand {
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
}

.navbar-dark .navbar-brand {
  color: #ffffff;
}

.navbar-dark .navbar-brand:hover {
  color: #ffffff;
  text-decoration: none;
}

.navbar-dark .navbar-nav .nav-link {
  font-weight: 500;
  opacity: 0.9;
  transition: opacity 0.15s ease, color 0.15s ease, background-color 0.15s ease;
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link:focus,
.navbar-dark .navbar-nav .nav-link.active {
  opacity: 1;
}

/* Dropdown dans la navbar */

.navbar .dropdown-menu {
  font-size: 0.95rem;
  border-radius: 0.75rem;
  border-color: rgba(0, 0, 0, 0.08);
  box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.18);
  padding: 0.35rem 0;
}

.navbar .dropdown-item {
  padding: 0.45rem 1rem;
}

.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
  background-color: var(--sv-bg-soft);
}

/* Séparateurs dans les dropdowns */
.navbar .dropdown-divider {
  margin: 0.25rem 0;
}


/* Liens de la navbar : on neutralise le soulignement global */
.navbar .nav-link,
.navbar .nav-link:hover,
.navbar .nav-link:focus {
  text-decoration: none;
}

/* Lien de sélection de langue (globe) :
   - jamais de soulignement
   - léger effet de survol uniquement via l’opacité déjà gérée plus haut */
.navbar-dark .navbar-nav .nav-link.nav-link-lang {
  text-decoration: none;
}

.navbar-dark .navbar-nav .nav-link.nav-link-lang:hover,
.navbar-dark .navbar-nav .nav-link.nav-link-lang:focus {
  text-decoration: none;
  opacity: 1; /* “surexposition” au survol */
}



/* ---------- HERO ---------- */

/* IMPORTANT : ne jamais casser la couleur héritée de .bg-dark .text-light.
   On ne met donc aucune règle globale qui force "color" ici.
   On ajoute juste des classes utilitaires. */

/* Badges custom hero (si tu les réutilises) */
.badge-hero {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.8rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border: 1px solid rgba(255, 255, 255, 0.3);
  background-color: rgba(255, 255, 255, 0.08);
  color: #ffffff;
}

.badge-hero i {
  font-size: 0.9rem;
}

/* Dans le HERO, tout le texte doit rester clair.
   On s'assure juste que rien ne le repasse en noir. */
#hero,
#hero h1,
#hero h2,
#hero h3,
#hero p,
#hero li {
  /* on ne met PAS !important : normalement, il hérite déjà de .text-light.
     Cette règle sert juste à battre d’éventuels styles trop génériques. */
  color: #f8f9fa;
}

/* Sauf la carte de droite, qui doit rester sur fond clair avec texte sombre */
#hero .card,
#hero .card h2,
#hero .card h3,
#hero .card p,
#hero .card li {
  color: #212529;
}

/* ---------- Cartes et hover ---------- */

.card-hover {
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.card-hover:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.75rem 1.8rem rgba(15, 23, 42, 0.14);
  border-color: rgba(15, 23, 42, 0.05);
}

/* Petits ajustements de cartes */
.card {
  border-radius: 0.9rem;
}

/* ---------- Badges de step (section "Comment démarrer") ---------- */

.badge-step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.9rem;
  background-color: var(--sv-primary);
  color: #ffffff;
}

/* Si tu as gardé "badge rounded-pill text-bg-primary",
   cette classe restera compatible avec Bootstrap et ce style-step sera juste un plus. */

/* ---------- Boutons "brand" (remplacer le bleu Bootstrap) ---------- */

.btn-primary {
  background-color: var(--sv-primary);
  border-color: var(--sv-primary);
  color: #ffffff;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--sv-primary-soft);
  border-color: var(--sv-primary-soft);
  color: #ffffff;
}

.btn-primary:active {
  background-color: #000000;
  border-color: #000000;
  color: #ffffff;
}

/* Boutons outline brand */
.btn-outline-primary {
  color: var(--sv-primary);
  border-color: var(--sv-primary);
  background-color: transparent;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background-color: var(--sv-primary);
  border-color: var(--sv-primary);
  color: #ffffff;
}

/* Boutons outline dark déjà Bootstrap, on les laisse. */

/* ---------- Sections (padding / titres) ---------- */

section {
  scroll-margin-top: 5rem; /* pour les ancres (#solutions, #linux, etc.) */
}

/* Titres de section */
section h2.fw-bold {
  letter-spacing: 0.01em;
}

/* ----------------------------------------------------------
 * FAQ / Accordéon – thème noir & blanc élégant
 * -------------------------------------------------------- */

.accordion {
  --sv-accordion-radius: 0.5rem;
}

/* Chaque bloc question/réponse : même style partout */
.accordion-item {
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: var(--sv-accordion-radius);
  overflow: hidden;                  /* applique bien les arrondis au header + body */
  margin-bottom: 0.75rem;
  background-color: #ffffff;
}

/* Bouton/question */
.accordion-button {
  background-color: #ffffff;
  color: #212529;
  box-shadow: none;
  border: 0;
  font-weight: 500;
  padding: 0.9rem 1.25rem;
}

/* Survol : léger voile */
.accordion-button:hover {
  background-color: #f9fafb;
  color: #212529;
}

/* Focus : pas de halo bleu, juste un outline discret */
.accordion-button:focus {
  outline: 2px solid rgba(0, 0, 0, 0.25);
  outline-offset: 2px;
  box-shadow: none;
}

/* Quand la question est OUVERTE */
.accordion-button:not(.collapsed) {
  color: #000000;
  background-color: #ffffff;
  font-weight: 600;
  box-shadow: inset 3px 0 0 #000000;   /* barre noire sur la question */
}

/* Wrapper de la réponse */
.accordion-collapse {
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

/* Quand la réponse est visible : barre noire à gauche aussi sur le bloc de réponse */
.accordion-collapse.show {
  border-left: 3px solid #000000;      /* même ligne noire que la question */
}

/* Corps de la réponse */
.accordion-body {
  background-color: #f9fafb;           /* léger gris pour distinguer de la question suivante */
  color: #212529;
  padding: 0.75rem 1.25rem 1rem 1.25rem;
}

/* ---------- Bouton "Back to top" ---------- */

.back-to-top {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  background-color: var(--sv-primary);
  color: #ffffff;
  box-shadow: 0 0.75rem 1.8rem rgba(15, 23, 42, 0.45);
  z-index: 1030;
  transition: opacity 0.2s ease, transform 0.2s ease, background-color 0.15s ease;
}

/* Tu sembles gérer l’affichage avec d-none / d-flex en JS.
   On n’emploie pas "display" ici pour ne pas casser ton script. */

.back-to-top:hover {
  background-color: var(--sv-primary-soft);
  color: #ffffff;
  transform: translateY(-1px);
}

/* ---------- Footer ---------- */

.site-footer,
footer.site-footer {
  background-color: #111827;
  color: #e5e7eb;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.site-footer a {
  color: #e5e7eb;
}

.site-footer a:hover {
  color: #ffffff;
}

/* ---------- Utilitaires divers ---------- */

/* Petits textes gris */
.text-muted {
  color: #5c636a !important;
}

/* Eviter toute fantaisie sur "ul" : pas de content, pas de styles bizarres */
ul {
  margin-top: 0;
  margin-bottom: 1rem;
}

/* Ne pas toucher aux "ul::before" ou "li::before" pour ne pas voir apparaître des /ul :) */

/* Images dans les sections "cas d’usage / illustrations" */
img.img-fluid {
  border-radius: 0.9rem;
}

/* ---------- Responsive léger ---------- */

@media (max-width: 575.98px) {
  .navbar-brand {
    font-size: 1rem;
  }

  #hero h1 {
    font-size: 1.9rem;
  }
}

