:root {
  --wrap-max: 1220px;
  --wrap-pad: 32px;

  /* Espacement vertical des blocs */
  --section-y: 65px;
  --section-y-sm: 45px;

  /* Cohérence des arrondis SaaS */
  --ps-radius-xl: 28px; 
  --ps-radius-lg: 22px;
  --ps-radius-md: 16px;

  /* Grille standard */
  --grid-gap: 14px; 
}

.wrap {
  max-width: var(--wrap-max);
  margin: 0 auto;
  padding: 0 var(--wrap-pad);
}

section {
  padding: var(--section-y) 0;
  position: relative; /* Indispensable pour tes glows et décors */
  overflow: hidden;   /* Évite les scrolls horizontaux dus aux animations */
}

@media(max-width: 640px) {
  :root { --wrap-pad: 18px; }
  section { padding: var(--section-y-sm) 0; }
}
/* Annule l'espacement pour les petites cartes */
section.ps-compareLite__card {
  padding: 0;
  overflow: hidden; /* Celui-ci on le garde pour les coins arrondis de la carte */
}

/* RESSUSCITE L'EFFET STICKY DU COMPARATIF */
section.ps-compareLite {
  overflow: visible;
}

/* ═══════════════════════════════════════
   PS SECTION TITLE
   ═══════════════════════════════════════ */

.ps-sec{
  text-align:center;
  margin-bottom:30px;
}

@media(max-width:640px){
  .ps-sec{
    margin-bottom:22px;
  }
}
.ps-sec__ey{
  font-size:11.5px;
  font-weight:820;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ps-amber);
  margin-bottom:16px;
  display:block;
}

.ps-sec__title{
  font-size:clamp(26px,3.4vw,44px);
  font-weight:860;
  color:var(--ps-text);
  line-height:1.04;
  letter-spacing:-.035em;
  margin-bottom:16px;
}

.ps-sec__title em{
  font-style:normal;
  color:var(--ps-blue);
}

.ps-sec__sub{
  font-size:17px;
  color:var(--ps-text-2);
  max-width:600px;
  margin:0 auto;
  line-height:1.6;
  font-weight:500;
}

/* ═══════════════════════════════════════
   UTILITAIRE : masquer sur mobile
   ═══════════════════════════════════════ */
@media (max-width: 980px) {
  .ps-hide-mobile { display: none !important; }
}
@media (min-width: 981px) {
  .ps-hide-desktop { display: none !important; }
}

/* ═══════════════════════════════════════
   Boutons
   ═══════════════════════════════════════ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 10px; padding: 15px 30px; border-radius: 100px;
  font-family: inherit; font-size: 15.5px; font-weight: 800;
  border: none; cursor: pointer; white-space: nowrap;
  transition: all .26s var(--ps-ease);
}
.btn--primary {
  background: var(--ps-blue); color: #fff;
  box-shadow: 0 6px 24px rgba(70,103,129,.22);
}
.btn--primary:hover {
  background: var(--ps-blue-deep);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(70,103,129,.30);
}
.btn--primary .arr {
  display: inline-block; font-size: 17px;
  transition: transform .28s var(--ps-spring);
}
.btn--primary:hover .arr { transform: translateX(4px); }

.btn--ghost {
  background: transparent; color: var(--ps-text-2);
  font-weight: 700; padding: 15px 4px;
  position: relative; border-radius: 0;
}
.btn--ghost::after {
  content: ''; position: absolute;
  bottom: 10px; left: 4px; right: 4px;
  height: 1.5px; background: rgba(26,42,53,.14);
  transition: background .2s;
}
.btn--ghost:hover { color: var(--ps-blue); }
.btn--ghost:hover::after { background: var(--ps-amber); }




/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero {
  padding: 44px 0 calc(var(--section-y) / 2);
  background: var(--ps-bg);
}
/* ── titre kicker ── */
.hero__label{
  display:inline-flex;
  align-items:center;
  margin-bottom:14px;
}

.hero__label span{
  font-size:11.5px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ps-amber);
}

@media(max-width:980px){
  .hero__label{ justify-content:center; }
}
/* ── ambient light ── */
.hero__glow {
  position: absolute;
  pointer-events: none;
  border-radius: 50%;
}
.hero__glow--amber {
  width: 700px; height: 700px;
  top: -22%; right: -8%;
  background: radial-gradient(ellipse, rgba(199,164,109,.13), transparent 58%);
  animation: drift 10s ease-in-out infinite alternate;
}
.hero__glow--blue {
  width: 550px; height: 550px;
  bottom: -28%; left: -12%;
  background: radial-gradient(ellipse, rgba(70,103,129,.08), transparent 58%);
  animation: drift 10s ease-in-out infinite alternate-reverse;
}
@keyframes drift {
  0%   {transform: translate(0,0) scale(1)}
  100% {transform: translate(-24px,18px) scale(1.06)}
}

.hero__inner {
  display: grid;
  grid-template-columns: 1.12fr .88fr;
  gap: 52px;
  align-items: center;
  position: relative; z-index: 1;
}

/* ── H1 ── */
.hero__h1 {
  font-size: clamp(36px, 5vw, 66px);
  font-weight: 900;
  line-height: .98;
  letter-spacing: -.045em;
  color: var(--ps-text);
  margin-bottom: 26px;
  animation: up .55s var(--ps-ease) .06s both;
}
.hero__h1 span {
  position: relative;
  color: var(--ps-blue);
  white-space: nowrap;
}
.hero__h1 span::after {
  content: ''; position: absolute;
  left: 0; right: 0; bottom: .04em; height: .13em;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--ps-amber), rgba(199,164,109,.25));
  transform-origin: left;
  animation: grow .7s var(--ps-ease) .45s both;
}
@keyframes grow { from {transform: scaleX(0)} to {transform: scaleX(1)} }

/* ── lead ── */
.hero__lead {
  font-size: 17.5px; line-height: 1.62;
  color: var(--ps-text-2); max-width: 470px;
  margin-bottom: 36px; font-weight: 500;
  animation: up .55s var(--ps-ease) .12s both;
}
.hero__lead strong { color: var(--ps-text); font-weight: 700; }

/* ── actions ── */
.hero__actions {
  display: flex; align-items: center; gap: 20px;
  margin-bottom: 42px;
  animation: up .55s var(--ps-ease) .18s both;
}

/* ── trust bar ── */
.hero__trust {
  display: flex; flex-wrap: wrap; gap: 20px;
  animation: up .55s var(--ps-ease) .24s both;
}
.hero__trust-item {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; color: var(--ps-text-3);
}
.hero__trust-ico {
  width: 24px; height: 24px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; flex-shrink: 0;
}
.hero__trust-ico--g { background: var(--ps-green-soft); color: var(--ps-green); }
.hero__trust-ico--b { background: var(--ps-blue-wash); color: var(--ps-blue); }
.hero__trust-ico--a { background: var(--ps-amber-soft); color: var(--ps-amber-dark); }

/* ── visual ── */
.hero__visual {
  position: relative;
  animation: up .65s var(--ps-ease) .14s both;
}
.hero__frame {
  position: relative; border-radius: var(--ps-radius-xl); overflow: hidden;
  background: var(--ps-white);
  box-shadow: 0 36px 80px rgba(70,103,129,.14), 0 0 0 1px rgba(70,103,129,.04);
}
.hero__frame::after {
  content: ''; position: absolute; inset: 7px;
  border-radius: var(--ps-radius-lg); border: 1px solid rgba(255,255,255,.55);
  pointer-events: none; z-index: 2;
}
.hero__frame img { width: 100%; height: auto; display: block; }

/* floaters */
.hero__card {
  position: absolute; z-index: 10;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(14px);
  border-radius: var(--ps-radius-md);
  box-shadow: 0 14px 44px rgba(70,103,129,.16), 0 0 0 1px rgba(70,103,129,.04);
}

.hero__card--progress {
  bottom: -18px; left: -26px;
  padding: 16px 20px; min-width: 224px;
  border-left: 3px solid var(--ps-amber);
  animation: bob 5s ease-in-out infinite;
}
.hero__card--rdv {
  top: 22px; right: -18px;
  padding: 14px 18px;
  animation: bob 5s ease-in-out infinite 2.4s;
}
@keyframes bob {
  0%, 100% {transform: translateY(0)}
  50% {transform: translateY(-7px)}
}

.fc__label {
  font-size: 10px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ps-text-3); margin-bottom: 10px;
}
.fc__track {
  height: 6px; border-radius: 4px;
  background: var(--ps-blue-wash); margin-bottom: 8px;
  position: relative; overflow: visible;
}
.fc__bar {
  height: 100%; width: 0; border-radius: 4px;
  background: linear-gradient(90deg, var(--ps-amber), #D4B27A);
  position: relative;
  animation: barFill 1.1s var(--ps-ease) .7s forwards;
}
@keyframes barFill { to {width: 72%} }
.fc__bar::after {
  content: ''; position: absolute; right: -6px; top: 50%;
  transform: translateY(-50%);
  width: 12px; height: 12px;
  background: #fff; border: 2.5px solid var(--ps-amber); border-radius: 50%;
  box-shadow: 0 2px 8px rgba(199,164,109,.28);
}
.fc__info { font-size: 12.5px; font-weight: 660; color: var(--ps-text); }
.fc__info span { color: var(--ps-text-3); font-weight: 400; }

.fc__row { display: flex; align-items: center; gap: 10px; }
.fc__ava {
  width: 32px; height: 32px; border-radius: 10px;
  background: var(--ps-green-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; color: var(--ps-green); font-weight: 800;
}
.fc__txt strong { display: block; font-size: 12.5px; font-weight: 800; color: var(--ps-green); }
.fc__txt span { font-size: 11.5px; color: var(--ps-text-3); font-weight: 400; }


/* ═══════════════════════════════════════
   HERO FORMAT A — Photo + carte glass
   ═══════════════════════════════════════ */
.va__wrap { position: relative; }

.va__frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow:
    0 36px 80px rgba(70,103,129,.16),
    0 0 0 1px rgba(70,103,129,.04);
}
.va__frame img {
  width: 100%; height: 100%;
  display: block; object-fit: cover;
  object-position: center 60%;
  filter: saturate(.88) contrast(1.03);
}
/* teinte chaude uniforme */
.va__frame::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(160deg, rgba(199,164,109,.08), rgba(70,103,129,.06));
  mix-blend-mode: multiply;
  pointer-events: none;
}
.va__frame--portrait { max-height: 500px; min-height: 380px; }
.va__frame--landscape { max-height: 400px; }

/* carte glass overlay */
.va__card {
  position: absolute;
  bottom: 14px; left: 12px; right: 12px;
  z-index: 3;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 14px 40px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.45);
}
.va__card-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 10px;
}
.va__card-ico {
  width: 38px; height: 38px; border-radius: 11px;
  background: var(--ps-amber-pale);
  border: 1px solid rgba(199,164,109,.14);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0; color: var(--ps-blue);
}
.va__card-title { font-size: 13.5px; font-weight: 800; color: var(--ps-text); }
.va__card-sub { font-size: 10.5px; color: var(--ps-text-3); margin-top: 1px; }
.va__card-pct {
  margin-left: auto;
  font-size: 11.5px; font-weight: 800;
  color: var(--ps-green); background: var(--ps-green-soft);
  padding: 4px 11px; border-radius: 100px;
}
.va__tags { display: flex; gap: 5px; flex-wrap: wrap; }
.va__tag {
  font-size: 10px; font-weight: 700;
  padding: 4px 9px; border-radius: 100px;
  display: inline-flex; align-items: center; gap: 4px;
}
.va__tag i { font-size: 9px; }
.va__tag--done { background: var(--ps-green-soft); color: var(--ps-green); }
.va__tag--wip { background: var(--ps-blue-wash); color: var(--ps-blue); }

/* floater glass — desktop only */
.va__floater {
  position: absolute; top: 16px; right: -14px; z-index: 4;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-radius: 14px; padding: 12px 16px;
  box-shadow: 0 12px 36px rgba(70,103,129,.16), inset 0 1px 0 rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.45);
  animation: bob 5s ease-in-out infinite 1.5s;
}
.va__floater-row { display: flex; align-items: center; gap: 8px; }
.va__floater-row + .va__floater-row { margin-top: 5px; }
.va__floater-check { font-size: 12px; }
.va__floater-text { font-size: 11.5px; font-weight: 660; color: var(--ps-text); }


/* ═══════════════════════════════════════
   HERO FORMAT B — Dashboard app
   ═══════════════════════════════════════ */
.vb__wrap {
  position: relative;
  transform: perspective(1200px) rotateY(-3deg) rotateX(1.5deg);
  transform-origin: left center;
}
.vb__glow {
  position: absolute; top: -40px; right: -40px;
  width: 280px; height: 280px;
  background: radial-gradient(ellipse, rgba(199,164,109,.22), transparent 60%);
  border-radius: 50%; pointer-events: none;
}
.vb__frame {
  border-radius: 20px; overflow: hidden;
  background: var(--ps-bg);
  box-shadow: 0 36px 80px rgba(70,103,129,.18), 0 0 0 1px rgba(70,103,129,.04);
  border: 1px solid rgba(70,103,129,.08);
  position: relative; z-index: 1;
}

/* browser chrome */
.vb__chrome {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.8));
  border-bottom: 1px solid rgba(70,103,129,.06);
}
.vb__dots { display: flex; gap: 5px; }
.vb__dot { width: 8px; height: 8px; border-radius: 50%; }
.vb__dot:nth-child(1) { background: #f87171; }
.vb__dot:nth-child(2) { background: #fbbf24; }
.vb__dot:nth-child(3) { background: #34d399; }
.vb__url {
  flex: 1; height: 22px; border-radius: 6px;
  background: rgba(255,255,255,.9); border: 1px solid rgba(70,103,129,.06);
  display: flex; align-items: center; padding: 0 10px;
  font-size: 10px; color: var(--ps-text-3); font-weight: 600; gap: 5px;
}
.vb__url i { font-size: 8px; color: var(--ps-green); }

/* app layout */
.vb__app { display: flex; }

/* sidebar */
.vb__sidebar {
  width: 48px;
  background: linear-gradient(180deg, #466781, #3a5a70);
  display: flex; flex-direction: column; align-items: center;
  padding: 12px 0; gap: 4px;
}
.vb__nav-item {
  width: 30px; height: 30px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; color: rgba(255,255,255,.55);
}
.vb__nav-item.is-active {
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff;
}
.vb__nav-spacer { margin-top: auto; }

/* content */
.vb__content {
  flex: 1; padding: 16px;
  background: linear-gradient(180deg, rgba(250,246,242,.5), rgba(250,246,242,.95));
}
.vb__section-label {
  font-size: 9.5px; font-weight: 800; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ps-text-3); margin-bottom: 10px;
}

/* rows */
.vb__row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; margin-bottom: 5px;
  border-radius: 12px; background: var(--ps-white);
  border: 1px solid rgba(70,103,129,.04);
}
.vb__row-ico {
  width: 30px; height: 30px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; flex-shrink: 0;
}
.vb__row-ico--done { background: var(--ps-green-soft); color: var(--ps-green); }
.vb__row-ico--wip { background: var(--ps-amber-pale); color: var(--ps-amber-dark); }
.vb__row-ico--todo { background: rgba(70,103,129,.04); color: var(--ps-text-3); }
.vb__row-name { font-size: 12.5px; font-weight: 700; color: var(--ps-text); }
.vb__row-status { font-size: 10px; color: var(--ps-text-3); }
.vb__row-badge {
  margin-left: auto;
  font-size: 9.5px; font-weight: 800;
  padding: 3px 8px; border-radius: 100px; white-space: nowrap;
}
.vb__row-badge--done { color: var(--ps-green); background: var(--ps-green-soft); }
.vb__row-badge--wip { color: var(--ps-amber-dark); background: var(--ps-amber-soft); }

/* stats */
.vb__stats { display: flex; gap: 6px; margin-top: 10px; }
.vb__stat {
  flex: 1; padding: 10px 8px; border-radius: 10px;
  background: var(--ps-white); border: 1px solid rgba(70,103,129,.04);
  text-align: center;
}
.vb__stat-num { font-size: 15px; font-weight: 900; letter-spacing: -.02em; }
.vb__stat-label { font-size: 9px; font-weight: 700; color: var(--ps-text-3); margin-top: 1px; }

/* mobile header (replaces sidebar) — hidden on desktop */
.vb__mobile-header { display: none; }


@keyframes up {
  from {opacity: 0; transform: translateY(20px)}
  to {opacity: 1; transform: translateY(0)}
}

/* ═══════════════════════════════════════
   PS BENTO (GLOBAL)
   ═══════════════════════════════════════ */

.ps-bento{
  background:var(--ps-white);
  position:relative;
}

.ps-bento::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(70,103,129,.07),transparent);
}

/* grid */

.ps-bento__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:var(--grid-gap);
}

/* Bento — variante 3 colonnes égales */
.ps-bento__grid--3eq{
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:auto;
}

.ps-bento__grid--3eq .ps-bc--navy,
.ps-bento__grid--3eq .ps-bc--cream,
.ps-bento__grid--3eq .ps-bc--amber{
  grid-column:auto;
  grid-row:auto;
}

@media(max-width:980px){
  .ps-bento__grid--3eq{
    grid-template-columns:1fr;
  }
}
/* ═══════════════════════════════════════
   CARDS
   ═══════════════════════════════════════ */

.ps-bc{
  border-radius:var(--ps-radius-lg);
  padding:34px;
  display:flex;
  flex-direction:column;
  text-decoration:none!important;
  border:1px solid transparent;
  overflow:hidden;
  position:relative;

  transition:
    transform .32s var(--ps-ease),
    box-shadow .32s,
    border-color .32s;
}

.ps-bc:hover{
  transform:translateY(-5px);
}

.ps-bc__tag{
  font-size:10.5px;
  font-weight:820;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:7px;
}

.ps-bc__dot{
  width:5px;
  height:5px;
  border-radius:50%;
  background:currentColor;
  flex-shrink:0;
}

.ps-bc__h{
  font-size:clamp(20px,2.2vw,28px);
  font-weight:860;
  line-height:1.04;
  letter-spacing:-.025em;
  margin-bottom:12px;
}

.ps-bc__p{
  font-size:14.8px;
  line-height:1.62;
  font-weight:500;
}

.ps-bc__ui{
  margin-top:28px;
}

.ps-bc__cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13.5px;
  font-weight:760;
  margin-top:auto;
  padding-top:24px;
  border-bottom:1.5px solid;
  padding-bottom:2px;
  width:fit-content;
  transition:gap .3s var(--ps-spring), border-color .2s;
}

.ps-bc:hover .ps-bc__cta{
  gap:12px;
}
/* NAVY */

.ps-bc--navy{
  background:
  radial-gradient(550px 280px at 88% 8%,rgba(199,164,109,.14),transparent 56%),
  linear-gradient(168deg,#466781 0%,#345166 100%);

  grid-column:1;
  grid-row:1/3;
}

.ps-bc--navy:hover{
  box-shadow:0 28px 72px rgba(70,103,129,.30);
}

.ps-bc--navy .ps-bc__tag{color:rgba(199,164,109,.78);}
.ps-bc--navy .ps-bc__h{color:#fff;}
.ps-bc--navy .ps-bc__p{color:rgba(255,255,255,.52);}
.ps-bc--navy .ps-bc__cta{
  color:var(--ps-amber);
  border-bottom-color:rgba(199,164,109,.35);
}
.ps-bc--navy:hover .ps-bc__cta{
  border-bottom-color:var(--ps-amber);
}


/* CREAM */

.ps-bc--cream{
  background:var(--ps-bg);
  border-color:rgba(70,103,129,.05);
  grid-column:2;
  grid-row:1;
}

.ps-bc--cream:hover{
  box-shadow:0 22px 56px rgba(70,103,129,.10);
}

.ps-bc--cream .ps-bc__tag{color:var(--ps-blue);}
.ps-bc--cream .ps-bc__h{color:var(--ps-text);}
.ps-bc--cream .ps-bc__p{color:var(--ps-text-2);}
.ps-bc--cream .ps-bc__cta{
  color:var(--ps-blue);
  border-bottom-color:rgba(70,103,129,.22);
}
.ps-bc--cream:hover .ps-bc__cta{
  border-bottom-color:var(--ps-blue);
}


/* AMBER */

.ps-bc--amber{
  background:
  radial-gradient(380px 180px at 82% 0%,rgba(199,164,109,.16),transparent 55%),
  var(--ps-amber-pale);

  border-color:rgba(199,164,109,.06);
  grid-column:3;
  grid-row:1;
}

.ps-bc--amber:hover{
  box-shadow:0 22px 56px rgba(199,164,109,.14);
}

.ps-bc--amber .ps-bc__tag{color:var(--ps-amber-dark);}
.ps-bc--amber .ps-bc__h{color:var(--ps-text);}
.ps-bc--amber .ps-bc__p{color:rgba(70,103,129,.56);}
.ps-bc--amber .ps-bc__cta{
  color:var(--ps-blue);
  border-bottom-color:rgba(70,103,129,.22);
}
.ps-bc--amber:hover .ps-bc__cta{
  border-bottom-color:var(--ps-blue);
}


/* WHITE */

.ps-bc--white{
  background:#eef2ef;
  border-color:rgba(70,103,129,.06);

  grid-column:2/4;
  grid-row:2;
}

.ps-bc--white:hover{
  box-shadow:0 22px 56px rgba(70,103,129,.08);
}

.ps-bc--white .ps-bc__tag{color:var(--ps-green);}
.ps-bc--white .ps-bc__h{color:var(--ps-text);}
.ps-bc--white .ps-bc__p{color:var(--ps-text-2);}
.ps-bc--white .ps-bc__cta{
  color:var(--ps-text);
  border-bottom-color:rgba(26,42,53,.18);
}
.ps-bc--white:hover .ps-bc__cta{
  border-bottom-color:rgba(26,42,53,.38);
}


/* ═══════════════════════════════════════
   BENTO UI
   ═══════════════════════════════════════ */

.ps-bento__pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:12px;
}

.ps-bento__pill{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:11px;
  font-weight:700;
  padding:5px 10px;
  border-radius:100px;
  background:var(--ps-white);
  border:1px solid var(--ps-border-soft);
  color:var(--ps-text-2);
}

.ps-bento__pill i{
  font-size:11px;
}

.ps-bento__price{
  display:flex;
  align-items:baseline;
  gap:8px;
}

.ps-bento__price-val{
  font-size:20px;
  font-weight:880;
  color:var(--ps-text);
}

.ps-bento__price-note{
  font-size:11.5px;
  color:var(--ps-text-3);
}

.ps-bento__inline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.ps-bento__trust{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}

.ps-bento__trust span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:11.5px;
  font-weight:660;
  color:rgba(255,255,255,.56);
}

.ps-bento__trust i{
  color:var(--ps-green);
  font-size:12px;
}

.ps-bento__extras{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}

.ps-bento__extras span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:11.5px;
  font-weight:680;
  color:rgba(255,255,255,.48);
  padding:5px 12px;
  border-radius:100px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}

.ps-bento__extras i{
  font-size:12px;
  color:var(--ps-amber);
}

.ps-bc--amber .ps-bento__pill{
  background:rgba(255,255,255,.6);
  border-color:rgba(199,164,109,.12);
}

.ps-bc--white .ps-bento__pill{
  background:rgba(255,255,255,.7);
  border-color:rgba(70,103,129,.08);
}

/* mobile */

@media(max-width:640px){

  .ps-bento__inline{
    flex-direction:column;
    align-items:flex-start;
  }

  .ps-bento__price-val{
    font-size:17px;
  }

}
/* ═══════════════════════════════════════
   PS BENTO — RESPONSIVE
   ═══════════════════════════════════════ */

@media(max-width:1080px){
  .ps-bc{padding:28px;}
}

@media(max-width:980px){

  .ps-bento__grid{
    grid-template-columns:1fr 1fr;
  }

  .ps-bc--navy{
    grid-column:1/3;
    grid-row:auto;
  }

  .ps-bc--cream{
    grid-column:1;
    grid-row:auto;
  }

  .ps-bc--amber{
    grid-column:2;
    grid-row:auto;
  }

  .ps-bc--white{
    grid-column:1/3;
    grid-row:auto;
  }

}

@media(max-width:640px){

  .ps-bento__grid{
    grid-template-columns:1fr;
  }

  .ps-bc--navy,
  .ps-bc--cream,
  .ps-bc--amber,
  .ps-bc--white{
    grid-column:1;
  }

  .ps-bc{
    padding:24px;
    border-radius:var(--ps-radius-lg);
  }

}
/* ═══════════════════════════════════════
   MICRO-UI
   ═══════════════════════════════════════ */
/* progress */
.mu-progress {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px; padding: 18px 20px;
  display: flex; flex-direction: column; gap: 11px;
}
.mu-row { display: grid; grid-template-columns: 84px 1fr 38px; align-items: center; gap: 10px; }
.mu-row__n { font-size: 12px; font-weight: 700; color: rgba(255,255,255,.42); }
.mu-row__t { height: 5px; border-radius: 3px; background: rgba(255,255,255,.07); }
.mu-row__f { height: 100%; border-radius: 3px; }
.mu-row__f--ok { background: var(--ps-green); }
.mu-row__f--wip { background: var(--ps-amber); position: relative; }
.mu-row__f--wip::after {
  content: ''; position: absolute; right: -5px; top: 50%; transform: translateY(-50%);
  width: 9px; height: 9px; background: var(--ps-blue-deep); border: 2px solid var(--ps-amber); border-radius: 50%;
}
.mu-row__f--no { background: rgba(255,255,255,.04); width: 8%!important; }
.mu-row__v { font-size: 10.5px; font-weight: 800; text-align: right; }
.mu-row__v--ok { color: var(--ps-green); }
.mu-row__v--wip { color: var(--ps-amber); }
.mu-row__v--no { color: rgba(255,255,255,.16); }

.mu-stats { display: flex; gap: 28px; margin-top: 22px; }
.mu-stat__num { font-size: 30px; font-weight: 900; letter-spacing: -.03em; color: var(--ps-amber); }
.mu-stat__lbl { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.34); margin-top: 2px; }

/* files */
.mu-files { display: flex; flex-direction: column; gap: 7px; }
.mu-file {
  background: var(--ps-white); border: 1px solid rgba(70,103,129,.05);
  border-radius: 12px; padding: 11px 14px;
  display: flex; align-items: center; gap: 10px;
  transition: border-color .2s;
}
.ps-bc:hover .mu-file { border-color: rgba(70,103,129,.1); }
.mu-file__ico {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; flex-shrink: 0;
}
.mu-file__ico--a { background: var(--ps-amber-soft); }
.mu-file__ico--b { background: var(--ps-blue-wash); }
.mu-file__meta { flex: 1; min-width: 0; }
.mu-file__name { font-size: 12.5px; font-weight: 700; color: var(--ps-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mu-file__size { font-size: 10.5px; color: var(--ps-text-3); font-weight: 400; }
.mu-file__lock { font-size: 10px; color: var(--ps-amber); }
.mu-file--add {
  border-style: dashed!important; border-color: rgba(70,103,129,.10)!important;
  background: transparent!important; justify-content: center;
  color: var(--ps-text-3); font-size: 18px; height: 38px; cursor: pointer;
  transition: border-color .2s, color .2s;
}
.ps-bc:hover .mu-file--add { border-color: rgba(70,103,129,.18)!important; color: var(--ps-blue); }

/* calendar */
.mu-cal { border-radius: 14px; overflow: hidden; border: 1px solid rgba(199,164,109,.10); }
.mu-cal__hd {
  background: linear-gradient(135deg, var(--ps-blue), var(--ps-blue-deep));
  padding: 10px 14px; display: flex; align-items: center; justify-content: space-between;
}
.mu-cal__mo { font-size: 11.5px; font-weight: 800; color: rgba(255,255,255,.86); letter-spacing: .04em; }
.mu-cal__nav { display: flex; gap: 4px; }
.mu-cal__nav button {
  background: rgba(255,255,255,.1); border: none; color: white;
  width: 22px; height: 22px; border-radius: 6px; font-size: 11px; cursor: pointer;
  transition: background .15s;
}
.mu-cal__nav button:hover { background: rgba(255,255,255,.18); }
.mu-cal__body { background: white; padding: 10px; }
.mu-cal__days { display: grid; grid-template-columns: repeat(7,1fr); gap: 2px; margin-bottom: 8px; }
.mu-cal__d {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  font-size: 10.5px; font-weight: 500; border-radius: 6px; color: #999;
}
.mu-cal__d--hd { font-weight: 800; color: var(--ps-text); font-size: 9px; }
.mu-cal__d--sel { background: var(--ps-blue); color: white; font-weight: 700; }
.mu-cal__d--ring { border: 2px solid var(--ps-amber); color: var(--ps-amber); font-weight: 700; }
.mu-cal__d--dim { opacity: .2; }
.mu-cal__slot {
  background: var(--ps-amber-pale); border-radius: 10px;
  padding: 9px 12px; display: flex; align-items: center; gap: 10px;
  border-left: 3px solid var(--ps-amber);
}
.mu-cal__time { font-size: 12px; font-weight: 800; color: var(--ps-amber-dark); flex-shrink: 0; }
.mu-cal__who { font-size: 12px; font-weight: 700; color: var(--ps-text); }
.mu-cal__type { font-size: 10.5px; color: var(--ps-text-3); }

/* capsule */
.mu-capsule {
  background: var(--ps-bg); border: 1px solid rgba(70,103,129,.04);
  border-radius: 16px; padding: 18px;
  display: flex; gap: 14px; align-items: flex-start;
  transition: border-color .2s;
}
.ps-bc:hover .mu-capsule { border-color: rgba(70,103,129,.1); }
.mu-capsule__ico {
  width: 38px; height: 38px; background: var(--ps-amber-pale);
  border: 1px solid rgba(199,164,109,.14); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.mu-capsule__meta {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; gap: 8px; flex-wrap: wrap;
}
.mu-capsule__to { font-size: 13px; font-weight: 800; color: var(--ps-text); }
.mu-capsule__date {
  font-size: 10.5px; font-weight: 800;
  background: white; color: var(--ps-amber-dark);
  padding: 4px 10px; border-radius: 100px;
  border: 1px solid rgba(199,164,109,.14);
}
.mu-capsule__q {
  font-style: italic; font-size: 13.5px; line-height: 1.55; color: var(--ps-text-3);
  margin: 0;
}
.mu-capsule__badge {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 10px; font-size: 11px; font-weight: 800;
  color: var(--ps-green); background: var(--ps-green-soft);
  padding: 4px 10px; border-radius: 100px;
}
.mu-capsule__badge i { font-size: 9px; }

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width: 1080px) {
  .hero__inner { gap: 36px; }
  .bc { padding: 28px; }
}

@media(max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; gap: 32px; }
  .hero__visual { order: 1; }
  .hero__content { text-align: center; }
  .hero__lead { margin-left: auto; margin-right: auto; }
  .hero__actions { justify-content: center; }
  .hero__trust { justify-content: center; }
  .hero__hint { display: none; }

  /* Format A — photo */
  .va__floater { display: none; }
  .va__frame { max-height: 360px; min-height: 280px; }

  /* Format B — dashboard */
  .vb__wrap { transform: none; }
  .vb__sidebar { display: none; }
  .vb__stats { display: none; }
  .vb__mobile-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: linear-gradient(135deg, var(--ps-blue), var(--ps-blue-deep));
    color: #fff;
  }
  .vb__mobile-header i { font-size: 15px; opacity: .8; }
  .vb__mobile-header strong {
    font-size: 12px; font-weight: 800;
    letter-spacing: .06em; text-transform: uppercase;
  }
  .vb__mobile-header .vb__mobile-badge {
    margin-left: auto;
    font-size: 10px; font-weight: 800;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.14);
    padding: 3px 10px; border-radius: 100px;
  }

}

@media(max-width: 640px) {
  .hero__h1 { font-size: clamp(30px, 9vw, 48px); }
  .hero__lead { font-size: 16px; }
  .hero__actions { flex-direction: column; width: 100%; }
  .btn { width: 100%; justify-content: center; }
  .btn--ghost { width: auto; }
  .hero__trust { gap: 12px; }

  .hero__frame { border-radius: 20px; }
  .hero__frame::after { inset: 4px; border-radius: 17px; }

  /* Format A — compact */
  .va__frame { max-height: 320px; min-height: 240px; }
  .va__card { padding: 10px 12px; bottom: 8px; left: 8px; right: 8px; border-radius: 12px; }
  .va__card-head { gap: 8px; margin-bottom: 6px; }
  .va__card-ico { width: 30px; height: 30px; font-size: 12px; border-radius: 9px; }
  .va__card-title { font-size: 12px; }
  .va__card-sub { font-size: 9.5px; }
  .va__card-pct { font-size: 10px; padding: 3px 8px; }
  .va__tags { gap: 3px; }
  .va__tag { font-size: 8.5px; padding: 3px 6px; }

  /* Format B — compact */
  .vb__row { padding: 8px 10px; gap: 8px; margin-bottom: 4px; }
  .vb__row-ico { width: 28px; height: 28px; font-size: 10px; }
  .vb__row-name { font-size: 12px; }
  .vb__row-status { font-size: 9.5px; }
  .vb__content { padding: 12px; }
  .vb__chrome { padding: 7px 10px; }
  .vb__dot { width: 7px; height: 7px; }

  .mu-stats { gap: 20px; }
  .mu-stat__num { font-size: 26px; }
  .mu-row { grid-template-columns: 68px 1fr 34px; }
}
/* ═══════════════════════════════════════
   TRUST / SÉCURITÉ
   ═══════════════════════════════════════ */
.trust {
  background:
    radial-gradient(700px 320px at 14% 16%, rgba(199,164,109,.14), transparent 56%),
    radial-gradient(700px 320px at 88% 8%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(168deg, #466781 0%, #345166 100%);
  color: #fff;
}
.trust::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}

.trust__header { text-align: center; margin-bottom: 32px; }

.trust__ey {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11.5px; font-weight: 800;
  letter-spacing: .16em; text-transform: uppercase;
  color: rgba(255,255,255,.88);
  padding: 7px 16px; border-radius: 100px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  margin-bottom: 20px;
}

.trust__title {
  font-size: clamp(26px, 3.4vw, 44px);
  font-weight: 900; color: #fff;
  line-height: 1.04; letter-spacing: -.035em;
  margin-bottom: 18px;
}
.trust__title span { color: var(--ps-amber); }

.trust__sub {
  font-size: 17px; color: rgba(255,255,255,.62);
  max-width: 520px; margin: 0 auto; line-height: 1.6; font-weight: 400;
}

.trust__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap);
  margin-bottom: 40px;
}

.trust__card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--ps-radius-lg);
  padding: 34px 28px;
  position: relative;
  transition: transform .3s var(--ps-ease), background .3s, border-color .3s, box-shadow .3s;
}
.trust__card:hover {
  transform: translateY(-5px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 20px 56px rgba(0,0,0,.18);
}

.trust__icon {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.10);
  font-size: 20px; color: rgba(255,255,255,.8);
}
.trust__icon--amber {
  background: rgba(199,164,109,.14); border-color: rgba(199,164,109,.22);
  color: var(--ps-amber);
}
.trust__card-top {
  display: flex; align-items: flex-start; gap: 12px;
  margin-bottom: 14px;
}
.trust__badge {
  display: inline-block; font-size: 11px; font-weight: 800;
  letter-spacing: .06em; padding: 5px 12px; border-radius: 8px;
  background: rgba(0,0,0,.18); border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.78); margin-bottom: 0px; margin-left: 10px;
  font-family: 'Inter', monospace, sans-serif; font-variant-numeric: tabular-nums;
}
.trust__badge--amber { color: var(--ps-amber); border-color: rgba(199,164,109,.22); }

.trust__card-h {
  font-size: clamp(20px, 2vw, 24px); font-weight: 900; color: #fff;
  line-height: 1.08; letter-spacing: -.02em; margin-bottom: 12px; margin-top: 4px;
}

.trust__card-p {
  font-size: 14.8px; line-height: 1.62;
  color: rgba(255,255,255,.52); font-weight: 400; margin: 0;
}

.trust__footer {
  background: rgba(0,0,0,.14); border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--ps-radius-lg); padding: 28px 34px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}

.trust__footer-txt h4 {
  font-size: 18px; font-weight: 800; color: #fff;
  margin: 0 0 6px 0; letter-spacing: -.01em;
}
.trust__footer-txt p {
  font-size: 14.5px; color: rgba(255,255,255,.56);
  margin: 0; font-weight: 400;
}

.trust__footer-actions { display: flex; gap: 12px; flex-shrink: 0; }

@media(max-width: 980px) {
  .trust__grid { grid-template-columns: 1fr 1fr; }
  .trust__grid .trust__card:last-child { grid-column: 1/3; }
  .trust__footer { flex-direction: column; text-align: center; padding: 24px; }
  .trust__footer-actions { width: 100%; justify-content: center; }
}

@media(max-width: 640px) {
  .trust__grid { grid-template-columns: 1fr; }
  .trust__grid .trust__card:last-child { grid-column: 1; }
  .trust__card { padding: 26px 22px; }
  .trust__footer-actions { flex-direction: column; }
  .trust__footer-actions .btn { width: 100%; }
}

/* ═══════════════════════════════════════
   TRANSMISSION / PERSONNE DE CONFIANCE
   ═══════════════════════════════════════ */
.transmit {
  background: var(--ps-bg);
}
.transmit::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(70,103,129,.07), transparent);
}

.transmit__inner {
  display: grid; grid-template-columns: 1.15fr .85fr;
  gap: 40px; align-items: center;
}

.transmit__ey {
  font-size: 11.5px; font-weight: 800;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--ps-amber); display: block; margin-bottom: 16px;
}

.transmit__title {
  font-size: clamp(26px, 3.4vw, 44px); font-weight: 900; color: var(--ps-text);
  line-height: 1.04; letter-spacing: -.035em; margin-bottom: 18px;
}
.transmit__title span { color: var(--ps-blue); }

.transmit__lead {
  font-size: 16px; color: var(--ps-text-2);
  line-height: 1.62; font-weight: 400; max-width: 580px; margin-bottom: 28px;
}

.transmit__rules { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.transmit__rule { display: flex; align-items: flex-start; gap: 14px; }
.transmit__rule-ico {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.transmit__rule-ico--green { background: var(--ps-green-soft); color: var(--ps-green); }
.transmit__rule-ico--amber { background: var(--ps-amber-soft); color: var(--ps-amber-dark); }
.transmit__rule-ico--blue { background: var(--ps-blue-wash); color: var(--ps-blue); }

.transmit__rule strong { display: block; font-size: 14.5px; font-weight: 800; color: var(--ps-text); margin-bottom: 2px; }
.transmit__rule span { font-size: 13.8px; color: var(--ps-text-2); line-height: 1.5; font-weight: 400; }

.transmit__link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 700; color: var(--ps-blue);
  border-bottom: 1.5px solid rgba(70,103,129,.18); padding-bottom: 2px;
  transition: border-color .2s, gap .25s var(--ps-spring);
}
.transmit__link:hover { border-color: var(--ps-amber); gap: 10px; }

.transmit__card{
  position:relative;
  display:block;
  text-decoration:none;
  color:inherit;
}
.transmit__card:hover .transmit__card-inner{
  transform:translateY(-3px);
  box-shadow:0 16px 44px rgba(70,103,129,.08);
  border-color:rgba(70,103,129,.10);
}

.transmit__card-inner{
  border-radius:var(--ps-radius-lg);
  padding:36px 30px;
  border:1px solid rgba(70,103,129,.08);

  background:
    radial-gradient(400px 200px at 80% 0%, rgba(70,103,129,.06), transparent 55%),
    var(--ps-white);

  box-shadow:0 20px 56px rgba(70,103,129,.08);
  text-align:center;

  transition:
    transform .3s var(--ps-ease),
    box-shadow .3s,
    border-color .3s;
}

.transmit__card-badge {
  display: inline-block; font-size: 11px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase; color: var(--ps-blue);
  background: var(--ps-blue-wash); padding: 6px 14px; border-radius: 100px; margin-bottom: 22px;
}

.transmit__card-ava {
  width: 60px; height: 60px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ps-blue), var(--ps-blue-deep));
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; font-size: 24px; color: #fff;
  box-shadow: 0 8px 28px rgba(70,103,129,.22);
}

.transmit__card-h {
  font-size: 20px; font-weight: 900; color: var(--ps-text);
  line-height: 1.12; letter-spacing: -.02em; margin-bottom: 12px;
}
.transmit__card-p {
  font-size: 14px; line-height: 1.6; color: var(--ps-text-2);
  font-weight: 400; margin-bottom: 20px;
}

.transmit__perms { display: flex; flex-direction: column; gap: 8px; text-align: left; }
.transmit__perm { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--ps-text); }
.transmit__perm i {
  font-size: 11px; color: var(--ps-green);
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--ps-green-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

@media(max-width: 980px) {
  .transmit__inner { grid-template-columns: 1fr; gap: 32px; }
  .transmit__text { text-align: center; }
  .transmit__lead { margin-left: auto; margin-right: auto; }
  .transmit__rules { 
    align-items: stretch;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
  }
  .transmit__link { justify-content: center; }
}

@media(max-width: 640px) {
  .transmit__rule { text-align: left; }
  .transmit__card-inner { padding: 28px 22px; }
}

/* ═══════════════════════════════════════
   OFFRES — TEASER
   ═══════════════════════════════════════ */
.offers {
  background:
    radial-gradient(700px 300px at 10% 16%, rgba(199,164,109,.10), transparent 55%),
    radial-gradient(700px 300px at 92% 8%, rgba(70,103,129,.06), transparent 55%),
    var(--ps-bg);
}
.offers::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(70,103,129,.07), transparent);
}

.offers__header { text-align: center; margin-bottom: 32px; }
.offers__ey {
  font-size: 11.5px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase;
  color: var(--ps-amber); display: block; margin-bottom: 16px;
}
.offers__title {
  font-size: clamp(26px, 3.4vw, 44px); font-weight: 900; color: var(--ps-text);
  line-height: 1.06; letter-spacing: -.035em; margin-bottom: 16px;
}
.offers__title em { font-style: normal; color: var(--ps-blue); }
.offers__sub {
  font-size: 16px; color: var(--ps-text-2); max-width: 500px; margin: 0 auto;
  line-height: 1.62; font-weight: 400;
}

.offers__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap); margin-bottom: 40px;
}

.offers__pill {
  display: flex; align-items: flex-start; gap: 14px; padding: 24px 22px;
  border-radius: var(--ps-radius-md); border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-white); box-shadow: 0 8px 28px rgba(0,0,0,.04);
  transition: transform .3s var(--ps-ease), box-shadow .3s, border-color .3s;
}
.offers__pill:hover {
  transform: translateY(-3px); box-shadow: 0 16px 44px rgba(70,103,129,.08);
  border-color: rgba(70,103,129,.10);
}

.offers__pill-ico {
  width: 40px; height: 40px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0; background: var(--ps-green-soft); color: var(--ps-green);
}
.offers__pill-ico--amber { background: var(--ps-amber-soft); color: var(--ps-amber-dark); }
.offers__pill-ico--blue { background: var(--ps-blue-wash); color: var(--ps-blue); }

.offers__pill strong { display: block; font-size: 15px; font-weight: 800; color: var(--ps-text); margin-bottom: 4px; }
.offers__pill span { font-size: 13.8px; color: var(--ps-text-2); line-height: 1.5; font-weight: 400; }

.offers__foot { text-align: center; }



@media(max-width: 980px) {
  .offers__grid { grid-template-columns: 1fr 1fr; }
  .offers__grid .offers__pill:last-child { grid-column: 1/3; }
}

@media(max-width: 640px) {
  .offers__grid { grid-template-columns: 1fr; }
  .offers__grid .offers__pill:last-child { grid-column: 1; }
  .offers__pill { padding: 20px 18px; }
}

/* ═══════════════════════════════════════
   CTA FINAL
   ═══════════════════════════════════════ */
.ctafinal {
  background:
    radial-gradient(700px 320px at 14% 18%, rgba(199,164,109,.14), transparent 56%),
    radial-gradient(700px 320px at 88% 8%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(168deg, #466781 0%, #345166 100%);
}

.ctafinal__box { text-align: center; max-width: 620px; margin: 0 auto; }

.ctafinal__h {
  font-size: clamp(26px, 3.4vw, 44px); font-weight: 900; color: #fff;
  line-height: 1.04; letter-spacing: -.04em; margin-bottom: 16px;
}
.ctafinal__h span { color: var(--ps-amber); }

.ctafinal__p {
  font-size: 17px; color: rgba(255,255,255,.56);
  font-weight: 400; line-height: 1.6; margin-bottom: 32px;
}

.ctafinal__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.btn--lg { padding: 16px 34px; font-size: 15px; }

.btn--amber {
  background: var(--ps-amber); color: var(--ps-blue-deep)!important;
  box-shadow: 0 8px 28px rgba(199,164,109,.30);
}
.btn--amber:hover {
  background: #d4b27a; transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(199,164,109,.38);
}

.btn--glass {
  background: rgba(255,255,255,.06); color: rgba(255,255,255,.9)!important;
  border: 1px solid rgba(255,255,255,.18);
}
.btn--glass:hover {
  background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.32); transform: translateY(-2px);
}

@media(max-width: 640px) {
  .ctafinal__actions { flex-direction: column; }
  .ctafinal__actions .btn { width: 100%; }
}

/* ── STATS CHIFFRÉES ── */

.ps-stats{
  background:
    radial-gradient(700px 320px at 14% 16%, rgba(199,164,109,.14), transparent 56%),
    radial-gradient(700px 320px at 88% 8%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(168deg,#466781 0%,#345166 100%);
  color:#fff;
  position:relative;
}

.ps-stats::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
}

.ps-stats__header{
  text-align:center;
  margin-bottom:52px;
}

.ps-stats__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--grid-gap);
}

.ps-stats__item{
  text-align:center;
  padding:32px 20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--ps-radius-lg);
  transition:transform .3s var(--ps-ease), background .3s, border-color .3s;
}

.ps-stats__item:hover{
  transform:translateY(-4px);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.16);
}

.ps-stats__num{
  font-size:clamp(36px,4.5vw,56px);
  font-weight:900;
  letter-spacing:-.04em;
  line-height:1;
  color:var(--ps-amber);
  margin-bottom:12px;
}

.ps-stats__label{
  font-size:14px;
  line-height:1.45;
  color:rgba(255,255,255,.56);
  font-weight:450;
  margin:0;
}

/* source */

.ps-stats__src{
  display:block;
  margin-top:10px;
  font-size:11px;
  font-weight:620;
  color:rgba(255,255,255,.30);
  letter-spacing:.02em;
}

/* responsive */

@media(max-width:980px){
  .ps-stats__grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:640px){

  .ps-stats__grid{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .ps-stats__item{
    padding:24px 16px;
  }

  .ps-stats__num{
    font-size:clamp(30px,10vw,44px);
  }

  .ps-stats__label{
    font-size:12.5px;
  }

}

/* ── TÉMOIGNAGES ── */

.ps-testi-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--grid-gap);
}

.ps-testi{
  background:var(--ps-bg);
  border:1px solid var(--ps-border-soft);
  border-radius:var(--ps-radius-lg);
  padding:28px;
  display:flex;
  flex-direction:column;
}

.ps-testi__type{
  font-size:10.5px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ps-amber-dark);
  margin-bottom:14px;
}

.ps-testi__q{
  font-size:15px;
  line-height:1.65;
  color:var(--ps-text);
  font-weight:500;
  font-style:italic;
  margin:0 0 auto;
  padding-bottom:18px;
}

.ps-testi__sig{
  display:flex;
  align-items:center;
  gap:10px;
  padding-top:16px;
  border-top:1px solid var(--ps-border-soft);
}

.ps-testi__ava{
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--ps-blue-wash),var(--ps-amber-pale));
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:800;
  color:var(--ps-blue);
  flex-shrink:0;
}

.ps-testi__sig strong{
  display:block;
  font-size:13px;
  font-weight:740;
  color:var(--ps-text);
}

.ps-testi__sig span{
  font-size:11.5px;
  color:var(--ps-text-3);
}

.ps-testi__type i{
  margin-right:4px;
  font-size:11px;
  position:relative;
  top:-1px;
}

/* responsive */

@media(max-width:980px){

  .ps-testi-grid{
    grid-template-columns:1fr 1fr;
  }

  .ps-testi-grid .ps-testi:last-child{
    grid-column:1/3;
  }

}

@media(max-width:640px){

  .ps-testi-grid{
    grid-template-columns:1fr;
  }

  .ps-testi-grid .ps-testi:last-child{
    grid-column:1;
  }

}
/* ═══════════════════════════════════════
   TÉMOIGNAGES SUR FOND BLEU
   ═══════════════════════════════════════ */
.ps-testi-blue {
  background:
    radial-gradient(700px 320px at 14% 16%, rgba(199,164,109,.14), transparent 56%),
    radial-gradient(700px 320px at 88% 8%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(168deg, #466781 0%, #345166 100%);
  color: #fff;
  position: relative;
}

.ps-testi-blue::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}

.ps-testi-blue .ps-sec__ey {
  color: rgba(255,255,255,.88);
}

.ps-testi-blue .ps-sec__title {
  color: #fff;
}

.ps-testi-blue .ps-sec__title em {
  color: var(--ps-amber);
}

.ps-testi--onblue {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}

.ps-testi--onblue:hover {
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.18);
}

.ps-testi--onblue .ps-testi__type {
  color: var(--ps-amber);
}

.ps-testi--onblue .ps-testi__q {
  color: rgba(255,255,255,.82);
}

.ps-testi--onblue .ps-testi__sig {
  border-top-color: rgba(255,255,255,.10);
}

.ps-testi--onblue .ps-testi__sig strong {
  color: #fff;
}

.ps-testi--onblue .ps-testi__sig span {
  color: rgba(255,255,255,.48);
}

.ps-testi--onblue .ps-testi__ava {
  background: linear-gradient(135deg, rgba(255,255,255,.10), rgba(199,164,109,.14));
  color: rgba(255,255,255,.82);
}
/* ═══════════════════════════════════════
   BRIDGE MODULES — Bandeau navy (refonte)
   ═══════════════════════════════════════ */

.ps-bridge{
  padding: 48px 0;
  background:
    radial-gradient(700px 280px at 14% 20%, rgba(199,164,109,.12), transparent 55%),
    radial-gradient(700px 280px at 88% 10%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(168deg, #466781 0%, #345166 100%);
  border-top: none;
  position: relative;
}

.ps-bridge::before{
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}

.ps-bridge__intro{
  text-align: center;
  font-size: 17px;
  font-weight: 600;
  color: rgba(255,255,255,.56);
  margin: 0 0 28px;
  max-width: 580px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.6;
}

.ps-bridge__grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.ps-bridge__card{
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 22px;
  border-radius: var(--ps-radius-lg, 22px);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  text-decoration: none !important;
  transition: transform .28s var(--ps-ease, ease), box-shadow .28s, border-color .28s, background .28s;
}

.ps-bridge__card:hover{
  transform: translateY(-4px);
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 16px 44px rgba(0,0,0,.18);
}

.ps-bridge__card i{
  font-size: 22px;
  color: var(--ps-amber, #C7A46D);
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  transition: background .28s, border-color .28s;
}

.ps-bridge__card:hover i{
  background: rgba(199,164,109,.14);
  border-color: rgba(199,164,109,.22);
}

.ps-bridge__card h3{
  font-size: clamp(14px, 1.4vw, 16px);
  font-weight: 800;
  color: #fff;
  display: block;
  margin: 0 0 0px 0;
  padding-bottom: 4px!important;
  line-height: 1.2;
}

.ps-bridge__card span{
  font-size: 12.8px;
  color: rgba(255,255,255,.52);
  font-weight: 400;
  line-height: 1.4;
}

/* ─────────────────────────────────────
   RESPONSIVE
   ───────────────────────────────────── */

@media (max-width: 980px){
  .ps-bridge{
    padding: 40px 0;
  }
  
  .ps-bridge__intro{
    margin-bottom: 24px;
    font-size: 15px;
  }
  
  .ps-bridge__grid{
    grid-template-columns: 1fr; /* ← 1 colonne tablette */
    gap: 12px;
  }
  
  .ps-bridge__card{
    padding: 18px 20px;
  }
}

@media (max-width: 640px){
  .ps-bridge{
    padding: 36px 0;
  }
  
  .ps-bridge__intro{
    margin-bottom: 22px;
  }
  
  .ps-bridge__card{
    padding: 16px 18px;
  }
  
  .ps-bridge__card i{
    width: 40px;
    height: 40px;
    font-size: 20px;
  }
}
/* ═══════════════════════════════════════
   PS HÉRITAGE — CSS SCOPÉ (.ph-)
   Composants neufs + overrides spécifiques
   À ajouter dans refonte.css
   ═══════════════════════════════════════ */


/* ─────────────────────────────────────
   HERO : Letter card (remplace le frame photo)
   ───────────────────────────────────── */
.ph-letter {
  position: relative;
  border-radius: var(--ps-radius-xl, 28px);
  padding: 32px 28px 26px;
  border: 1px solid rgba(70,103,129,.10);
  background:
    radial-gradient(700px 280px at 18% 0%, rgba(199,164,109,.16), transparent 55%),
    radial-gradient(700px 280px at 92% 6%, rgba(70,103,129,.08), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.995), rgba(248,249,251,.94));
  box-shadow:
    0 28px 72px rgba(70,103,129,.12),
    0 0 0 1px rgba(70,103,129,.04);
  animation: up .65s var(--ps-ease, ease) .14s both;
}

.ph-letter__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}

.ph-letter__badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 800;
  background: var(--ps-amber-soft, rgba(199,164,109,.14));
  border: 1px solid rgba(199,164,109,.18);
  color: var(--ps-amber-dark, #6b5a33);
}

.ph-letter__badge i { font-size: 12px; }

.ph-letter__date {
  font-size: 12px;
  font-weight: 700;
  color: var(--ps-text-3, rgba(26,42,53,.48));
}

.ph-letter__title {
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 900;
  color: var(--ps-text, #1a2a35);
  letter-spacing: -.02em;
  margin: 0 0 14px;
  line-height: 1.1;
}

.ph-letter__body {
  font-size: 15px;
  line-height: 1.72;
  color: var(--ps-text-2, rgba(26,42,53,.62));
  font-weight: 400;
  font-style: italic;
  margin: 0 0 18px;
  max-width: 440px;
}

.ph-letter__sig {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 900;
  font-size: 15px;
  color: var(--ps-text, #1a2a35);
  margin-bottom: 16px;
}

.ph-letter__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--ps-amber, #C7A46D);
}

.ph-letter__meta {
  display: flex;
  gap: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(70,103,129,.06);
}

.ph-letter__meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--ps-text-3, rgba(26,42,53,.48));
}

.ph-letter__meta i { font-size: 12px; }

@media (max-width: 640px) {
  .ph-letter { padding: 24px 20px 20px; }
  .ph-letter__body { font-size: 14px; }
}


/* ─────────────────────────────────────
   OUTILS : Section showcase (structure propre)
   ───────────────────────────────────── */
.ps-outils {
  background: var(--ps-white, #fff);
  position: relative;
  overflow: hidden;
}

.ps-outils::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(70,103,129,.07), transparent);
}

.ps-outils__header {
  text-align: center;
  margin-bottom: 32px;
}

/* Featured (messages posthumes) */
.ps-outils__featured {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 36px;
  align-items: center;
  padding: 32px 32px;
  border-radius: var(--ps-radius-xl, 28px);
  border: 1px solid rgba(70,103,129,.08);
  background:
    radial-gradient(600px 280px at 88% 8%, rgba(199,164,109,.10), transparent 56%),
    linear-gradient(168deg, #466781 0%, #345166 100%);
  box-shadow: 0 28px 72px rgba(70,103,129,.18);
  margin-bottom: 20px;
  color: #fff;
}

.ps-outils__num {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  color: rgba(199,164,109,.7);
  margin-bottom: 12px;
}

.ps-outils__featured-txt h3 {
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 900;
  line-height: 1.06;
  letter-spacing: -.03em;
  margin: 0 0 14px;
  color: #fff;
}

.ps-outils__featured-txt p {
  font-size: 15px;
  line-height: 1.62;
  color: rgba(255,255,255,.58);
  font-weight: 400;
  margin: 0 0 18px;
  max-width: 420px;
}

.ps-outils__tags {
  list-style: none;
  padding: 0!important;
  margin: 0 0 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ps-outils__tags li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 700;
  color: rgba(255,255,255,.56);
  padding: 5px 12px;
  border-radius: 100px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}

.ps-outils__tags li i { font-size: 13px; color: var(--ps-amber, #C7A46D); }

.ps-outils__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 800;
  color: var(--ps-amber);
  text-decoration: none;
  border-bottom: 1.5px solid rgba(199,164,109,.35); /* ← ajout */
  padding-bottom: 2px; /* ← ajout */
  width: fit-content; /* ← ajout */
  transition: gap .25s, border-color .2s; /* ← modif */
}

.ps-outils__link:hover { 
  gap: 12px;
  border-bottom-color: var(--ps-amber); /* ← ajout */
}

/* Mini-UI messages */
.ps-outils__msgPreview {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  margin-bottom: 10px;
  transition: background .2s;
}

.ps-outils__featured:hover .ps-outils__msgPreview {
  background: rgba(255,255,255,.08);
}

.ps-outils__msgIcon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 15px;
  color: #fff;
  flex-shrink: 0;
}

.ps-outils__msgIcon--amber {
  background: rgba(199,164,109,.16);
  border-color: rgba(199,164,109,.22);
  color: var(--ps-amber, #C7A46D);
}

.ps-outils__msgPreview strong {
  display: block;
  font-size: 13.5px;
  font-weight: 800;
  color: #fff;
}

.ps-outils__msgPreview span {
  font-size: 11.5px;
  color: rgba(255,255,255,.46);
  font-weight: 400;
}

.ps-outils__msgStatus {
  margin-left: auto;
  font-size: 12px;
  font-weight: 800;
  color: var(--ps-green, #4caf50);
}

.ps-outils__msgStatus--wip { color: var(--ps-amber, #C7A46D); }

/* Grid 2×2 */
.ps-outils__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--grid-gap, 14px);
}

.ps-outils__card {
  display: flex;
  flex-direction: column;
  padding: 28px 24px;
  border-radius: var(--ps-radius-lg, 22px);
  border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-bg, #FAF6F2);
  text-decoration: none !important;
  transition: transform .28s var(--ps-ease, ease), box-shadow .28s, border-color .28s;
}

.ps-outils__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(70,103,129,.10);
  border-color: rgba(70,103,129,.12);
}

.ps-outils__cardNum {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  color: var(--ps-text-3, rgba(26,42,53,.36));
  margin-bottom: 14px;
}

.ps-outils__cardIcon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  background: var(--ps-blue-wash, rgba(70,103,129,.08));
  color: var(--ps-blue, #466781);
  border: 1px solid rgba(70,103,129,.10);
  margin-bottom: 16px;
}

.ps-outils__cardIcon--amber {
  background: var(--ps-amber-soft, rgba(199,164,109,.14));
  border-color: rgba(199,164,109,.18);
  color: var(--ps-amber-dark, #6b5a33);
}

.ps-outils__card h3 {
  font-size: 16px;
  font-weight: 800;
  color: var(--ps-text, #1a2a35);
  margin: 0 0 8px;
  line-height: 1.15;
}

.ps-outils__card p {
  font-size: 13.8px;
  line-height: 1.55;
  color: var(--ps-text-2, rgba(26,42,53,.56));
  font-weight: 500;
  margin: 0;
  flex: 1;
}

.ps-outils__cardLink {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 18px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ps-blue);
  border-bottom: 1.5px solid rgba(70,103,129,.18);
  padding-bottom: 2px;
  width: fit-content;
  transition: gap .25s, border-color .2s;
}

.ps-outils__card:hover .ps-outils__cardLink { 
  gap: 10px;
  border-bottom-color: var(--ps-blue);
}

@media (max-width: 980px) {
  .ps-outils__featured { grid-template-columns: 1fr; gap: 24px; padding: 28px 24px; }
  .ps-outils__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .ps-outils__featured { padding: 22px 18px; }
  .ps-outils__grid { grid-template-columns: 1fr; }
  .ps-outils__card { padding: 22px 20px; }
}



/* Responsive pour TOUS les .ps-outils__grid */
@media (max-width: 980px) {
  .ps-outils__grid { 
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 640px) {
  .ps-outils__grid { 
    grid-template-columns: 1fr !important;
  }
  .ps-outils__card { 
    padding: 22px 18px; 
  }
}
/* ─────────────────────────────────────
   FAQ : section background
   ───────────────────────────────────── */
.ps-faq-section {
  background: var(--ps-white, #fff);
  position: relative;
}


/* ─────────────────────────────────────
   RESSOURCES : grid 3×2
   ───────────────────────────────────── */
.ps-resources {
  background:
    radial-gradient(700px 300px at 10% 16%, rgba(199,164,109,.08), transparent 55%),
    radial-gradient(700px 300px at 92% 8%, rgba(70,103,129,.04), transparent 55%),
    var(--ps-bg, #FAF6F2);
  position: relative;
  overflow: hidden;
}

.ps-resources::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(70,103,129,.07), transparent);
}

.ps-resources__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap, 14px);
}

.ps-resources__card {
  display: flex;
  flex-direction: column;
  padding: 26px 22px;
  border-radius: var(--ps-radius-lg, 22px);
  border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-white, #fff);
  text-decoration: none !important;
  transition: transform .3s var(--ps-ease, ease), box-shadow .3s, border-color .3s;
}

.ps-resources__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(70,103,129,.10);
  border-color: rgba(70,103,129,.12);
}

.ps-resources__icon {
  width: 42px; height: 42px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  margin-bottom: 16px;
  background: var(--ps-blue-wash, rgba(70,103,129,.08));
  color: var(--ps-blue, #466781);
  border: 1px solid rgba(70,103,129,.10);
}

.ps-resources__card h3 {
  font-size: 15.5px;
  font-weight: 800;
  color: var(--ps-text, #1a2a35);
  margin: 0 0 8px;
  line-height: 1.2;
}

.ps-resources__card p {
  font-size: 13.8px;
  line-height: 1.55;
  color: var(--ps-text-2, rgba(26,42,53,.56));
  font-weight: 400;
  margin: 0;
  flex: 1;
}

.ps-resources__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 16px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ps-blue, #466781);
  transition: gap .25s;
}

.ps-resources__card:hover .ps-resources__link { gap: 10px; }

@media (max-width: 980px) {
  .ps-resources__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .ps-resources__grid { grid-template-columns: 1fr; }
  .ps-resources__card { padding: 22px 18px; }
}


/* ═══════════════════════════════════════
   PS NOTAIRE — CSS SCOPÉ (.pn-)
   Uniquement les composants qui n'existent
   PAS dans refonte.css
   ═══════════════════════════════════════ */

/* ─────────────────────────────────────
   FORMATS : 2 cartes pricing (étude vs visio)
   ───────────────────────────────────── */
.ps-formats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--grid-gap, 14px);
}

.ps-format {
  border-radius: var(--ps-radius-lg, 22px);
  padding: 32px 26px;
  border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-white, #fff);
  display: flex;
  flex-direction: column;
  transition: transform .28s var(--ps-ease, ease), box-shadow .28s, border-color .28s;
}

.ps-format:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(70,103,129,.10);
  border-color: rgba(70,103,129,.12);
}

.ps-format--featured {
  border-color: rgba(70,103,129,.14);
  background:
    radial-gradient(400px 200px at 80% 0%, rgba(70,103,129,.06), transparent 55%),
    var(--ps-white, #fff);
  box-shadow: 0 10px 32px rgba(70,103,129,.08);
}

.ps-format__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 100px;
  margin-bottom: 18px;
  width: fit-content;
}

.ps-format__badge--blue {
  color: var(--ps-blue, #466781);
  background: var(--ps-blue-wash, rgba(70,103,129,.08));
  border: 1px solid rgba(70,103,129,.12);
}

.ps-format__badge--amber {
  color: var(--ps-amber-dark, #6b5a33);
  background: var(--ps-amber-soft, rgba(199,164,109,.14));
  border: 1px solid rgba(199,164,109,.18);
}

.ps-format__title {
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 900;
  color: var(--ps-text, #1a2a35);
  letter-spacing: -.02em;
  margin: 0 0 8px;
  line-height: 1.1;
}

.ps-format__desc {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ps-text-2, rgba(26,42,53,.56));
  font-weight: 400;
  margin: 0 0 18px;
}

.ps-format__price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 20px;
}

.ps-format__amount {
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 900;
  letter-spacing: -.03em;
  color: var(--ps-blue, #466781);
}

.ps-format__unit {
  font-size: 14px;
  font-weight: 700;
  color: var(--ps-text-3, rgba(26,42,53,.48));
}

.ps-format__features {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.ps-format__features li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  color: var(--ps-text, #1a2a35);
}

.ps-format__features li i {
  font-size: 12px;
  color: var(--ps-green, #3d8b5f);
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ps-green-soft, rgba(61,139,95,.10));
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .ps-formats { grid-template-columns: 1fr; }
  .ps-format { padding: 26px 22px; }
}


/* ═══════════════════════════════════════
   PS TRANSMISSION — CSS SCOPÉ (.pt-)
   Uniquement les composants qui n'existent
   PAS dans refonte.css
   ═══════════════════════════════════════ */

/* ─────────────────────────────────────
   TIMELINE RÈGLES D'ACCÈS (3 colonnes)
   ───────────────────────────────────── */
.pt-timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
}



.pt-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 16px;
  position: relative;
  z-index: 1;
}

.pt-step__dot {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
  color: #fff;
  margin-bottom: 18px;
  box-shadow: 0 4px 14px rgba(0,0,0,.12);
  flex-shrink: 0;
}

.pt-step__dot--green {
  background: var(--ps-green, #3d8b5f);
  box-shadow: 0 4px 14px rgba(61,139,95,.30), 0 0 0 6px rgba(61,139,95,.10);
}

.pt-step__dot--amber {
  background: var(--ps-amber, #C7A46D);
  box-shadow: 0 4px 14px rgba(199,164,109,.30), 0 0 0 6px rgba(199,164,109,.10);
}

.pt-step__dot--muted {
  background: rgba(70,103,129,.30);
  box-shadow: 0 4px 14px rgba(70,103,129,.12), 0 0 0 6px rgba(70,103,129,.06);
}

.pt-step__card {
  border-radius: var(--ps-radius-lg, 22px);
  padding: 24px 20px;
  border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-white, #fff);
  box-shadow: 0 8px 28px rgba(0,0,0,.04);
  width: 100%;
  transition: transform .28s var(--ps-ease, ease), box-shadow .28s, border-color .28s;
}

.pt-step__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 44px rgba(70,103,129,.10);
  border-color: rgba(70,103,129,.12);
}

.pt-step__label {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 0px;
}

.pt-step__label--green { color: var(--ps-green, #3d8b5f); }
.pt-step__label--amber { color: var(--ps-amber-dark, #6b5a33); }
.pt-step__label--muted { color: var(--ps-text-3, rgba(26,42,53,.48)); }

.pt-step__h {
  font-size: 16px;
  font-weight: 800;
  color: var(--ps-text, #1a2a35);
  margin: 0 0 8px;
  line-height: 1.15;
}

.pt-step__p {
  font-size: 13.8px;
  line-height: 1.55;
  color: var(--ps-text-2, rgba(26,42,53,.56));
  font-weight: 500;
  margin: 0;
}

@media (max-width: 640px) {
  .pt-timeline {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .pt-timeline::before {
    display: none;
  }

  .pt-step {
    flex-direction: row;
    text-align: left;
    gap: 14px;
    padding: 0;
  }

  .pt-step__dot {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .pt-step__card {
    padding: 18px 16px;
  }
}

/* ═══════════════════════════════════════
   PS ABOUT — CSS SCOPÉ (.ps-team)
   Uniquement les composants qui n'existent
   PAS dans refonte.css
   ═══════════════════════════════════════ */

/* ─────────────────────────────────────
   TEAM : grid 3 cards membres
   ───────────────────────────────────── */
.ps-team {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap, 14px);
}

.ps-team__card {
  border-radius: var(--ps-radius-lg, 22px);
  padding: 32px 24px;
  border: 1px solid rgba(70,103,129,.06);
  background: var(--ps-white, #fff);
  text-align: center;
  transition: transform .28s var(--ps-ease, ease), box-shadow .28s, border-color .28s;
}

.ps-team__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(70,103,129,.10);
  border-color: rgba(70,103,129,.12);
}

.ps-team__ava {
  width: 64px; height: 64px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 18px;
  font-size: 24px;
  box-shadow: 0 8px 28px rgba(0,0,0,.10);
}

.ps-team__ava--blue {
  background: linear-gradient(135deg, var(--ps-blue, #466781), var(--ps-blue-deep, #345166));
  color: #fff;
}

.ps-team__ava--amber {
  background: linear-gradient(135deg, var(--ps-amber, #C7A46D), #d4b27a);
  color: #fff;
}

.ps-team__role {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 14px;
}

.ps-team__role--blue {
  color: var(--ps-blue, #466781);
  background: var(--ps-blue-wash, rgba(70,103,129,.08));
}

.ps-team__role--amber {
  color: var(--ps-amber-dark, #6b5a33);
  background: var(--ps-amber-soft, rgba(199,164,109,.14));
}

.ps-team__card h3 {
  font-size: 17px;
  font-weight: 800;
  color: var(--ps-text, #1a2a35);
  margin: 0 0 10px;
  line-height: 1.15;
}

.ps-team__card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ps-text-2, rgba(26,42,53,.56));
  font-weight: 400;
  margin: 0;
}

@media (max-width: 980px) {
  .ps-team { grid-template-columns: 1fr 1fr; }
  .ps-team .ps-team__card:last-child { grid-column: 1/3; }
}

@media (max-width: 640px) {
  .ps-team { grid-template-columns: 1fr; }
  .ps-team .ps-team__card:last-child { grid-column: 1; }
  .ps-team__card { padding: 26px 20px; }
}