@charset "UTF-8";

/* =========================================================
   SITE PAGES
   Uniquement les classes manquantes
   Le reste est déjà géré par style.css
========================================================= */

/* ===== Layouts complémentaires ===== */

.sp-wrap{
  max-width: 1240px;
  margin: 0 auto;
}

.sp-wrap-narrow{
  max-width: 980px;
  margin: 0 auto;
}

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

/* ===== Cartes / blocs complémentaires ===== */

.sp-box,
.sp-feature-card,
.sp-process,
.sp-faq-item,
.sp-stat{
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.sp-box{
  padding: 28px 24px;
  text-align: left;
  transition: opacity .22s ease, transform .22s ease, box-shadow .22s ease;
}

.sp-box:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.sp-icon{
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--blue-pale);
  color: var(--blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  margin-bottom: 16px;
}

.sp-box h3,
.sp-process h3,
.sp-feature-card h3{
  font-family: var(--font-cormorant);
  color: var(--blue);
  line-height: 1.1;
}

.sp-box h3{
  font-size: 1.38rem;
  margin-bottom: 10px;
}

.sp-box p{
  color: var(--gray-600);
  font-size: .94rem;
  line-height: 1.76;
}

/* ===== Side panel ===== */

.sp-side-panel{
  background: linear-gradient(145deg, var(--blue) 0%, var(--blue-mid) 100%);
  border-radius: var(--radius-lg);
  padding: 38px 34px;
  color: #fff;
  position: relative;
  overflow: hidden;
  text-align: left;
}

.sp-side-panel::before{
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}

.sp-side-panel h3{
  position: relative;
  z-index: 1;
  font-family: var(--font-cormorant);
  font-size: 1.8rem;
  line-height: 1.12;
  margin-bottom: 16px;
  color: #fff;
}

.sp-side-panel p{
  position: relative;
  z-index: 1;
  color: rgba(255,255,255,.88);
  line-height: 1.8;
  margin-bottom: 20px;
  font-size: .95rem;
}

.sp-check-list{
  list-style: none;
  position: relative;
  z-index: 1;
  display: grid;
  gap: 13px;
}

.sp-check-list li{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .92rem;
  line-height: 1.7;
  color: rgba(255,255,255,.92);
}

.sp-check-list li span{
  color: #E8C860;
  flex-shrink: 0;
}

/* ===== Mini listes ===== */

.sp-mini-list,
.sp-feature-list{
  list-style: none;
}

.sp-mini-list{
  margin-top: 16px;
  display: grid;
  gap: 8px;
}

.sp-mini-list li{
  position: relative;
  padding-left: 14px;
  color: var(--gray-600);
  font-size: .88rem;
  line-height: 1.65;
}

.sp-mini-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 11px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
}

.sp-feature-list{
  display: grid;
  gap: 10px;
}

.sp-feature-list li{
  position: relative;
  padding-left: 18px;
  color: var(--gray-600);
  line-height: 1.72;
  font-size: .93rem;
}

.sp-feature-list li::before{
  content: "—";
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 700;
}
.methodologie {
  background: var(--off-white);
}
/* ===== Feature block ===== */

.sp-feature-section{
  background: #fff;
  padding: 96px 6%;
}

.sp-feature{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 34px;
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
}

.sp-feature-media{
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  background: #f2f5f8;
}

.sp-feature-media picture,
.sp-feature-media img{
  display: block;
  width: 100%;
  height: 100%;
}

.sp-feature-media img{
  object-fit: cover;
}

.sp-feature-card{
  padding: 38px 34px;
  text-align: left;
}

.sp-feature-card h3{
  font-size: 1.8rem;
  margin-bottom: 14px;
}

.sp-feature-card p{
  color: var(--gray-600);
  line-height: 1.84;
  margin-bottom: 16px;
  font-size: .95rem;
}

/* ===== Stats ===== */

.sp-stats{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.sp-stat{
  padding: 28px 20px;
  text-align: center;
}

.sp-stat-num{
  font-family: var(--font-cormorant);
  font-size: 2.4rem;
  line-height: 1;
  font-weight: 700;
  color: var(--blue);
  margin-bottom: 8px;
}

.sp-stat-label{
  font-size: .84rem;
  color: var(--gray-600);
  line-height: 1.55;
}

/* ===== Process ===== */

.sp-process-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.sp-process{
  padding: 26px 22px;
  text-align: left;
}

.sp-step{
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-cormorant);
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.sp-process h3{
  font-size: 1.35rem;
  margin-bottom: 10px;
}

.sp-process p{
  color: var(--gray-600);
  line-height: 1.72;
  font-size: .92rem;
}

/* ===== FAQ statique ===== */

.sp-faq{
  display: grid;
  gap: 14px;
}

.sp-faq-item{
  padding: 24px 24px 20px;
  text-align: left;
}

.sp-faq-item h3{
  font-size: 1rem;
  line-height: 1.45;
  color: var(--dark);
  margin-bottom: 8px;
  font-weight: 600;
  font-family: var(--font-jost);
}

.sp-faq-item p{
  color: var(--gray-600);
  line-height: 1.8;
  font-size: .92rem;
}

/* ===== Responsive ===== */

@media (max-width:1200px){
  .sp-process-grid,
  .sp-stats{
    grid-template-columns: repeat(2, 1fr);
  }

  .sp-grid-3{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width:900px){
  .sp-feature{
    grid-template-columns: 1fr;
  }
}

@media (max-width:640px){
  .sp-grid-3,
  .sp-process-grid,
  .sp-stats{
    grid-template-columns: 1fr;
  }

  .sp-feature-card,
  .sp-side-panel,
  .sp-box{
    padding: 22px 18px;
  }
}