/* =========================
   SiteBug — CSS clean (v1)
   Objectifs :
   - dédoublonné, cohérent, lisible
   - corrections (ex : "/.navbar" invalide)
   - variables (couleurs, radius, ombres)
   - responsive harmonisé
   ========================= */

/* ---------- Variables / base ---------- */
:root{
  --maxw: 1160px;

  --blue-100: #cfe3f3;
  --blue-500: #39b5ff;
  --blue-700: #0b57d0;
  --blue-800: #004aad;

  --bg-soft: #f3f4f6;
  --surface: #ffffff;
  --text: #0f172a;
  --text-2: #111827;
  --muted: #475569;

  --border: rgba(15,23,42,.08);
  --shadow: 0 10px 24px rgba(15,23,42,.08);

  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 18px;
  --radius-xl: 26px;

  --gap: 18px;
}

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

html, body{ height:100%; }

body{
  margin:0;
  color:var(--text);
  font-family: Arial, Helvetica, sans-serif;
  background:#fff;
}

img{ max-width:100%; height:auto; display:block; }

a{ color:inherit; }

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; scroll-behavior:auto !important; }
}

/* Utilitaire : container interne (tu l’utilises déjà partout) */
.expertise__inner,
.stats-band__inner,
.about-band__inner,
.process__inner,
.causes__inner,
.criteria__inner,
.faq__inner,
.blog-latest__inner,
.site-footer__inner{
  max-width:var(--maxw);
}

/* ---------- Header topbar (tel) ---------- */
/* Si possible, remplace "header p" par une classe .header-topbar dans ton HTML.
   Pour compat, on garde header p. */
header p{
  background-color:#c7dff0;
  min-height:40px;
  margin:0;
  padding:8px 12px;
  text-align:center;
  text-transform:uppercase;
  font-size:20px;
  color:var(--blue-800);
}

/* ---------- Navbar ---------- */
/* Tu utilises Bootstrap : on évite de tout écraser, on ajuste proprement. */
nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:#fff;
  padding:10px 20px;
}

/* Centre les liens dans #navbarNav */
#navbarNav{
  justify-content:center;
  font-size:15px;
  font-weight:700;
}

.navbar .navbar-nav{
  margin:0;
  gap:18px;
}

/* Liens : underline animée */
.navbar .navbar-nav .nav-link{
  position:relative;
  padding:14px 10px;
}

.navbar .navbar-nav .nav-link::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  bottom:6px;
  height:3px;
  border-radius:999px;
  background:#1d4ed8;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .18s ease;
}

.navbar .navbar-nav .nav-link:hover::after,
.navbar .navbar-nav .nav-link:focus-visible::after,
.navbar .navbar-nav .nav-link.active::after,
.navbar .navbar-nav .nav-link[aria-current="page"]::after{
  transform:scaleX(1);
}

/* Espace menu -> bouton (si tu as un .d-flex dans navbarNav) */
#navbarNav .d-flex{ margin-left:12px; }

/* Un peu plus d’air dans le container navbar (si Bootstrap) */
.navbar > .container{
  padding-left:24px;
  padding-right:24px;
}

@media (max-width: 991.98px){
  #navbarNav .d-flex{
    margin-left:0;
    margin-top:12px;
  }
  #navbarNav .btn,
  .navbar .btn{
    width:100%;
    margin-top:12px;
  }
}

/* ---------- Hero / intro ---------- */
h1{
  font-size:36px;
  font-weight:800;
  text-align:center;
  padding-top:50px;
  margin:0;
}

#sitebug p{
  font-size:18px;
  color:#333;
  text-align:center;
  padding:20px 50px;
  margin:0;
}

.logo{
  width:150px;
  height:auto;
}

/* ---------- Tech logos ---------- */
.tech-logos .logos{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:28px;
  flex-wrap:wrap;
  padding:24px 0;
}

.tech-logos .logo{
  height:70px;
  width:auto;
  max-width:180px;
  object-fit:contain;
}

/* ---------- Stats band ---------- */
.stats-band{
  background:var(--blue-100);
  padding:22px 0 18px;
}

.stats-band__title{
  margin:0 0 18px;
  text-align:center;
  color:#0b4aa6;
  font-size:22px;
  font-weight:800;
  line-height:1.25;
}

.stats{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:var(--gap);
  align-items:center;
  text-align:center;
}

.stat{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:6px 8px;
}

.stat__icon{
  font-size:64px;
  line-height:1;
  color:#ffffff;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.10));
  margin-bottom:6px;
}

.stat__value{
  color:#ff5c73;
  font-size:44px;
  font-weight:900;
  line-height:1;
  margin:2px 0 6px;
}

.stat__label{
  color:#0b4aa6;
  font-size:16px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

@media (max-width: 900px){
  .stats{ grid-template-columns:1fr; gap:14px; }
  .stat__value{ font-size:40px; }
  .stat__icon{ font-size:58px; }
}

/* ---------- Expertise cards ---------- */
.expertise{
  padding:26px 0;
}

.expertise__title{
  text-align:center;
  margin:0 0 16px;
  font-size:28px;
  font-weight:900;
  color:var(--text);
}

.expertise-card{
  background:var(--bg-soft);
  border-radius:var(--radius-lg);
  padding:22px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:var(--gap);
  align-items:center;
}

.expertise-card__kicker{
  margin:0 0 10px;
  font-size:14px;
  letter-spacing:.04em;
  font-weight:900;
  color:var(--text);
  text-transform:uppercase;
}

.expertise-card p{
  margin:0 0 10px;
  color:var(--text-2);
  line-height:1.55;
  font-size:15.5px;
}

.expertise-card__list{
  margin:10px 0 16px;
  padding-left:18px;
  color:var(--text-2);
}

.expertise-card__list li{
  margin:6px 0;
  line-height:1.45;
}

.expertise-card__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:14px;
  background:var(--blue-700);
  color:#fff;
  text-decoration:none;
  font-weight:800;
  box-shadow:0 10px 22px rgba(11,87,208,.18);
  transition:transform .12s ease, box-shadow .12s ease;
}
.expertise-card__btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 26px rgba(11,87,208,.22);
}

.expertise-card__media{
  display:flex;
  justify-content:center;
  align-items:center;
}

/* Cercle (si tu veux l’effet) */
.expertise-card__circle{
  width:320px;
  height:320px;
  border-radius:50%;
  background: radial-gradient(circle at 30% 20%, #4ea9ff 0%, #1677ff 60%, #0b57d0 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.expertise-card__img{
  width:100%;
  height:100%;
  object-fit:contain;
}

/* Variante : PAS de cercle (utilise <article class="expertise-card expertise-card--no-circle"> ) */
.expertise-card--no-circle .expertise-card__circle{
  background:transparent;
  width:auto;
  height:auto;
  padding:0;
  border-radius:0;
}
.expertise-card--no-circle .expertise-card__img{
  width:auto;
  height:auto;
  max-width:320px;
}

/* Inversion image/texte */
.expertise-card.is-reverse{
  grid-template-columns: .8fr 1.2fr;
}
.expertise-card.is-reverse .expertise-card__media{ order:1; }
.expertise-card.is-reverse .expertise-card__text{ order:2; }

.expertise-card__actions{
  display:flex;
  justify-content:center;
  margin-top:10px;
}

@media (max-width: 980px){
  .expertise-card{
    grid-template-columns:1fr;
  }
  .expertise-card__circle{
    width:260px;
    height:260px;
  }
  .expertise-card.is-reverse .expertise-card__media,
  .expertise-card.is-reverse .expertise-card__text{
    order:initial;
  }
}

/* ---------- About band ---------- */
.about-band{
  padding:22px 0;
}

.about-card{
  background:var(--blue-100);
  border-radius:var(--radius-xl);
  padding:22px 26px;
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:var(--gap);
  align-items:center;
  overflow:hidden;
}

.about-card__title{
  margin:0 0 10px;
  font-size:34px;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--text);
  text-transform:uppercase;
}

.about-card p{
  margin:0 0 12px;
  color:var(--text-2);
  line-height:1.55;
  font-size:15.5px;
}

.about-card__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:14px;
  background:var(--blue-700);
  color:#fff;
  text-decoration:none;
  font-weight:800;
  box-shadow:0 10px 22px rgba(11,87,208,.18);
  transition:transform .12s ease, box-shadow .12s ease;
}
.about-card__btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 26px rgba(11,87,208,.22);
}

.about-card__media{
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
}

.about-card__img{
  width:100%;
  max-width:260px;
  object-fit:cover;
  border-radius:10px;
}

@media (max-width: 980px){
  .about-card{
    grid-template-columns:1fr;
  }
  .about-card__media{ justify-content:center; }
  .about-card__img{ max-width:240px; }
  .about-card__title{ font-size:28px; }
}

/* ---------- Process (3 étapes + 2 boxes) ---------- */
.process{
  background:var(--bg-soft);
  padding:26px 0;
}

.process__title{
  margin:0 0 18px;
  font-size:28px;
  font-weight:900;
  color:var(--text);
  text-align:center;
}

.process-steps{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:var(--gap);
  margin-bottom:18px;
}

.step{
  position:relative;
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:22px 18px 18px;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.06);
  text-align:center;
}

.step__badge{
  position:absolute;
  top:-16px;
  left:50%;
  transform:translateX(-50%);
  width:40px;
  height:40px;
  border-radius:999px;
  background:#ff5c73;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  box-shadow:0 10px 22px rgba(255,92,115,.22);
}

.step__title{
  margin:14px 0 10px;
  font-size:18px;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--text);
}

.step__text{
  margin:0;
  color:var(--text-2);
  line-height:1.55;
  font-size:14.8px;
}

.process-bottom{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:var(--gap);
}

.box{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:18px 18px 16px;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.06);
}

.box__title{
  margin:0 0 10px;
  font-size:22px;
  font-weight:900;
  color:var(--text);
}

.box p{
  margin:0 0 10px;
  color:var(--text-2);
  line-height:1.6;
  font-size:15px;
}

.checklist{
  margin:8px 0 0;
  padding:0;
  list-style:none;
}

.checklist li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:7px 0;
  color:var(--text-2);
  line-height:1.45;
  font-size:15px;
}

.checklist li::before{
  content:"✓";
  font-weight:900;
  color:#6d28d9;
  margin-top:1px;
}

@media (max-width: 980px){
  .process-steps{ grid-template-columns:1fr; }
  .process-bottom{ grid-template-columns:1fr; }
  .process__title{ font-size:24px; }
}

/* ---------- Causes (6 cards) ---------- */
.causes{
  background:var(--bg-soft);
  padding:26px 0;
}

.causes__title{
  margin:0 0 18px;
  font-size:22px;
  font-weight:900;
  color:var(--text);
  letter-spacing:.02em;
  text-transform:uppercase;
  text-align:center;
  padding-bottom:23px;
}

.causes-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:var(--gap);
}

.cause-card{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:18px 16px 16px;
  text-align:center;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.06);
}

/* --- Causes : icônes SANS cercle, plus grandes --- */
.cause-card__icon{
  width: 100%;
  height: auto;
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0;
  margin: 0 auto 12px;      /* plus de marge négative */
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: visible;
}

.cause-card__img{
  width: clamp(90px, 9vw, 140px);  /* augmente la taille */
  height: auto;
  object-fit: contain;
  display: block;
}
/* Réduit uniquement la dernière carte (Base de données encombrée) */
.causes-grid .cause-card:last-child .cause-card__img{
  width: clamp(55px, 5.0vw, 75px);
  height: auto;
}

.cause-card__title{
  margin:8px 0 8px;
  font-size:15.5px;
  font-weight:900;
  color:var(--text);
}

.cause-card__text{
  margin:0;
  color:var(--text-2);
  line-height:1.55;
  font-size:14.5px;
}

@media (max-width: 980px){
  .causes-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
  .causes-grid{ grid-template-columns:1fr; }
  .cause-card__icon{ margin-top:0; }
}

/* ---------- Criteria (3 lignes) ---------- */
/* Tu voulais du blanc autour (gauche/droite) + espace au-dessus : on le fait proprement */
.criteria{
  background:var(--bg-soft);
  padding:26px 0;
  margin-top:40px;
  margin-bottom:40px;
  margin-inline: clamp(12px, 4vw, 60px);
  border-radius:var(--radius-lg);
}

.criteria__inner{
  padding-left:20px;
  padding-right:20px;
}

.criteria__title{
  margin:0 0 18px;
  font-size:28px;
  font-weight:900;
  color:var(--text);
}

.criteria__row{
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap:26px;
  padding:18px 8px;
  border-top:1px solid rgba(15,23,42,.10);
}

.criteria__row:first-child{ border-top:none; }

.criteria__left{
  font-size:22px;
  font-weight:900;
  color:var(--text);
  line-height:1.25;
}

.criteria__right{
  font-size:15.5px;
  line-height:1.65;
  color:var(--text-2);
}

@media (max-width: 980px){
  .criteria__row{
    grid-template-columns:1fr;
    gap:10px;
    padding:16px 6px;
  }
  .criteria__left{ font-size:20px; }
}

/* ---------- FAQ ---------- */
.faq{
  background:var(--blue-100);
  padding:22px 0 26px;
}

.faq__title{
  margin:0 0 14px;
  font-size:28px;
  font-weight:900;
  color:var(--text);
}

.faq-acc{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.faq-item{
  border-radius:var(--radius-lg);
}

.faq-q{
  width:100%;
  border:1px solid var(--border);
  background:#fff;
  padding:14px 16px;
  border-radius:var(--radius-lg);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  cursor:pointer;
  color:var(--text);
  font-size:16px;
  font-weight:700;
  text-align:left;
  box-shadow:0 10px 20px rgba(15,23,42,.08);
  white-space:normal;
}

.faq-q span:first-child{
  flex:1;
  min-width:0;
  line-height:1.35;
  overflow-wrap:anywhere;
  word-break:break-word;
}

.faq-ico{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  font-weight:900;
  color:var(--text);
  background:#eef2ff;
  flex:0 0 auto;
  transition:transform .12s ease;
}

.faq-a{
  margin-top:10px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:14px 16px;
  box-shadow:0 10px 20px rgba(15,23,42,.08);
}

.faq-a p{
  margin:0;
  line-height:1.65;
  color:var(--text-2);
  font-size:15.5px;
  overflow-wrap:anywhere;
  word-break:break-word;
}

.faq-item.is-open .faq-ico{
  transform:rotate(45deg);
}

@media (max-width:720px){
  .faq__title{ font-size:22px; }
  .faq-q{ padding:12px 14px; }
}

/* ---------- Blog latest ---------- */
.blog-latest{
  padding:28px 0 34px;
  background:#fff;
}

.blog-latest__title{
  text-align:center;
  margin:0 0 18px;
  font-size:30px;
  font-weight:900;
  color:var(--text);
}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.post-card{
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,23,42,.06);
  display:flex;
  flex-direction:column;
  min-height:100%;
}

.post-card__img{
  width:100%;
  height:160px;
  object-fit:cover;
}

.post-card__body{
  padding:14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.post-card__meta{
  display:flex;
  gap:12px;
  color:#64748b;
  font-size:13px;
  align-items:center;
}

.meta-item{
  display:inline-flex;
  gap:6px;
  align-items:center;
}

.post-card__title{
  margin:0;
  font-size:15.8px;
  line-height:1.35;
  font-weight:900;
}

.post-card__title a{
  color:var(--text);
  text-decoration:none;
}
.post-card__title a:hover{ text-decoration:underline; }

.post-card__excerpt{
  margin:0;
  color:var(--muted);
  font-size:14.2px;
  line-height:1.6;
  flex:1;
}

.post-card__link{
  color:#2563eb;
  font-weight:800;
  text-decoration:none;
  font-size:14px;
}
.post-card__link:hover{ text-decoration:underline; }

@media (max-width: 980px){
  .blog-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
  .blog-grid{ grid-template-columns:1fr; }
  .post-card__img{ height:180px; }
}

/* ---------- Footer ---------- */
.site-footer{
  background:#efefef;
  padding:18px 0 12px;
}

.footer-cta{
  background:var(--blue-500);
  border-radius:999px;
  padding:18px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}

.footer-cta__text{
  font-size:28px;
  font-weight:900;
  color:var(--text);
}

.footer-cta__btn{
  background:#fff;
  color:var(--text);
  text-decoration:none;
  font-weight:800;
  padding:12px 18px;
  border-radius:14px;
  min-width:220px;
  text-align:center;
  box-shadow:0 10px 20px rgba(15,23,42,.12);
  transition:transform .12s ease;
}
.footer-cta__btn:hover{ transform:translateY(-1px); }

.footer-cols{
  display:grid;
  grid-template-columns: 1fr 1.6fr 1fr;
  gap:26px;
  padding:6px 0 16px;
}

.footer-col__title{
  margin:0 0 10px;
  font-size:14px;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--text);
  text-transform:uppercase;
}

.footer-info{
  margin:0 0 10px;
  color:var(--text-2);
  line-height:1.55;
  font-size:14.5px;
}

.footer-info a{
  color:var(--text-2);
  text-decoration:none;
}
.footer-info a:hover{ text-decoration:underline; }

.footer-ico{
  display:inline-block;
  width:20px;
}

.footer-links{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:7px;
}

.footer-links--2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.footer-links--2 ul{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:7px;
}

.footer-links a{
  color:var(--text);
  text-decoration:underline;
  font-size:14.5px;
}
.footer-links a:hover{ text-decoration:none; }

.footer-social{
  display:flex;
  gap:10px;
  margin-top:10px;
}

.social-btn{
  width:48px;
  height:48px;
  border-radius:10px;
  background:#3b82f6;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:900;
  font-size:20px;
}

.social-btn--ig{
  background:linear-gradient(135deg,#7c3aed,#ec4899,#f59e0b);
}

.footer-bottom{
  text-align:center;
  padding-top:10px;
  border-top:1px solid rgba(15,23,42,.10);
  color:var(--text);
  font-size:13px;
}

@media (max-width: 980px){
  .footer-cols{ grid-template-columns:1fr; }
  .footer-cta{
    border-radius:22px;
    flex-direction:column;
    align-items:flex-start;
  }
  .footer-cta__btn{
    width:100%;
    min-width:0;
  }
  .footer-links--2{ grid-template-columns:1fr; }
}

/* --- FIX MOBILE : image sous le texte (même pour .is-reverse) --- */
@media (max-width: 991.98px){
  .expertise-card{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch;
  }

  .expertise-card__text{ order: 1; }
  .expertise-card__media{
    order: 2;
    width: 100%;
    margin-top: 14px;
    justify-content: center;
  }

  /* Taille d’image clean sur mobile */
  .expertise-card__img{
    width: min(320px, 100%);
    height: auto;
  }
}