/* =========================================================
   KB — UX WIDGET DEUIL (NETTOYÉ)
   Objectif : même rendu, sans doublons / collisions
   ========================================================= */


/* ================================
   FIX: overflow / haut rogné
   ================================ */
.kb-ux-container,
.kbmb-widget,
.kbmb-deuil,
.kbmb-deuil-inner,
.kbmb-deuil--v2{
  overflow: visible !important;
}

.elementor-section,
.elementor-widget-wrap{
  overflow: visible;
}

.kbmb-deuil-inner{
  padding-top: 14px;
}

.kb-ux-container:has(> .kbmb-deuil.kbmb-widget.kbmb-glass),
.elementor-widget-container:has(> .kbmb-deuil.kbmb-widget.kbmb-glass),
.elementor-element:has(> .kbmb-deuil.kbmb-widget.kbmb-glass),
.e-con:has(> .kbmb-deuil.kbmb-widget.kbmb-glass),
.e-con-inner:has(> .kbmb-deuil.kbmb-widget.kbmb-glass) {
  width: min(100%, 1680px);
  max-width: 1680px;
  margin-inline: auto;
  padding-inline: clamp(16px, 2vw, 28px);
}

.kbmb-deuil,
.kbmb-deuil.kbmb-widget.kbmb-glass,
.kbmb-deuil-inner.kbmb-deuil--v2 {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.kb-ux-container > .kbmb-widget.kb-section--deuil,
.kb-ux-container > .kbmb-widget.kb-section--deuil.kb-wrap,
.kbmb-deuil.kbmb-widget.kbmb-glass{
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 24px auto !important;
  padding: clamp(18px, 2.2vw, 36px) !important;
  box-sizing: border-box;
  border-radius: 28px;
  position: relative;
  overflow: visible !important;
  transform: none !important;
}

.kbmb-deuil .kbmb-section-header:first-child,
.kbmb-deuil .kb-alert:first-child{
  margin-top: 8px;
}

/* =========================================================
   DEUIL — BANDE "SOUVENIRS" (Sanctuaire) — VERSION FINALE
   (On conserve la version "mini polaroid" la plus aboutie)
   ========================================================= */

.kbmb-deuil .kb-ux-ritual-strip{
  margin-top: 16px;
  padding: 14px 14px 12px;
  border-radius: 22px;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(255,255,255,.52);
  box-shadow: 0 10px 26px rgba(44,62,80,.06);
  backdrop-filter: blur(10px);
}

.kbmb-deuil .kb-ux-ritual-strip__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.kbmb-deuil .kb-ux-ritual-strip__title{
  font-weight: 600;
  color: #2c3e50;
  font-size: 14px;
  letter-spacing: .2px;
}

.kbmb-deuil .kb-ux-ritual-strip__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(44,62,80,.14);
  background: rgba(255,255,255,.65);
  color: rgba(44,62,80,.78);
  font-size: 13px;
  text-decoration: none;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}

.kbmb-deuil .kb-ux-ritual-strip__cta:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.80);
  box-shadow: 0 10px 24px rgba(44,62,80,.10);
}

.kbmb-deuil .kb-ux-ritual-strip__rail{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 4px 2px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.kbmb-deuil .kb-ux-ritual-strip__rail::-webkit-scrollbar{ display:none; }

.kbmb-deuil .kb-ux-ritual-strip__item{
  flex: 0 0 auto;
  width: 66px;
  height: 66px;
  padding: 6px;
  border-radius: 16px;
  border: 1px solid rgba(44,62,80,.12);
  background: rgba(255,255,255,.85);
  box-shadow: 0 10px 22px rgba(44,62,80,.10);
  scroll-snap-align: start;
  transform: rotate(-1.5deg);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
  cursor: pointer;
  position: relative;
}

.kbmb-deuil .kb-ux-ritual-strip__item:nth-child(2n){ transform: rotate(1.2deg); }
.kbmb-deuil .kb-ux-ritual-strip__item:nth-child(3n){ transform: rotate(-0.6deg); }

.kbmb-deuil .kb-ux-ritual-strip__item:hover{
  transform: translateY(-2px) rotate(0deg);
  box-shadow: 0 14px 30px rgba(44,62,80,.14);
  border-color: rgba(212,175,55,.45);
}

.kbmb-deuil .kb-ux-ritual-strip__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
  box-shadow: inset 0 0 0 1px rgba(44,62,80,.06);
}

/* Accessibilité focus */
.kbmb-deuil .kb-ux-ritual-strip__item:focus{ outline: none; }
.kbmb-deuil .kb-ux-ritual-strip__item:focus-visible{
  outline: 2px solid rgba(212,175,55,.70);
  outline-offset: 2px;
}

@media (max-width: 720px){
  .kbmb-deuil .kb-ux-ritual-strip{
    padding: 12px;
    border-radius: 20px;
  }
  .kbmb-deuil .kb-ux-ritual-strip__item{
    width: 62px;
    height: 62px;
  }
  .kbmb-deuil .kb-ux-ritual-strip__cta{
    padding: 7px 12px;
    font-size: 12.5px;
  }
}

/* =========================================================
   DEUIL — FRISE DE TRAVERSÉE (4 étapes) — PONT
   VERSION ÉMOTIONNELLE : Aurore céleste + Eau + Atmosphère poétique
   ========================================================= */

.kbmb-deuil .kbmb-section--bridgeprogress{
  margin: 10px 0 20px 0;
}

/* Corrige l'alignement: la carte parent ne doit pas ajouter de retrait interne */
.kbmb-deuil .kbmb-card--bridgeprogress{
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-crossing-steps{
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 48px;
  padding: 34px 30px 26px 30px;
  margin: 0;

  border-radius: 30px;
  border: 1px solid rgba(178, 198, 237, .26);
  background:
    /* Étoiles (comme dans le mur de photos) */
    radial-gradient(circle at 14% 18%, rgba(255,255,255,.92) 0 1px, transparent 1.2px),
    radial-gradient(circle at 26% 40%, rgba(255,255,255,.76) 0 1px, transparent 1.2px),
    radial-gradient(circle at 38% 16%, rgba(255,255,255,.84) 0 1px, transparent 1.2px),
    radial-gradient(circle at 53% 33%, rgba(255,255,255,.70) 0 1px, transparent 1.2px),
    radial-gradient(circle at 66% 14%, rgba(255,255,255,.82) 0 1px, transparent 1.2px),
    radial-gradient(circle at 78% 42%, rgba(255,255,255,.74) 0 1px, transparent 1.2px),
    radial-gradient(circle at 91% 24%, rgba(255,255,255,.88) 0 1px, transparent 1.2px),
    /* Lueurs nocturnes subtiles (bleu + or) */
    radial-gradient(120% 130% at 22% -10%, rgba(146,173,232,.24), rgba(146,173,232,0) 58%),
    radial-gradient(120% 130% at 84% 14%, rgba(202,182,120,.18), rgba(202,182,120,0) 62%),
    /* Fond nocturne (comme le mur de photos) */
    linear-gradient(180deg, rgba(24,31,53,.95), rgba(14,19,35,.96));
  box-shadow:
    0 24px 52px rgba(7,10,20,.34),
    inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(16px);

  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  flex: 0 0 auto;
  overflow: visible;
}

/* Pont doré avec reflet d'eau en dessous (Point 3) */
.kbmb-deuil .kbmb-crossing-steps::before{
  content:"";
  position:absolute;
  left: 26px;
  right: 26px;
  top: 24px;
  height: 96px;
  pointer-events:none;
  background:
    /* Le pont lui-même - plus chaleureux */
    radial-gradient(120% 140% at 50% 130%,
      transparent 52%,
      rgba(255,183,107,.85) 53%,
      rgba(212,175,55,.45) 56%,
      transparent 62%
    );
  filter: drop-shadow(0 12px 24px rgba(212,175,55,.30));
  opacity: 1;
  animation: kbBridgeGentleGlow 4s ease-in-out infinite;
}

/* Effet de reflet d'eau sous le pont (Point 3) */
.kbmb-deuil .kbmb-crossing-steps::after{
  content:"";
  position:absolute;
  left: 20px;
  right: 20px;
  bottom: -15px;
  height: 30px;
  border-radius: 30px;
  pointer-events:none;
  background:
    /* Reflet du pont dans l'eau */
    radial-gradient(ellipse 100% 80% at 50% 0%,
      rgba(212,175,55,.15) 0%,
      rgba(135,206,235,.20) 30%,
      rgba(147,112,219,.08) 60%,
      transparent 100%
    );
  opacity: .75;
  filter: blur(8px);
  animation: kbWaterRipple 3s ease-in-out infinite;
}

/* Effet de bokeh / particules lumineuses (Point 4) */
.kbmb-deuil .kbmb-crossing-steps{
  --bokeh-color-1: rgba(255,183,107,.25);
  --bokeh-color-2: rgba(255,182,193,.20);
  --bokeh-color-3: rgba(147,112,219,.15);
}

.kbmb-deuil .kbmb-crossing-steps:before:before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 30px;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 15% 25%, var(--bokeh-color-1) 0, transparent 3px),
    radial-gradient(circle at 85% 15%, var(--bokeh-color-2) 0, transparent 4px),
    radial-gradient(circle at 45% 35%, var(--bokeh-color-3) 0, transparent 2px),
    radial-gradient(circle at 72% 42%, var(--bokeh-color-1) 0, transparent 3px),
    radial-gradient(circle at 28% 55%, var(--bokeh-color-2) 0, transparent 2.5px),
    radial-gradient(circle at 60% 65%, var(--bokeh-color-3) 0, transparent 3.5px),
    radial-gradient(circle at 90% 75%, var(--bokeh-color-1) 0, transparent 2px);
  opacity: .6;
  animation: kbBokehFloat 8s ease-in-out infinite;
  z-index: 0;
}

.kbmb-deuil .kbmb-crossing-step{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
  text-align: center;
  z-index: 1;
  user-select: none;
  transition: transform 0.3s ease;
}

/* Micro-interaction : respiration au survol (Point 5) */
.kbmb-deuil .kbmb-crossing-step:hover{
  transform: scale(1.05);
}

.kbmb-deuil .kbmb-crossing-step .dot{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(224, 233, 255, .35);
  border: 1px solid rgba(224, 233, 255, .50);
  box-shadow: 0 10px 24px rgba(146,173,232,.25);
  transition: all 0.4s ease;
}

/* Effet de lueur au survol des étapes (Point 5) */
.kbmb-deuil .kbmb-crossing-step:hover .dot{
  transform: scale(1.1);
  box-shadow:
    0 12px 28px rgba(44,62,80,.16),
    0 0 12px rgba(212,175,55,.25);
}

.kbmb-deuil .kbmb-crossing-step .label{
  font-size: 14px;
  line-height: 1.15;
  color: rgba(224, 233, 255, .88);
  letter-spacing: .25px;
  white-space: nowrap;
  transition: color 0.3s ease, transform 0.3s ease;
}

/* Animation douce du label au survol (Point 5) */
.kbmb-deuil .kbmb-crossing-step:hover .label{
  color: rgba(212,175,55,.95);
  transform: translateY(-2px);
}

.kbmb-deuil .kbmb-crossing-step.is-on .label{
  color: #d4af37;
  font-weight: 700;
}

/* Animation de respiration douce pour le point actif (Point 5) */
@keyframes kbBridgePulse{
  0%, 100% {
    transform: translateY(0) scale(1);
    opacity: .88;
    box-shadow:
      0 12px 34px rgba(212,175,55,.30),
      0 0 0 7px rgba(212,175,55,.12),
      0 0 15px rgba(255,183,107,.20);
  }
  50% {
    transform: translateY(-2px) scale(1.08);
    opacity: 1;
    box-shadow:
      0 14px 38px rgba(212,175,55,.40),
      0 0 0 10px rgba(212,175,55,.18),
      0 0 25px rgba(255,183,107,.35);
  }
}

.kbmb-deuil .kbmb-crossing-step.is-on .dot{
  background: radial-gradient(circle at 35% 35%, #f5e5a0 0%, #d4af37 60%, #b8932a 100%);
  border-color: rgba(212,175,55,.70);
  box-shadow:
    0 12px 34px rgba(212,175,55,.30),
    0 0 0 7px rgba(212,175,55,.12);
  animation: kbBridgePulse 2.6s ease-in-out infinite;
}

/* Scène vivante : la lettre traverse le pont */
.kbmb-deuil .kbmb-crossing-steps{
  --kbmb-cross-progress: .12;
}

.kbmb-deuil .kbmb-crossing-scene{
  position: absolute;
  left: 22px;
  right: 22px;
  top: 8px;
  height: 54px;
  z-index: 2;
  pointer-events: none;
}

/* Particules dorées qui s'échappent de la lettre (Point 2) */
.kbmb-deuil .kbmb-crossing-scene::before,
.kbmb-deuil .kbmb-crossing-scene::after{
  content: "";
  position: absolute;
  left: calc((100% - 30px) * var(--kbmb-cross-progress) + 15px);
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,215,0,.9) 0%, rgba(212,175,55,.6) 50%, transparent 100%);
  transition: left 1.15s cubic-bezier(.2,.72,.18,.99);
}

.kbmb-deuil .kbmb-crossing-scene::before{
  top: 6px;
  animation: kbParticleFloat1 2.8s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-scene::after{
  top: 28px;
  animation: kbParticleFloat2 3.4s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-letter{
  position: absolute;
  top: 8px;
  left: calc((100% - 30px) * var(--kbmb-cross-progress));
  width: 30px;
  height: 20px;
  border-radius: 4px;
  border: 1px solid rgba(212,175,55,.65);
  background:
    /* Dégradé plus chaleureux (Point 4) */
    linear-gradient(145deg, #fffbf0 0%, #ffe8c5 50%, #ffd7a8 100%);
  box-shadow:
    0 10px 24px rgba(44,62,80,.18),
    0 0 20px rgba(255,183,107,.35),
    0 0 0 1px rgba(255,255,255,.50) inset;
  transform: translateZ(0);
  transition: left 1.15s cubic-bezier(.2,.72,.18,.99);
  animation: kbCrossLetterFloat 3.2s ease-in-out infinite;
  filter: drop-shadow(0 0 8px rgba(212,175,55,.25));
}

/* Traînée lumineuse derrière la lettre (Point 2) */
.kbmb-deuil .kbmb-crossing-letter:before{
  content: "";
  position: absolute;
  left: -40px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 2px;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(255,183,107,.0) 20%,
    rgba(255,183,107,.35) 60%,
    rgba(212,175,55,.45) 100%
  );
  opacity: .85;
  filter: blur(1px);
  animation: kbLetterTrail 3s ease-in-out infinite;
}

/* Sceau doré sur la lettre avec effet de lueur (Point 1) */
.kbmb-deuil .kbmb-crossing-letter::after{
  content: "";
  position: absolute;
  width: 9px;
  height: 9px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: radial-gradient(
    circle at 35% 35%,
    #fff9e6 0%,
    #f3dfa1 25%,
    #d4af37 65%,
    #b28f2a 100%
  );
  box-shadow:
    0 0 0 4px rgba(212,175,55,.18),
    0 0 8px rgba(212,175,55,.40),
    0 2px 6px rgba(44,62,80,.15);
  animation: kbSealPulse 2.5s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-arrival{
  position: absolute;
  right: 0;
  top: 14px;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background:
    /* Effet céleste chaleureux (Point 1 & 4) */
    radial-gradient(circle at 35% 35%,
      rgba(255,250,240,.98) 0%,
      rgba(255,215,0,.75) 25%,
      rgba(255,183,107,.45) 50%,
      rgba(212,175,55,.25) 70%,
      transparent 100%
    );
  opacity: .65;
  transform: scale(.95);
  animation: kbCrossArrivalGlow 2.7s ease-in-out infinite;
  box-shadow:
    0 0 15px rgba(255,183,107,.40),
    0 0 30px rgba(212,175,55,.20);
}

/* Pulsation douce à l'arrivée (Point 5) */
.kbmb-deuil .kbmb-crossing-steps.is-phase-3 .kbmb-crossing-arrival{
  opacity: 1;
  transform: scale(1.08);
  animation: kbArrivalBreathing 2.2s ease-in-out infinite;
  box-shadow:
    0 0 20px rgba(255,183,107,.50),
    0 0 40px rgba(212,175,55,.30),
    0 0 60px rgba(255,182,193,.15);
}

.kbmb-deuil .kbmb-crossing-steps.kbmb-arrival-replay-active .kbmb-crossing-letter{
  transition: left 1.95s cubic-bezier(.18,.78,.18,1);
  box-shadow:
    0 12px 26px rgba(44,62,80,.20),
    0 0 0 1px rgba(255,255,255,.50) inset,
    0 0 22px rgba(212,175,55,.34);
}

.kbmb-deuil .kbmb-crossing-steps.kbmb-arrival-replay-active .kbmb-crossing-arrival{
  opacity: 1;
  transform: scale(1.08);
  animation: kbCrossArrivalReplay 1.1s ease-out 2;
}

.kbmb-deuil .kbmb-crossing-note--arrival{
  background: rgba(212,175,55,.12);
  border: 1px solid rgba(212,175,55,.25);
}

.kbmb-deuil .kbmb-crossing-note{
  position: relative;
  overflow: hidden;
}

.kbmb-deuil .kbmb-crossing-note::after{
  content: "";
  position: absolute;
  top: -120%;
  left: -32%;
  width: 24%;
  height: 340%;
  transform: rotate(18deg);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.34), rgba(255,255,255,.02));
  animation: kbCrossNoteSheen 5.6s ease-in-out infinite;
  pointer-events: none;
}

/* One-shot solennel au clic "Laisser ces mots traverser le pont" */
.kbmb-deuil .kbmb-ritual-note--oneshot{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(212,175,55,.42);
  background: linear-gradient(135deg, rgba(255,250,243,.96), rgba(255,244,222,.94));
  color: #2c3e50;
  box-shadow:
    0 10px 24px rgba(44,62,80,.10),
    inset 0 1px 0 rgba(255,255,255,.72);
  animation: kbRitualOneShotFade 20s ease-out forwards;
}

.kbmb-deuil .kbmb-ritual-note--oneshot .kbmb-ritual-note__line{
  display: block;
  line-height: 1.45;
}

.kbmb-deuil .kbmb-ritual-note--oneshot .kbmb-ritual-note__line + .kbmb-ritual-note__line{
  margin-top: 2px;
}

/* Animation flottement poétique de la lettre (Point 2) */
@keyframes kbCrossLetterFloat{
  0%, 100% {
    transform: translateY(0) rotate(-2deg);
  }
  25% {
    transform: translateY(-4px) rotate(0deg);
  }
  50% {
    transform: translateY(-5px) rotate(1.5deg);
  }
  75% {
    transform: translateY(-3px) rotate(0deg);
  }
}

/* Animation de la traînée lumineuse (Point 2) */
@keyframes kbLetterTrail{
  0%, 100% {
    opacity: .7;
    transform: translateY(-50%) scaleX(1);
  }
  50% {
    opacity: 1;
    transform: translateY(-50%) scaleX(1.15);
  }
}

/* Pulsation du sceau doré (Point 2) */
@keyframes kbSealPulse{
  0%, 100% {
    transform: translate(-50%, -50%) scale(1);
    box-shadow:
      0 0 0 4px rgba(212,175,55,.18),
      0 0 8px rgba(212,175,55,.40),
      0 2px 6px rgba(44,62,80,.15);
  }
  50% {
    transform: translate(-50%, -50%) scale(1.12);
    box-shadow:
      0 0 0 5px rgba(212,175,55,.25),
      0 0 15px rgba(212,175,55,.55),
      0 2px 8px rgba(44,62,80,.20);
  }
}

/* Particules dorées flottantes (Point 2) */
@keyframes kbParticleFloat1{
  0%, 100% {
    transform: translate(0, 0);
    opacity: .8;
  }
  25% {
    transform: translate(-5px, -8px);
    opacity: .95;
  }
  50% {
    transform: translate(-8px, -15px);
    opacity: .6;
  }
  75% {
    transform: translate(-10px, -10px);
    opacity: .3;
  }
}

@keyframes kbParticleFloat2{
  0%, 100% {
    transform: translate(0, 0);
    opacity: .7;
  }
  30% {
    transform: translate(-7px, 6px);
    opacity: .9;
  }
  60% {
    transform: translate(-12px, 12px);
    opacity: .5;
  }
  85% {
    transform: translate(-15px, 8px);
    opacity: .2;
  }
}

/* Lueur douce du pont (Point 1) */
@keyframes kbBridgeGentleGlow{
  0%, 100% {
    opacity: .95;
    filter: drop-shadow(0 12px 24px rgba(212,175,55,.30));
  }
  50% {
    opacity: 1;
    filter: drop-shadow(0 12px 30px rgba(255,183,107,.40));
  }
}

/* Ondulation de l'eau (Point 3) */
@keyframes kbWaterRipple{
  0%, 100% {
    transform: scaleX(1) scaleY(1);
    opacity: .70;
  }
  50% {
    transform: scaleX(1.05) scaleY(.95);
    opacity: .85;
  }
}

/* Mouvement du bokeh (Point 4) */
@keyframes kbBokehFloat{
  0%, 100% {
    opacity: .5;
    transform: translateY(0);
  }
  50% {
    opacity: .75;
    transform: translateY(-3px);
  }
}

/* Respiration de l'arrivée (Point 5) */
@keyframes kbArrivalBreathing{
  0%, 100% {
    transform: scale(1.08);
    opacity: .95;
  }
  50% {
    transform: scale(1.15);
    opacity: 1;
  }
}

@keyframes kbCrossArrivalGlow{
  0%, 100% {
    box-shadow:
      0 0 15px rgba(255,183,107,.40),
      0 0 30px rgba(212,175,55,.20);
  }
  50% {
    box-shadow:
      0 0 20px rgba(255,183,107,.50),
      0 0 40px rgba(212,175,55,.30);
  }
}

@keyframes kbCrossNoteSheen{
  0%   { left: -36%; opacity: .2; }
  40%  { left: 118%; opacity: .65; }
  100% { left: 118%; opacity: .2; }
}

@keyframes kbRitualOneShotFade{
  0%{
    opacity: 0;
    transform: translateY(2px);
  }
  12%{
    opacity: 1;
    transform: translateY(0);
  }
  72%{
    opacity: 1;
    transform: translateY(0);
  }
  100%{
    opacity: .12;
    transform: translateY(-2px);
  }
}

@keyframes kbCrossArrivalReplay{
  0%   {
    box-shadow:
      0 0 20px rgba(255,183,107,.50),
      0 0 40px rgba(212,175,55,.30);
  }
  35%  {
    box-shadow:
      0 0 30px rgba(255,183,107,.65),
      0 0 60px rgba(212,175,55,.45);
  }
  100% {
    box-shadow:
      0 0 20px rgba(255,183,107,.50),
      0 0 40px rgba(212,175,55,.30);
  }
}

@media (prefers-reduced-motion: reduce){
  .kbmb-deuil .kbmb-crossing-letter,
  .kbmb-deuil .kbmb-crossing-arrival,
  .kbmb-deuil .kbmb-crossing-note::after{
    animation: none !important;
  }
  .kbmb-deuil .kbmb-crossing-letter{
    transition: none;
  }
}

@media (max-width: 560px){
  .kbmb-deuil .kbmb-crossing-steps{
    flex-direction: column;
    gap: 12px;
    padding: 20px 16px 16px 16px;
    margin: 0;
  }
  .kbmb-deuil .kbmb-crossing-steps::before{
    left: 14px;
    right: 14px;
    top: 12px;
    height: 44px;
    background:
      radial-gradient(160% 160% at 50% 140%,
        transparent 52%,
        rgba(212,175,55,.70) 53%,
        rgba(212,175,55,.28) 56%,
        transparent 62%
      );
  }
  .kbmb-deuil .kbmb-crossing-step{
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    gap: 12px;
  }
  .kbmb-deuil .kbmb-crossing-step .label{
    white-space: normal;
  }
  .kbmb-deuil .kbmb-crossing-scene{
    left: 14px;
    right: 14px;
    top: 4px;
  }
  .kbmb-deuil .kbmb-crossing-letter{
    width: 28px;
    height: 18px;
  }
  .kbmb-deuil .kbmb-crossing-arrival{
    width: 22px;
    height: 22px;
  }
}

/* =========================================================
   DEUIL — FRISE DE TRAVERSÉE (WEB RECADRÉ)
   Scène large + noyau narratif + timeline basse
   ========================================================= */

.kbmb-deuil .kbmb-crossing-note--bridge-source{
  display: none !important;
}

.kbmb-deuil .kbmb-section--bridgeprogress{
  margin: 10px 0 24px 0;
}

.kbmb-deuil .kbmb-card--bridgeprogress{
  position: relative;
  width: min(100%, 1680px);
  margin: 0 auto;
}

.kbmb-deuil .kbmb-crossing-help{
  position: absolute;
  top: 18px;
  right: 22px;
  z-index: 3;
  margin: 0;
}

.kbmb-deuil .kbmb-crossing-steps{
  --kbmb-cross-progress: .12;
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-content: stretch;
  justify-items: stretch;
  align-items: stretch;
  gap: 14px;
  padding: 22px 30px 20px;
  margin: 0;
  border-radius: 34px;
  border: 1px solid rgba(178, 198, 237, .24);
  background:
    radial-gradient(circle at 14% 18%, rgba(255,255,255,.92) 0 1px, transparent 1.2px),
    radial-gradient(circle at 27% 38%, rgba(255,255,255,.72) 0 1px, transparent 1.2px),
    radial-gradient(circle at 39% 15%, rgba(255,255,255,.84) 0 1px, transparent 1.2px),
    radial-gradient(circle at 55% 31%, rgba(255,255,255,.66) 0 1px, transparent 1.2px),
    radial-gradient(circle at 68% 16%, rgba(255,255,255,.8) 0 1px, transparent 1.2px),
    radial-gradient(circle at 82% 27%, rgba(255,255,255,.72) 0 1px, transparent 1.2px),
    radial-gradient(circle at 93% 14%, rgba(255,255,255,.88) 0 1px, transparent 1.2px),
    radial-gradient(120% 130% at 22% -10%, rgba(146,173,232,.26), rgba(146,173,232,0) 58%),
    radial-gradient(120% 130% at 84% 10%, rgba(214,186,120,.20), rgba(214,186,120,0) 60%),
    linear-gradient(180deg, rgba(34,44,72,.96) 0%, rgba(14,19,36,.98) 100%);
  box-shadow:
    0 26px 50px rgba(8,11,20,.28),
    inset 0 1px 0 rgba(255,255,255,.08);
  overflow: hidden;
}

.kbmb-deuil .kbmb-crossing-steps::before,
.kbmb-deuil .kbmb-crossing-steps::after{
  content: none;
}

.kbmb-deuil .kbmb-crossing-stage{
  position: relative;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  height: 136px;
  margin: -4px -4px 0;
  border-radius: 26px;
  overflow: hidden;
}

.kbmb-deuil .kbmb-crossing-glow,
.kbmb-deuil .kbmb-crossing-bridge,
.kbmb-deuil .kbmb-crossing-reflection{
  position: absolute;
  pointer-events: none;
}

.kbmb-deuil .kbmb-crossing-glow--left{
  left: -8%;
  top: -18%;
  width: 52%;
  height: 74%;
  background: radial-gradient(circle, rgba(146,173,232,.34) 0%, rgba(146,173,232,0) 70%);
  animation: kbBokehFloat 8s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-glow--right{
  right: -10%;
  top: -20%;
  width: 50%;
  height: 70%;
  background: radial-gradient(circle, rgba(214,186,120,.30) 0%, rgba(214,186,120,0) 72%);
  animation: kbBokehFloat 9s ease-in-out infinite reverse;
}

.kbmb-deuil .kbmb-crossing-bridge{
  left: 3%;
  right: 3%;
  top: 30px;
  height: 74px;
  background:
    radial-gradient(120% 140% at 50% 130%,
      transparent 53%,
      rgba(255,183,107,.88) 54%,
      rgba(212,175,55,.46) 57%,
      transparent 63%);
  filter: drop-shadow(0 12px 24px rgba(212,175,55,.28));
  animation: kbBridgeGentleGlow 4.6s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-reflection{
  left: 8%;
  right: 8%;
  bottom: 4px;
  height: 18px;
  border-radius: 999px;
  background: radial-gradient(ellipse 100% 86% at 50% 0%, rgba(212,175,55,.18) 0%, rgba(135,206,235,.18) 36%, rgba(147,112,219,.08) 68%, transparent 100%);
  filter: blur(7px);
  opacity: .74;
  animation: kbWaterRipple 3.4s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-stage .kbmb-crossing-scene{
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.kbmb-deuil .kbmb-crossing-stage .kbmb-crossing-scene::before,
.kbmb-deuil .kbmb-crossing-stage .kbmb-crossing-scene::after{
  content: "";
  position: absolute;
  left: calc((100% - 30px) * var(--kbmb-cross-progress) + 15px);
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,215,0,.9) 0%, rgba(212,175,55,.6) 50%, transparent 100%);
  transition: left 1.15s cubic-bezier(.2,.72,.18,.99);
}

.kbmb-deuil .kbmb-crossing-stage .kbmb-crossing-scene::before{
  top: 34px;
  animation: kbParticleFloat1 2.8s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-stage .kbmb-crossing-scene::after{
  top: 58px;
  animation: kbParticleFloat2 3.4s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-letter{
  top: 40px;
  left: calc((100% - 30px) * var(--kbmb-cross-progress));
  width: 30px;
  height: 20px;
  transition: left 1.15s cubic-bezier(.2,.72,.18,.99);
}

.kbmb-deuil .kbmb-crossing-arrival{
  right: 4px;
  top: 44px;
  width: 28px;
  height: 28px;
}

.kbmb-deuil .kbmb-crossing-copy{
  position: relative;
  z-index: 1;
  display: grid;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  justify-items: center;
  gap: 0;
  text-align: center;
}

.kbmb-deuil .kbmb-crossing-eyebrow{
  margin: 0 0 6px;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(223,231,247,.74);
}

.kbmb-deuil .kbmb-crossing-status{
  margin: 0;
  font-family: "Cormorant Garamond", "Times New Roman", serif;
  font-size: clamp(46px, 5.2vw, 64px);
  font-style: italic;
  font-weight: 500;
  line-height: .98;
  color: #f7ebc2;
  text-shadow: 0 8px 26px rgba(17,23,39,.34);
}

.kbmb-deuil .kbmb-crossing-main{
  margin: 10px auto 0;
  max-width: 36ch;
  font-size: 17px;
  line-height: 1.58;
  color: rgba(236,241,249,.92);
}

.kbmb-deuil .kbmb-crossing-timer,
.kbmb-deuil .kbmb-crossing-arrival-note{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 12px auto 0;
  padding: 8px 12px;
  min-height: 32px;
  max-width: calc(100% - 20px);
  border-radius: 999px;
  border: 1px solid rgba(214,197,150,.2);
  background: rgba(255,255,255,.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  font-size: 13px;
  line-height: 1.35;
  color: rgba(244,226,170,.92);
  text-align: center;
}

.kbmb-deuil .kbmb-crossing-timer::before,
.kbmb-deuil .kbmb-crossing-arrival-note::before{
  content: "";
  flex: 0 0 auto;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: radial-gradient(circle at 35% 35%, #fff7d5 0%, #d4af37 66%, #b8932a 100%);
  box-shadow:
    0 0 10px rgba(212,175,55,.44),
    0 0 0 4px rgba(212,175,55,.12);
}

.kbmb-deuil .kbmb-crossing-arrival-note{
  color: #fff0c1;
  background: rgba(212,175,55,.08);
  border-color: rgba(212,175,55,.28);
}

.kbmb-deuil .kbmb-crossing-timeline{
  position: relative;
  z-index: 1;
  display: grid;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 2px;
}

.kbmb-deuil .kbmb-crossing-step{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-width: 0;
  text-align: center;
  user-select: none;
  transform: none;
}

.kbmb-deuil .kbmb-crossing-step:hover{
  transform: none;
}

.kbmb-deuil .kbmb-crossing-step .dot{
  width: 12px;
  height: 12px;
  background: rgba(224,233,255,.30);
  border: 1px solid rgba(224,233,255,.44);
  box-shadow: 0 8px 18px rgba(146,173,232,.20);
}

.kbmb-deuil .kbmb-crossing-step:hover .dot{
  transform: none;
  box-shadow: 0 8px 18px rgba(146,173,232,.20);
}

.kbmb-deuil .kbmb-crossing-step .label{
  display: block;
  font-size: 13px;
  line-height: 1.3;
  color: rgba(218,226,241,.78);
  white-space: normal;
}

.kbmb-deuil .kbmb-crossing-step:hover .label{
  color: rgba(218,226,241,.78);
  transform: none;
}

.kbmb-deuil .kbmb-crossing-step.is-on .dot{
  background: radial-gradient(circle at 35% 35%, #f5e5a0 0%, #d4af37 60%, #b8932a 100%);
  border-color: rgba(212,175,55,.76);
  box-shadow:
    0 10px 24px rgba(212,175,55,.26),
    0 0 0 5px rgba(212,175,55,.10);
  animation: none;
}

.kbmb-deuil .kbmb-crossing-step.is-on .label{
  color: #f4deb0;
  font-weight: 500;
}

.kbmb-deuil .kbmb-crossing-step.is-current .dot{
  transform: scale(1.08);
  box-shadow:
    0 12px 28px rgba(212,175,55,.34),
    0 0 0 8px rgba(212,175,55,.13);
  animation: kbBridgePulse 2.6s ease-in-out infinite;
}

.kbmb-deuil .kbmb-crossing-step.is-current .label{
  font-weight: 700;
  color: #f7ebc2;
}

.kbmb-deuil .kbmb-crossing-steps.kbmb-arrival-replay-active{
  box-shadow:
    0 28px 52px rgba(8,11,20,.30),
    0 0 0 1px rgba(248,223,154,.16) inset,
    0 0 42px rgba(212,175,55,.12);
}

@media (max-width: 1080px){
  .kbmb-deuil .kbmb-crossing-steps{
    padding: 19px 22px 18px;
    gap: 14px;
  }

  .kbmb-deuil .kbmb-crossing-stage{
    height: 122px;
  }

  .kbmb-deuil .kbmb-crossing-bridge{
    top: 28px;
    height: 68px;
  }

  .kbmb-deuil .kbmb-crossing-letter{
    top: 38px;
  }

  .kbmb-deuil .kbmb-crossing-arrival{
    top: 42px;
  }

  .kbmb-deuil .kbmb-crossing-status{
    font-size: clamp(38px, 4.8vw, 52px);
  }

  .kbmb-deuil .kbmb-crossing-main{
    font-size: 16px;
  }
}

@media (max-width: 720px){
  .kbmb-deuil .kbmb-crossing-help{
    top: 14px;
    right: 16px;
  }

  .kbmb-deuil .kbmb-crossing-steps{
    padding: 16px 14px 16px;
    gap: 12px;
    border-radius: 28px;
  }

  .kbmb-deuil .kbmb-crossing-stage{
    height: 102px;
  }

  .kbmb-deuil .kbmb-crossing-bridge{
    top: 24px;
    height: 58px;
  }

  .kbmb-deuil .kbmb-crossing-reflection{
    bottom: 4px;
  }

  .kbmb-deuil .kbmb-crossing-letter{
    top: 31px;
    width: 28px;
    height: 18px;
  }

  .kbmb-deuil .kbmb-crossing-arrival{
    top: 34px;
    width: 24px;
    height: 24px;
  }

  .kbmb-deuil .kbmb-crossing-status{
    font-size: 38px;
  }

  .kbmb-deuil .kbmb-crossing-main{
    max-width: 28ch;
    font-size: 14px;
  }

  .kbmb-deuil .kbmb-crossing-timeline{
    gap: 10px;
  }

  .kbmb-deuil .kbmb-crossing-step .label{
    font-size: 12px;
  }
}

/* =========================================================
   DEUIL — JOURNAL (Chemin + Traces)
   ========================================================= */

.kbmb-deuil .kbmb-section--journal .kbmb-section-header{
  margin-bottom: 16px;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(44,62,80,.12);
  background:
    radial-gradient(65% 120% at 12% 0%, rgba(212,175,55,.15), transparent 68%),
    linear-gradient(135deg, rgba(255,255,255,.76), rgba(247,249,252,.60));
  box-shadow: 0 16px 36px rgba(44,62,80,.10);
}

.kbmb-deuil .kbmb-journal-heading{
  font-size: clamp(27px, 3.2vw, 34px);
  line-height: 1.02;
  letter-spacing: .2px;
  color: #2c3e50;
  margin: 0 0 6px 0;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle{
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: rgba(44,62,80,.76);
  font-style: italic;
}

.kbmb-deuil .kbmb-journal-card{
  position: relative;
  margin: 14px 0 18px 0;
  padding: 38px 22px 18px 22px;
  margin-left: 52px;

  border-radius: 24px;
  border: 1px solid rgba(44,62,80,.17);
  background:
    radial-gradient(80% 120% at 0% 0%, rgba(212,175,55,.10), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.74), rgba(249,250,252,.62));
  box-shadow: 0 18px 50px rgba(44,62,80,.14);
  backdrop-filter: blur(12px);
  overflow: visible;
}

.kbmb-deuil .kbmb-journal-card::after{
  content:"";
  position:absolute;
  inset: 10px;
  border-radius: 18px;
  pointer-events:none;
  border: 1px solid rgba(212,175,55,.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.20), rgba(255,255,255,.06)),
    radial-gradient(80% 120% at 0% 0%, rgba(212,175,55,.09), transparent 60%),
    radial-gradient(90% 140% at 100% 20%, rgba(86,199,255,.07), transparent 62%);
  opacity: .85;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card{
  border-color: rgba(212,175,55,.34);
  box-shadow:
    0 22px 54px rgba(44,62,80,.16),
    0 0 0 1px rgba(212,175,55,.12) inset;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-title{
  font-size: 28px;
  line-height: 1.32;
}

.kbmb-deuil .kbmb-journal-item.is-just-arrived .kbmb-journal-card{
  animation: kbJournalArrivalCycle 7s cubic-bezier(.22,.61,.36,1) 1 both;
  will-change: transform, opacity, box-shadow, border-color;
}

.kbmb-deuil .kbmb-arrival-flash{
  margin: 0 0 12px 0;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(212,175,55,.50);
  background: linear-gradient(135deg, rgba(255,250,243,.98), rgba(255,244,222,.94));
  color: #2c3e50;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  box-shadow:
    0 16px 38px rgba(212,175,55,.24),
    0 10px 24px rgba(44,62,80,.10);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .45s ease, transform .45s ease;
}

.kbmb-deuil .kbmb-arrival-flash.is-visible{
  opacity: 1;
  transform: translateY(0);
}

.kbmb-deuil .kbmb-arrival-flash.is-hiding{
  opacity: 0;
  transform: translateY(-4px);
}

.kbmb-deuil .kbmb-journal-ribbon{
  position: absolute;
  left: 18px;
  top: -12px;
  z-index: 3;
  padding: 7px 13px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.35);
  background: linear-gradient(180deg, #5f738a 0%, #4f667d 100%);
  color: #f2df9e;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .25px;
  box-shadow: 0 12px 26px rgba(44,62,80,.20);
}

.kbmb-deuil .kbmb-journal-seal{
  position: absolute;
  top: -16px;
  right: 18px;
  z-index: 3;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.50);
  background: radial-gradient(circle at 35% 30%, #f5df99 0%, #d4af37 72%, #b58f24 100%);
  color: rgba(44,62,80,.90);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 10px 24px rgba(212,175,55,.30),
    0 0 0 6px rgba(212,175,55,.10);
}

.kbmb-deuil .kbmb-journal-seal span{
  font-size: 14px;
  line-height: 1;
}

.kbmb-deuil .kbmb-journal-wax{
  position: absolute;
  top: -16px;
  right: 18px;
  z-index: 3;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(122, 35, 29, .56);
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 216, 196, .52) 0%, rgba(255,216,196,.12) 28%, transparent 38%),
    radial-gradient(circle at 56% 62%, #c54a3d 0%, #a4362c 58%, #74221a 100%);
  box-shadow:
    0 12px 24px rgba(81, 20, 16, .34),
    0 0 0 7px rgba(122, 35, 29, .10),
    inset 0 2px 4px rgba(255, 224, 205, .22),
    inset 0 -3px 4px rgba(83, 22, 18, .25);
}

.kbmb-deuil .kbmb-journal-wax::before{
  content: "";
  position: absolute;
  inset: 7px;
  border-radius: 50%;
  border: 1px solid rgba(245, 214, 194, .36);
  box-shadow: inset 0 0 0 2px rgba(122, 35, 29, .20);
}

.kbmb-deuil .kbmb-journal-wax::after{
  content: "KB";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size: 10px;
  letter-spacing: .4px;
  font-weight: 700;
  color: rgba(255, 236, 221, .85);
  text-shadow: 0 1px 0 rgba(92, 24, 19, .44);
}

.kbmb-deuil .kbmb-journal-card::before{
  content:"";
  position:absolute;
  left: -26px;
  top: -18px;
  bottom: -18px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(
    to bottom,
    rgba(212,175,55,.00),
    rgba(212,175,55,.52),
    rgba(212,175,55,.25),
    rgba(212,175,55,.00)
  );
  opacity: .96;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card::before{
  background: linear-gradient(
    to bottom,
    rgba(212,175,55,.00),
    rgba(212,175,55,.72),
    rgba(212,175,55,.34),
    rgba(212,175,55,.00)
  );
}

.kbmb-deuil .kbmb-journal-card .kbmb-journal-dot,
.kbmb-deuil .kbmb-journal-card .kbmb-timeline-dot,
.kbmb-deuil .kbmb-journal-card .kbmb-dot{
  position:absolute;
  left: -34px;
  top: 22px;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: #d4af37;
  border: 1px solid rgba(212,175,55,.55);
  box-shadow:
    0 14px 34px rgba(212,175,55,.30),
    0 0 0 10px rgba(212,175,55,.13);
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card .kbmb-journal-dot,
.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card .kbmb-timeline-dot,
.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card .kbmb-dot{
  box-shadow:
    0 16px 36px rgba(212,175,55,.34),
    0 0 0 11px rgba(212,175,55,.16);
}

.kbmb-deuil .kbmb-journal-title,
.kbmb-deuil .kbmb-journal-card h4,
.kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
  font-family: "Savoye LET", "Segoe Script", "Bradley Hand", "Snell Roundhand", cursive;
  font-weight: 600;
  letter-spacing: .1px;
  color: #3b536c;
  margin-bottom: 9px;
  font-size: 28px;
  line-height: 1.32;
  text-shadow: 0 1px 0 rgba(255,255,255,.42);
}

.kbmb-deuil .kbmb-journal-date,
.kbmb-deuil .kbmb-journal-card .kbmb-date,
.kbmb-deuil .kbmb-journal-card time{
  color: rgba(44,62,80,.72);
  font-size: 13px;
}

.kbmb-deuil .kbmb-journal-badge,
.kbmb-deuil .kbmb-journal-card .kbmb-badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.30);
  background: rgba(212,175,55,.14);
  color: rgba(44,62,80,.90);
}

.kbmb-deuil .kbmb-journal-excerpt{
  margin: 0 0 8px 0;
  font-size: 16px;
  line-height: 1.58;
  color: rgba(44,62,80,.90);
}

.kbmb-deuil .kbmb-journal-excerpt--sealed{
  color: rgba(44,62,80,.64);
  font-style: italic;
}

.kbmb-deuil .kbmb-journal-open-letter{
  margin: 2px 0 10px 0;
  padding: 9px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border: 1px solid rgba(212,175,55,.42) !important;
  background: rgba(44,62,80,.92) !important;
  color: #d4af37 !important;
  box-shadow: 0 10px 20px rgba(44,62,80,.18);
}

.kbmb-deuil .kbmb-journal-open-letter:hover{
  background: rgba(34,50,71,.96) !important;
  transform: translateY(-1px);
}

.kbmb-deuil .kbmb-journal-fulltext-source{
  display: none !important;
}

.kbmb-letter-viewer{
  position: fixed;
  inset: 0;
  z-index: 10030;
  display: none;
}

.kbmb-letter-viewer.is-open{
  display: block;
}

.kbmb-letter-viewer__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(11,18,32,.62);
  backdrop-filter: blur(4px);
}

.kbmb-letter-viewer__dialog{
  position: relative;
  max-width: min(900px, calc(100vw - 28px));
  max-height: calc(100vh - 42px);
  margin: 22px auto;
  padding: 8px;
  overflow: auto;
  animation: kbmbLetterViewerIn .22s ease-out;
}

.kbmb-letter-viewer__close{
  position: sticky;
  top: 0;
  margin-left: auto;
  display: block;
  z-index: 2;
  border: 1px solid rgba(212,175,55,.45);
  border-radius: 999px;
  padding: 9px 16px;
  background: #2c3e50;
  color: #d4af37;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.1;
  box-shadow: 0 10px 24px rgba(15,23,42,.28);
  cursor: pointer;
  transition: transform .12s ease, box-shadow .18s ease, background-color .18s ease;
}

.kbmb-letter-viewer__close:hover{
  background: #22313f;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(15,23,42,.34);
}

.kbmb-letter-viewer__close:active{
  transform: translateY(0);
}

.kbmb-letter-viewer__close:focus-visible{
  outline: 2px solid rgba(212,175,55,.45);
  outline-offset: 2px;
}

.kbmb-letter-viewer__paper{
  position: relative;
  margin-top: 8px;
  padding: 24px 24px 22px 24px;
  border-radius: 18px;
  border: 1px solid rgba(198,182,144,.46);
  background:
    linear-gradient(180deg, rgba(255,255,253,.99), rgba(252,249,242,.98)),
    repeating-linear-gradient(
      180deg,
      rgba(129,102,62,.03) 0,
      rgba(129,102,62,.03) 1px,
      transparent 1px,
      transparent 32px
    );
  box-shadow:
    0 22px 54px rgba(11,18,32,.24),
    inset 0 1px 0 rgba(255,255,255,.94);
}

.kbmb-letter-viewer__head{
  margin-bottom: 12px;
  padding-right: 0;
}

.kbmb-letter-viewer__date{
  font-size: 13px;
  color: rgba(44,62,80,.72);
}

.kbmb-letter-viewer__title{
  margin: 6px 0 0 0;
  color: #3b5872;
  font-family: "Savoye LET", "Segoe Script", "Bradley Hand", "Snell Roundhand", cursive;
  font-size: 34px;
  font-weight: 700;
  line-height: 1.12;
}

.kbmb-letter-viewer__content{
  color: rgba(44,62,80,.96);
  font-size: 18px;
  line-height: 1.74;
  white-space: normal;
}

.kbmb-deuil .kbmb-crossing-help{
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}

@keyframes kbmbLetterViewerIn{
  from{
    opacity: 0;
    transform: translateY(14px) scale(.98);
  }
  to{
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 720px){
  .kbmb-letter-viewer__head{
    padding-right: 0;
  }
}

.kbmb-deuil .kbmb-journal-ritual{
  margin: 0;
  font-size: 13px;
  line-height: 1.35;
  color: rgba(44,62,80,.70);
  font-style: italic;
}

.kbmb-deuil .kbmb-journal-seal-hint{
  margin: 10px 0 4px 0;
  font-size: 13px;
  line-height: 1.4;
  color: rgba(44,62,80,.86);
}

.kbmb-deuil .kbmb-journal-seal-wait{
  margin: 0 0 10px 0;
  font-size: 12px;
  line-height: 1.35;
  color: rgba(44,62,80,.62);
}

.kbmb-deuil .kbmb-journal-seal-form{
  margin-top: 10px;
}

.kbmb-deuil .kbmb-journal-seal-btn[disabled]{
  opacity: .55;
  cursor: not-allowed;
  filter: grayscale(.2);
}

.kbmb-deuil .kbmb-journal-seal-btn.is-unlocked{
  position: relative;
  box-shadow:
    0 10px 26px rgba(44,62,80,.18),
    0 0 0 0 rgba(212,175,55,.18);
  animation: kbSealUnlockPulse 2.8s ease-in-out 2;
}

@keyframes kbSealUnlockPulse{
  0%, 100%{
    transform: translateY(0);
    box-shadow:
      0 10px 26px rgba(44,62,80,.18),
      0 0 0 0 rgba(212,175,55,.12);
  }
  50%{
    transform: translateY(-1px);
    box-shadow:
      0 12px 30px rgba(44,62,80,.20),
      0 0 0 7px rgba(212,175,55,.14);
  }
}

.kbmb-deuil .kbmb-history{
  margin-top: 18px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(44,62,80,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.68), rgba(248,250,252,.58));
  box-shadow: 0 14px 34px rgba(44,62,80,.10);
}

.kbmb-deuil .kbmb-history-title{
  font-size: 21px;
  line-height: 1.1;
  color: #2c3e50;
  margin-bottom: 12px;
}

.kbmb-deuil .kbmb-history-item{
  border-color: rgba(212,175,55,.22);
  background: rgba(255,252,246,.78);
}

.kbmb-deuil .kbmb-journal-card + .kbmb-journal-card{
  margin-top: 22px;
}

/* =========================================================
   DEUIL — PHOTOS DANS LA LETTRE
   ========================================================= */

.kbmb-deuil .kbmb-letter-photos-field{
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(255,255,255,.52);
}

.kbmb-deuil .kbmb-letter-photos-field__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.kbmb-deuil .kbmb-letter-photos-field__head-actions{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.kbmb-deuil .kbmb-letter-photos-field__hint{
  font-size: 12px;
  color: rgba(44,62,80,.70);
}

.kbmb-deuil .kbmb-letter-photos-add{
  white-space: nowrap;
}

.kbmb-deuil .kbmb-letter-photos-native{
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
}

.kbmb-deuil .kbmb-letter-photos-selected{
  margin-top: 10px;
}

.kbmb-deuil .kbmb-letter-photos-empty{
  font-size: 12px;
  color: rgba(44,62,80,.65);
}

.kbmb-deuil .kbmb-letter-photos-list{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(68px, 1fr));
  gap: 10px;
}

.kbmb-deuil .kbmb-letter-photos-item{
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(44,62,80,.12);
  background: rgba(255,255,255,.85);
  box-shadow: 0 10px 20px rgba(44,62,80,.10);
}

.kbmb-deuil .kbmb-letter-photos-item__img{
  display: block;
  width: 100%;
  height: 68px;
  object-fit: cover;
}

@keyframes kbJournalArrivalCycle{
  /* Phase 1 (0 -> 600ms): apparition posée */
  0%{
    opacity: 0;
    transform: translateY(10px);
    border-color: rgba(44,62,80,.17);
    box-shadow:
      0 18px 50px rgba(44,62,80,.14),
      0 0 0 0 rgba(212,175,55,0);
  }
  9%{
    opacity: 1;
    transform: translateY(0);
    border-color: rgba(44,62,80,.19);
    box-shadow:
      0 18px 50px rgba(44,62,80,.14),
      0 0 0 0 rgba(212,175,55,0);
  }

  /* Phase 2: mise en lumière perceptible */
  20%{
    border-color: rgba(212,175,55,.52);
    box-shadow:
      0 25px 60px rgba(44,62,80,.18),
      0 0 0 12px rgba(212,175,55,.20);
  }
  62%{
    border-color: rgba(212,175,55,.46);
    box-shadow:
      0 24px 58px rgba(44,62,80,.17),
      0 0 0 10px rgba(212,175,55,.16);
  }
  82%{
    border-color: rgba(212,175,55,.36);
    box-shadow:
      0 20px 52px rgba(44,62,80,.16),
      0 0 0 5px rgba(212,175,55,.10);
  }

  /* Phase 3: stabilisation */
  100%{
    opacity: 1;
    transform: translateY(0);
    border-color: rgba(44,62,80,.17);
    box-shadow:
      0 18px 50px rgba(44,62,80,.14),
      0 0 0 0 rgba(212,175,55,0);
  }
}

@media (max-width: 560px){
  .kbmb-deuil .kbmb-journal-title,
  .kbmb-deuil .kbmb-journal-card h4,
  .kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
    font-size: 28px;
    line-height: 1.34;
  }

  .kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-title{
    font-size: 28px;
  }

  .kbmb-deuil .kbmb-journal-card{
    margin-left: 38px;
    padding: 30px 16px 14px 16px;
  }
  .kbmb-deuil .kbmb-journal-ribbon{
    left: 12px;
    top: -10px;
    padding: 6px 10px;
    font-size: 11px;
  }
  .kbmb-deuil .kbmb-journal-seal{
    right: 12px;
    width: 30px;
    height: 30px;
  }
  .kbmb-deuil .kbmb-journal-wax{
    top: -14px;
    right: 12px;
    width: 34px;
    height: 34px;
  }
  .kbmb-deuil .kbmb-journal-card::before{
    left: -20px;
  }
  .kbmb-deuil .kbmb-journal-card .kbmb-journal-dot,
  .kbmb-deuil .kbmb-journal-card .kbmb-timeline-dot,
  .kbmb-deuil .kbmb-journal-card .kbmb-dot{
    left: -28px;
  }
}

/* =========================================================
   DEUIL — PHOTOS (Polaroid UX)
   ========================================================= */

.kbmb-deuil .kbmb-section--photos .kbmb-card--photos{
  padding: 28px;
  border-radius: 26px;
  border: 1px solid rgba(178, 198, 237, .26);
  background:
    radial-gradient(circle at 14% 18%, rgba(255,255,255,.92) 0 1px, transparent 1.2px),
    radial-gradient(circle at 26% 40%, rgba(255,255,255,.76) 0 1px, transparent 1.2px),
    radial-gradient(circle at 38% 16%, rgba(255,255,255,.84) 0 1px, transparent 1.2px),
    radial-gradient(circle at 53% 33%, rgba(255,255,255,.70) 0 1px, transparent 1.2px),
    radial-gradient(circle at 66% 14%, rgba(255,255,255,.82) 0 1px, transparent 1.2px),
    radial-gradient(circle at 78% 42%, rgba(255,255,255,.74) 0 1px, transparent 1.2px),
    radial-gradient(circle at 91% 24%, rgba(255,255,255,.88) 0 1px, transparent 1.2px),
    radial-gradient(120% 130% at 22% -10%, rgba(146,173,232,.24), rgba(146,173,232,0) 58%),
    radial-gradient(120% 130% at 84% 14%, rgba(202,182,120,.18), rgba(202,182,120,0) 62%),
    linear-gradient(180deg, rgba(24,31,53,.95), rgba(14,19,35,.96));
  box-shadow:
    0 24px 52px rgba(7,10,20,.34),
    inset 0 1px 0 rgba(255,255,255,.08);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photos-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 26px 22px;
  align-items: start;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
  width: 100%;
  max-width: 330px;
  margin: 0 auto;
  position: relative;
  transform: translateY(-2px) rotate(-1.6deg);
  transition: transform .14s ease, box-shadow .14s ease, opacity .14s ease;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(2n){
  transform: translateY(10px) rotate(1.3deg);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(3n){
  transform: translateY(-8px) rotate(-0.7deg);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(4n){
  transform: translateY(16px) rotate(2deg);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(5n){
  transform: translateY(-14px) rotate(-1.1deg);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::before{
  content: "";
  position: absolute;
  top: -10px;
  left: 50%;
  width: 26px;
  height: 16px;
  transform: translateX(-50%);
  border-radius: 5px 5px 7px 7px;
  border: 1px solid rgba(199,179,122,.52);
  background: linear-gradient(180deg, rgba(255,249,219,.96), rgba(224,201,135,.9));
  box-shadow: 0 4px 8px rgba(15,20,35,.25);
  z-index: 3;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::after{
  content: "";
  position: absolute;
  top: -5px;
  left: 50%;
  width: 6px;
  height: 6px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: rgba(58,71,98,.68);
  z-index: 4;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-inner{
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(209,188,129,.32);
  background: #fffef9;
  box-shadow: 0 18px 34px rgba(66,52,20,.18);
  padding: 0 0 14px 0;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-inner::before,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-inner::after,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-image::before,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-image::after{
  content: none !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:hover{
  transform: translateY(-5px) rotate(.2deg);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-image{
  margin: 0;
  padding: 0;
  line-height: 0;
  background: #fffef9;
}

.kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
  border-radius: 0;
  display: block;
  width: 100%;
  height: 252px;
  object-fit: cover;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-caption{
  padding: 10px 12px 4px 12px;
  background: transparent;
  border-top: 0;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-form{
  display: grid;
  gap: 8px;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-label{
  font-size: 11px;
  letter-spacing: .15px;
  color: rgba(44,62,80,.66);
  text-transform: uppercase;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-input{
  border: 0;
  border-bottom: 1px dashed rgba(44,62,80,.25);
  border-radius: 0;
  background: transparent;
  padding: 3px 2px 5px 2px;
  font-family: "Savoye LET", "Segoe Script", "Bradley Hand", "Snell Roundhand", cursive;
  font-size: 28px;
  line-height: 1.2;
  color: #405a72;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-input:focus{
  outline: none;
  border-bottom-color: rgba(212,175,55,.65);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions{
  display: grid;
  margin-top: 10px;
  justify-items: start;
  min-height: 38px;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn{
  border-radius: 999px !important;
  padding: 7px 13px;
  font-size: 11px !important;
  font-weight: 500;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
}

.kbmb-deuil .kbmb-section--photos .kbmb-btn--danger{
  border: 1px solid rgba(223,183,88,.46);
  background: rgba(42,57,84,.82);
  color: #d8bc6a;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:hover .kbmb-photo-polaroid-actions .kb-btn,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:focus-within .kbmb-photo-polaroid-actions .kb-btn{
  opacity: .92;
  visibility: visible;
  transform: translateY(0);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-upload{
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(178, 198, 237, .22);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-limit{
  color: rgba(224, 233, 255, .82);
  margin: 0 0 10px 0;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-limit:last-child{
  color: rgba(198, 210, 238, .72);
  font-size: 13px;
}

@media (max-width: 720px){
  .kbmb-deuil .kbmb-section--photos .kbmb-photos-grid{
    grid-template-columns: 1fr;
  }
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
    max-width: 300px;
    transform: rotate(0deg);
  }
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::before,
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::after{
    display: none;
  }
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn{
    opacity: .92;
    visibility: visible;
    transform: none;
  }
  .kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
    height: 268px;
  }
}
/* =========================================================
   DEUIL — Harmonisation boutons (bleu + texte or)
   Scope: uniquement widget Deuil
   Ajustements :
   - bleu plus « franc » (sans overlay/gradient)
   - boutons plus compacts (padding + typo)
   ========================================================= */

.kbmb-deuil .kb-btn,
.kbmb-deuil .kbmb-btn,
.kbmb-deuil button,
.kbmb-deuil input[type="submit"],
.kbmb-deuil input[type="button"],
.kbmb-deuil a.kb-btn,
.kbmb-deuil a.kbmb-btn {
  /* Couleurs (bleu franc + or) */
  background-color: #2c3e50 !important;
  background-image: none !important;
  color: #d4af37 !important;

  /* Contours / forme */
  border: 1px solid rgba(212, 175, 55, 0.35) !important;
  border-radius: 999px !important;

  /* Taille (plus compact) */
  padding: 8px 16px !important;
  font-size: 13px !important;
  line-height: 1.15 !important;
  font-weight: 600 !important;

  /* Rendu (évite l'effet « gris/filtré ») */
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;

  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.32) !important;
  text-decoration: none !important;
  transform: translateZ(0);
}

/* Hover */
.kbmb-deuil .kb-btn:hover,
.kbmb-deuil .kbmb-btn:hover,
.kbmb-deuil button:hover,
.kbmb-deuil input[type="submit"]:hover,
.kbmb-deuil input[type="button"]:hover,
.kbmb-deuil a.kb-btn:hover,
.kbmb-deuil a.kbmb-btn:hover {
  background-color: #22313f !important;
  background-image: none !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.42) !important;
  transform: translateY(-1px);
}

/* Active */
.kbmb-deuil .kb-btn:active,
.kbmb-deuil .kbmb-btn:active,
.kbmb-deuil button:active,
.kbmb-deuil input[type="submit"]:active,
.kbmb-deuil input[type="button"]:active,
.kbmb-deuil a.kb-btn:active,
.kbmb-deuil a.kbmb-btn:active {
  transform: translateY(0);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.30) !important;
}

/* Si certains boutons sont rendus plus grands par Elementor / thèmes */
.kbmb-deuil .kb-btn,
.kbmb-deuil .kbmb-btn {
  min-height: 0 !important;
}

/* Optionnel : bouton natif "Choisir le fichier" (input[type=file]) */
.kbmb-deuil input[type="file"]::file-selector-button {
  background-color: #2c3e50 !important;
  background-image: none !important;
  color: #d4af37 !important;
  border: 1px solid rgba(212, 175, 55, 0.35) !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  line-height: 1.15 !important;
  font-weight: 600 !important;
  cursor: pointer;
  opacity: 1 !important;
  filter: none !important;
}
.kbmb-deuil input[type="file"]::file-selector-button:hover {
  background-color: #22313f !important;
  background-image: none !important;
}

/* =========================================================
   DEUIL — UX QUOTAS (5 lettres déposées / 30j)
   Objectif : rendre la règle lisible AU BON MOMENT
   - micro-texte près des actions
   - état disabled lisible (sans casser le style global)
   - badge / info discrète dans Repères
   ========================================================= */

/* Micro-texte quota (près des boutons / zone actions) */
.kbmb-deuil .kbmb-quota-hint{
  margin-top: 8px;
  font-size: 12.5px;
  line-height: 1.35;
  color: rgba(44,62,80,.70);
}

.kbmb-deuil .kbmb-quota-hint strong{
  color: rgba(44,62,80,.92);
  font-weight: 700;
}

.kbmb-deuil .kbmb-limit-msg{
  margin: 0;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(44,62,80,.14);
  background: rgba(255,255,255,.72);
  color: #2c3e50;
  font-size: 13px;
  line-height: 1.45;
}

.kbmb-deuil .kbmb-limit-msg strong{
  font-weight: 700;
}

/* Variante : note d’info (ne doit pas ressembler à une erreur) */
.kbmb-deuil .kbmb-quota-hint--info{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(44,62,80,.05);
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.kbmb-deuil .kbmb-quota-hint--info::before{
  content: "ℹ";
  font-size: 12px;
  opacity: .75;
}

/* État disabled des boutons (quota atteint) — override du style global boutons */
.kbmb-deuil button[disabled],
.kbmb-deuil .kb-btn[disabled],
.kbmb-deuil .kbmb-btn[disabled],
.kbmb-deuil input[type="submit"][disabled],
.kbmb-deuil input[type="button"][disabled]{
  cursor: not-allowed !important;
  opacity: .55 !important;
  box-shadow: none !important;
  transform: none !important;
  background-color: rgba(44,62,80,.22) !important;
  color: rgba(44,62,80,.55) !important;
  border-color: rgba(44,62,80,.14) !important;
}

.kbmb-deuil button[disabled]:hover,
.kbmb-deuil .kb-btn[disabled]:hover,
.kbmb-deuil .kbmb-btn[disabled]:hover,
.kbmb-deuil input[type="submit"][disabled]:hover,
.kbmb-deuil input[type="button"][disabled]:hover{
  transform: none !important;
  box-shadow: none !important;
  background-color: rgba(44,62,80,.22) !important;
}

/* Badge discret (ex: "2/3") si utilisé dans le texte */
.kbmb-deuil .kbmb-quota-badge{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.25);
  background: rgba(212,175,55,.10);
  color: rgba(44,62,80,.85);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .2px;
}

/* Icône helper (réutilisable dans Repères, titres de section, etc.) */
.kbmb-deuil .kbmb-info{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 1px solid rgba(44,62,80,.14);
  background: rgba(255,255,255,.60);
  color: rgba(44,62,80,.70);
  font-size: 11px;
  line-height: 1;
  cursor: help;
  vertical-align: middle;
}

.kbmb-deuil .kbmb-reperes__label .kbmb-info,
.kbmb-deuil .kbmb-section-title .kbmb-info{
  margin-left: 6px;
}

/* Aide / tooltip basique via title : améliorer la lecture au survol */
.kbmb-deuil .kbmb-info:hover{
  border-color: rgba(212,175,55,.35);
  box-shadow: 0 10px 22px rgba(44,62,80,.10);
}

/* Séparation légère entre actions et repères si nécessaire */
.kbmb-deuil .kbmb-form-actions + .kbmb-reperes{
  margin-top: 16px;
}

/* =========================================================
   DEUIL — PASSE V2 MÉMORIELLE
   - conserve la structure actuelle
   - réinstalle une base crème / perle légèrement brumeuse
   - différencie les sceaux selon l'état de la lettre
   ========================================================= */

.kbmb-deuil{
  --kbmb-deuil-bg-cream: rgba(250, 246, 239, .96);
  --kbmb-deuil-bg-pearl: rgba(255, 252, 247, .94);
  --kbmb-deuil-bg-mist: rgba(171, 181, 197, .14);
  --kbmb-deuil-paper-border: rgba(108, 103, 95, .14);
  --kbmb-deuil-paper-shadow: 0 22px 52px rgba(98, 90, 75, .10);
  --kbmb-seal-slate-100: #f5f8fb;
  --kbmb-seal-slate-200: #d8e0e8;
  --kbmb-seal-slate-400: #97a8b8;
  --kbmb-seal-slate-600: #627487;
  --kbmb-seal-gold-100: #fff7d8;
  --kbmb-seal-gold-200: #efd691;
  --kbmb-seal-gold-400: #d5af4d;
  --kbmb-seal-gold-600: #9e7a2a;
}

.kbmb-deuil.kbmb-widget.kbmb-glass{
  background:
    radial-gradient(60% 52% at 12% 8%, rgba(214, 190, 121, .16), transparent 62%),
    radial-gradient(44% 40% at 88% 14%, rgba(176, 188, 210, .14), transparent 64%),
    radial-gradient(40% 28% at 52% 100%, rgba(186, 170, 145, .10), transparent 72%),
    linear-gradient(136deg, rgba(255, 252, 247, .95) 0%, rgba(248, 243, 235, .94) 54%, rgba(253, 250, 244, .93) 100%);
  border-color: rgba(255, 255, 255, .72);
  box-shadow:
    0 28px 74px rgba(98, 86, 63, .12),
    0 0 0 1px rgba(189, 173, 141, .06);
}

.kbmb-deuil.kbmb-widget.kbmb-glass::before{
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, .78), transparent 54%),
    radial-gradient(circle at 76% 16%, rgba(201, 212, 230, .30), transparent 58%),
    radial-gradient(circle at 42% 70%, rgba(214, 190, 121, .18), transparent 62%);
  opacity: .82;
}

.kbmb-deuil.kbmb-widget.kbmb-glass::after{
  background:
    radial-gradient(circle at 72% 64%, rgba(255, 255, 255, .40), transparent 56%),
    radial-gradient(circle at 26% 74%, rgba(180, 193, 214, .20), transparent 62%),
    radial-gradient(circle at 56% 36%, rgba(235, 219, 178, .16), transparent 66%);
  opacity: .62;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header,
.kbmb-deuil .kbmb-reperes,
.kbmb-deuil .kbmb-history,
.kbmb-deuil .kbmb-draft-item,
.kbmb-deuil .kbmb-letter-photos-field{
  border-color: rgba(148, 138, 120, .14);
  background:
    radial-gradient(85% 140% at 0% 0%, rgba(214, 190, 121, .08), transparent 58%),
    radial-gradient(95% 140% at 100% 12%, rgba(176, 188, 210, .08), transparent 62%),
    linear-gradient(180deg, rgba(255, 254, 251, .78), rgba(247, 241, 232, .64));
  box-shadow: 0 18px 42px rgba(95, 85, 68, .09);
}

.kbmb-deuil .kbmb-journal-card{
  border-color: var(--kbmb-deuil-paper-border);
  background:
    radial-gradient(100% 140% at 0% 0%, rgba(214, 190, 121, .10), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(176, 188, 210, .10), transparent 60%),
    linear-gradient(180deg, rgba(255, 253, 249, .88), rgba(246, 240, 231, .74));
  box-shadow: var(--kbmb-deuil-paper-shadow);
}

.kbmb-deuil .kbmb-journal-card::after{
  border-color: rgba(207, 192, 160, .18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .22), rgba(255, 255, 255, .06)),
    radial-gradient(80% 120% at 0% 0%, rgba(212, 175, 55, .07), transparent 62%),
    radial-gradient(90% 140% at 100% 20%, rgba(132, 151, 176, .06), transparent 62%);
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed){
  border-color: rgba(104, 119, 136, .18);
  box-shadow: 0 22px 50px rgba(83, 97, 117, .12);
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-ribbon{
  border-color: rgba(105, 123, 144, .28);
  background: linear-gradient(180deg, #879aac 0%, #687d91 100%);
  color: rgba(248, 243, 234, .96);
  box-shadow: 0 12px 24px rgba(86, 101, 119, .18);
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal{
  border-color: rgba(102, 120, 140, .42);
  background: radial-gradient(circle at 35% 30%, var(--kbmb-seal-slate-100) 0%, var(--kbmb-seal-slate-200) 34%, var(--kbmb-seal-slate-400) 72%, var(--kbmb-seal-slate-600) 100%);
  color: rgba(252, 248, 242, .94);
  box-shadow:
    0 10px 22px rgba(94, 110, 129, .16),
    0 0 0 6px rgba(124, 140, 159, .10);
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal span{
  color: rgba(251, 247, 240, .94);
  text-shadow: 0 1px 0 rgba(77, 91, 108, .26);
}

.kbmb-deuil .kbmb-journal-card.is-sealed{
  border-color: rgba(191, 163, 101, .22);
  background:
    radial-gradient(110% 150% at 0% 0%, rgba(218, 187, 115, .12), transparent 56%),
    radial-gradient(130% 140% at 100% 12%, rgba(255, 255, 255, .20), transparent 62%),
    linear-gradient(180deg, rgba(255, 252, 246, .89), rgba(247, 240, 228, .76));
  box-shadow: 0 22px 52px rgba(131, 108, 64, .13);
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-ribbon{
  border-color: rgba(198, 169, 104, .30);
  background: linear-gradient(180deg, rgba(238, 228, 195, .98) 0%, rgba(214, 191, 136, .96) 100%);
  color: #6f5a31;
  box-shadow: 0 12px 24px rgba(165, 136, 78, .16);
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
  border-color: rgba(168, 135, 58, .56);
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 247, 215, .58) 0%, rgba(255, 247, 215, .18) 28%, transparent 40%),
    radial-gradient(circle at 56% 62%, var(--kbmb-seal-gold-200) 0%, var(--kbmb-seal-gold-400) 58%, var(--kbmb-seal-gold-600) 100%);
  box-shadow:
    0 12px 24px rgba(156, 123, 46, .26),
    0 0 0 7px rgba(212, 175, 55, .11),
    inset 0 2px 4px rgba(255, 250, 232, .34),
    inset 0 -3px 4px rgba(118, 88, 27, .16);
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax::before{
  border-color: rgba(255, 244, 210, .42);
  box-shadow: inset 0 0 0 2px rgba(160, 125, 47, .18);
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax::after{
  color: rgba(255, 248, 231, .88);
  text-shadow: 0 1px 0 rgba(122, 91, 26, .30);
}

.kbmb-deuil .kbmb-journal-ritual,
.kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle,
.kbmb-deuil .kbmb-reperes__label,
.kbmb-deuil .kbmb-draft-date,
.kbmb-deuil .kbmb-letter-photos-field__hint{
  color: rgba(72, 82, 92, .72);
}

/* =========================================================
   DEUIL — V2.1 / RUPTURE VISUELLE
   Override final pour faire basculer le rendu vers la maquette.
   ========================================================= */

.kbmb-deuil.kbmb-widget.kbmb-glass{
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  padding: 22px 22px 26px !important;
  border-radius: 30px !important;
  background:
    radial-gradient(64% 54% at 10% 6%, rgba(233, 238, 242, .42), transparent 62%),
    radial-gradient(48% 42% at 86% 14%, rgba(229, 233, 238, .30), transparent 64%),
    radial-gradient(42% 30% at 52% 100%, rgba(242, 240, 235, .28), transparent 72%),
    linear-gradient(136deg, rgba(247, 245, 241, .97) 0%, rgba(244, 241, 234, .96) 46%, rgba(250, 250, 248, .95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, .74) !important;
  box-shadow:
    0 32px 78px rgba(93, 103, 114, .10),
    0 0 0 1px rgba(189, 197, 204, .06) !important;
}

.kbmb-deuil.kbmb-widget.kbmb-glass::before{
  opacity: .86 !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, .82), transparent 54%),
    radial-gradient(circle at 76% 16%, rgba(225, 232, 238, .34), transparent 58%),
    radial-gradient(circle at 42% 70%, rgba(232, 236, 239, .18), transparent 62%) !important;
}

.kbmb-deuil.kbmb-widget.kbmb-glass::after{
  opacity: .58 !important;
  background:
    radial-gradient(circle at 72% 64%, rgba(255, 255, 255, .42), transparent 56%),
    radial-gradient(circle at 26% 74%, rgba(228, 232, 236, .22), transparent 62%),
    radial-gradient(circle at 56% 36%, rgba(241, 243, 246, .18), transparent 66%) !important;
}

.kbmb-deuil-inner.kbmb-deuil--v2{
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding-top: 8px !important;
}

.kbmb-deuil .kbmb-section{
  margin-top: 30px !important;
}

.kbmb-deuil .kbmb-section:first-child{
  margin-top: 0 !important;
}

.kbmb-deuil .kbmb-section-header{
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 18px !important;
  padding: 10px 4px 12px !important;
  margin-bottom: 14px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-section-header::before,
.kbmb-deuil .kbmb-section-header::after{
  content: "" !important;
  flex: 1 1 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, rgba(164, 154, 139, 0), rgba(164, 154, 139, .56), rgba(164, 154, 139, 0)) !important;
  opacity: .95 !important;
}

.kbmb-deuil .kbmb-section-header > div:first-child{
  flex: 0 0 auto !important;
  min-width: clamp(280px, 42vw, 560px) !important;
  text-align: center !important;
}

.kbmb-deuil .kbmb-section-meta{
  position: absolute !important;
  right: 0 !important;
  top: 2px !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: rgba(94, 99, 104, .60) !important;
}

.kbmb-deuil .kbmb-section-title{
  font-family: "Cormorant Garamond", "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif !important;
  font-size: clamp(18px, 2vw, 26px) !important;
  line-height: 1.06 !important;
  letter-spacing: .02em !important;
  color: #314257 !important;
}

.kbmb-deuil .kbmb-section-subtitle{
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: rgba(63, 72, 83, .72) !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-header{
  padding-top: 18px !important;
  margin-bottom: 16px !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header,
.kbmb-deuil .kbmb-section--photos .kbmb-section-header{
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px 18px !important;
  padding: 0 0 10px !important;
  margin-bottom: 14px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header::before,
.kbmb-deuil .kbmb-section--journal .kbmb-section-header::after,
.kbmb-deuil .kbmb-section--photos .kbmb-section-header::before,
.kbmb-deuil .kbmb-section--photos .kbmb-section-header::after{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header > div:first-child,
.kbmb-deuil .kbmb-section--photos .kbmb-section-header > div:first-child{
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
  gap: 0 !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title,
.kbmb-deuil .kbmb-section--photos .kbmb-section-title{
  font-family: "Cormorant Garamond", "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif !important;
  font-size: clamp(18px, 2vw, 24px) !important;
  line-height: 1.05 !important;
  letter-spacing: .01em !important;
  color: #374150 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::after,
.kbmb-deuil .kbmb-section--photos .kbmb-section-title::after{
  content: "" !important;
  display: block !important;
  flex: 1 1 auto !important;
  min-width: clamp(48px, 18vw, 240px) !important;
  height: 1px !important;
  margin: 0 14px 0 16px !important;
  background: rgba(120, 105, 85, .18) !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle,
.kbmb-deuil .kbmb-section--photos .kbmb-section-subtitle{
  margin: 0 !important;
  max-width: 40ch !important;
  text-align: right !important;
  font-size: 12.5px !important;
  line-height: 1.45 !important;
  color: #7A746C !important;
  font-style: italic !important;
  justify-self: end !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-section-meta{
  position: static !important;
  justify-self: end !important;
  align-self: center !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
  color: #7D776F !important;
  opacity: .68 !important;
}

.kbmb-deuil .kbmb-card--journal{
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-card--letters{
  padding: 22px 20px 18px !important;
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .90), rgba(250, 246, 239, .84)) !important;
  border: 1px solid rgba(170, 158, 139, .20) !important;
  box-shadow: 0 18px 40px rgba(96, 86, 69, .09) !important;
  backdrop-filter: blur(14px) !important;
}

.kbmb-deuil .kbmb-input--subject{
  width: 100% !important;
  margin: 10px 0 14px !important;
  padding: 12px 14px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(168, 157, 140, .30) !important;
  background: rgba(255, 255, 255, .84) !important;
  color: #3a4651 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .92) !important;
}

.kbmb-deuil .kbmb-textarea{
  min-height: 240px !important;
  padding: 18px 20px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(168, 157, 140, .30) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(251, 248, 242, .88)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .92),
    0 10px 24px rgba(100, 88, 72, .06) !important;
  font-size: 15px !important;
  line-height: 1.74 !important;
}

.kbmb-deuil .kbmb-letter-photos-field{
  margin-top: 14px !important;
  padding: 14px 14px 12px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(170, 158, 139, .18) !important;
  background: rgba(255, 255, 255, .54) !important;
}

.kbmb-deuil .kbmb-form-actions{
  margin-top: 14px !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}

.kbmb-deuil .kbmb-form-actions .kb-btn{
  padding: 9px 18px !important;
}

.kbmb-deuil .kbmb-reperes{
  margin-top: 16px !important;
  padding: 16px 18px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(170, 158, 139, .18) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .72), rgba(247, 243, 236, .64)) !important;
  box-shadow: 0 12px 28px rgba(92, 82, 67, .08) !important;
}

.kbmb-deuil .kbmb-reperes__title{
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
}

.kbmb-deuil .kbmb-reperes__grid{
  gap: 10px !important;
}

.kbmb-deuil .kbmb-reperes__item{
  padding: 12px 14px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(170, 158, 139, .14) !important;
  background: rgba(255, 250, 244, .58) !important;
}

.kbmb-deuil .kbmb-reperes__value{
  font-size: 17px !important;
}

.kbmb-deuil .kbmb-journal{
  margin-top: 20px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 248px !important;
  gap: 18px !important;
  align-items: start !important;
}

.kbmb-deuil .kbmb-journal-list{
  padding-left: 24px !important;
}

.kbmb-deuil .kbmb-journal-list::before{
  left: 8px !important;
  top: 6px !important;
  bottom: 8px !important;
  width: 1px !important;
  background: linear-gradient(180deg, rgba(212, 175, 55, 0), rgba(212, 175, 55, .44), rgba(176, 183, 194, .24), rgba(212, 175, 55, 0)) !important;
}

.kbmb-deuil .kbmb-journal-item{
  position: relative !important;
  margin: 0 0 18px !important;
  padding: 24px 22px 18px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(168, 154, 132, .16) !important;
  background:
    radial-gradient(100% 120% at 0% 0%, rgba(214, 190, 121, .10), transparent 56%),
    linear-gradient(180deg, rgba(255, 253, 248, .96), rgba(248, 242, 233, .84)) !important;
  box-shadow: 0 14px 30px rgba(103, 91, 77, .08) !important;
  backdrop-filter: blur(10px) !important;
}

.kbmb-deuil .kbmb-journal-item::before{
  left: -24px !important;
  top: 24px !important;
  width: 9px !important;
  height: 9px !important;
  border-radius: 999px !important;
  box-shadow: 0 0 0 6px rgba(212, 175, 55, .12) !important;
}

.kbmb-deuil .kbmb-journal-ribbon{
  left: 18px !important;
  top: -10px !important;
  padding: 5px 11px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(237, 225, 187, .96), rgba(221, 201, 144, .92)) !important;
  color: #6d5a35 !important;
  box-shadow: 0 10px 18px rgba(126, 108, 64, .12) !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal{
  top: -14px !important;
  right: 16px !important;
  width: 32px !important;
  height: 32px !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
  top: -14px !important;
  right: 16px !important;
  width: 32px !important;
  height: 32px !important;
}

.kbmb-deuil .kbmb-journal-title,
.kbmb-deuil .kbmb-journal-card h4,
.kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
  margin: 10px 0 8px !important;
  font-size: clamp(24px, 2.4vw, 30px) !important;
  line-height: 1.18 !important;
  color: #3d546b !important;
}

.kbmb-deuil .kbmb-journal-excerpt{
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: rgba(52, 64, 76, .82) !important;
}

.kbmb-deuil .kbmb-journal-open-letter{
  padding: 8px 13px !important;
  font-size: 12px !important;
  border-radius: 999px !important;
  background: rgba(60, 72, 85, .96) !important;
  color: #e7d38e !important;
}

.kbmb-deuil .kbmb-history{
  margin-top: 0 !important;
  padding: 14px 14px 16px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(170, 158, 139, .16) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .82), rgba(247, 243, 236, .68)) !important;
  box-shadow: 0 12px 28px rgba(106, 96, 81, .08) !important;
}

.kbmb-deuil .kbmb-history-title{
  margin-bottom: 10px !important;
  font-size: 18px !important;
}

.kbmb-deuil .kbmb-history-item{
  padding: 12px 14px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(170, 158, 139, .12) !important;
  background: rgba(255, 250, 244, .70) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-card--photos{
  padding: 18px 18px 20px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, .08) !important;
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 255, 255, .06), transparent 26%),
    radial-gradient(circle at 84% 16%, rgba(255, 218, 145, .06), transparent 22%),
    linear-gradient(180deg, rgba(39, 43, 60, .97), rgba(23, 27, 42, .99)) !important;
  box-shadow:
    0 24px 48px rgba(18, 22, 35, .30),
    inset 0 1px 0 rgba(255, 255, 255, .05) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photos-grid{
  grid-template-columns: repeat(auto-fill, minmax(170px, 190px)) !important;
  gap: 18px !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
  max-width: 190px !important;
  border-radius: 14px !important;
  transform: translateY(0) rotate(-1.8deg) !important;
  background: rgba(255, 255, 255, .97) !important;
  box-shadow: 0 16px 34px rgba(6, 8, 14, .28) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(2n){
  transform: translateY(8px) rotate(1.2deg) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(3n){
  transform: translateY(-6px) rotate(-.8deg) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid:nth-child(4n){
  transform: translateY(12px) rotate(1.8deg) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::before{
  top: -12px !important;
  width: 24px !important;
  height: 14px !important;
  border-radius: 5px 5px 6px 6px !important;
  box-shadow: 0 5px 10px rgba(0, 0, 0, .28) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-inner{
  border-radius: 10px !important;
}

.kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
  height: 230px !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-caption{
  padding: 10px 12px 4px 12px !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-label{
  color: rgba(75, 92, 110, .62) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-input{
  font-size: 26px !important;
  color: #405a72 !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions{
  margin-top: 8px !important;
  min-height: 34px !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-btn--danger{
  background: rgba(58, 70, 88, .88) !important;
  border: 1px solid rgba(190, 160, 78, .38) !important;
  color: #d8bc6a !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-upload{
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(255, 255, 255, .08) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-limit{
  color: rgba(235, 241, 249, .72) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-limit:last-child{
  color: rgba(197, 208, 226, .70) !important;
}

@media (max-width: 1080px){
  .kbmb-deuil.kbmb-widget.kbmb-glass{
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 22px 18px 26px !important;
  }

  .kbmb-deuil-inner.kbmb-deuil--v2{
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .kbmb-deuil .kbmb-journal{
    grid-template-columns: minmax(0, 1fr) 228px !important;
  }

  .kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
    height: 218px !important;
  }
}

@media (max-width: 720px){
  .kbmb-deuil .kbmb-section-header{
    display: block !important;
    padding: 8px 0 10px !important;
  }

  .kbmb-deuil .kbmb-section-header::before,
  .kbmb-deuil .kbmb-section-header::after{
    display: none !important;
  }

  .kbmb-deuil .kbmb-section-header > div:first-child{
    min-width: 0 !important;
    width: 100% !important;
  }

  .kbmb-deuil .kbmb-section-meta{
    position: static !important;
    margin-top: 4px !important;
    text-align: right !important;
  }

  .kbmb-deuil .kbmb-journal{
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .kbmb-deuil .kbmb-history{
    margin-top: 12px !important;
  }

  .kbmb-deuil .kbmb-section--photos .kbmb-photos-grid{
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
    max-width: 100% !important;
    transform: rotate(0deg) !important;
  }

  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::before,
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid::after{
    display: none !important;
  }

  .kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
    height: 260px !important;
  }
}

/* =========================================================
   DEUIL — AJUSTEMENTS UX/UI FINALS
   Corrections ciblées demandées: meta, titres, relief, sceaux,
   et bloc "Dernières arrivées".
   ========================================================= */

.kbmb-deuil .kbmb-section-meta{
  display: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title,
.kbmb-deuil .kbmb-section--photos .kbmb-section-title{
  font-size: clamp(20px, 2.15vw, 27px) !important;
  line-height: 1.04 !important;
  letter-spacing: .015em !important;
}

.kbmb-deuil .kbmb-journal-item{
  border-color: rgba(168, 154, 132, .18) !important;
  box-shadow:
    0 18px 42px rgba(78, 68, 56, .12),
    0 1px 0 rgba(255, 255, 255, .72) inset,
    0 0 0 1px rgba(170, 158, 139, .06) !important;
}

.kbmb-deuil .kbmb-journal-card{
  box-shadow:
    0 22px 52px rgba(84, 73, 60, .11),
    0 1px 0 rgba(255, 255, 255, .62) inset !important;
}

.kbmb-deuil .kbmb-journal-card::after{
  inset: 8px !important;
  border-color: rgba(196, 180, 153, .20) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .26), rgba(255, 255, 255, .08)),
    radial-gradient(80% 120% at 0% 0%, rgba(212, 175, 55, .08), transparent 60%),
    radial-gradient(90% 140% at 100% 20%, rgba(86, 199, 255, .05), transparent 62%) !important;
  opacity: .92 !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal{
  width: clamp(38px, 3.2vw, 42px) !important;
  height: clamp(38px, 3.2vw, 42px) !important;
  top: -18px !important;
  right: 15px !important;
  box-shadow:
    0 14px 28px rgba(94, 110, 129, .18),
    0 0 0 7px rgba(124, 140, 159, .10),
    inset 0 1px 0 rgba(255, 255, 255, .45) !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal span{
  font-size: 15px !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
  width: clamp(40px, 3.4vw, 46px) !important;
  height: clamp(40px, 3.4vw, 46px) !important;
  top: -18px !important;
  right: 15px !important;
  box-shadow:
    0 14px 28px rgba(156, 123, 46, .26),
    0 0 0 7px rgba(212, 175, 55, .11),
    inset 0 2px 4px rgba(255, 250, 232, .34),
    inset 0 -3px 4px rgba(118, 88, 27, .16) !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax::after{
  font-size: 11px !important;
}

.kbmb-deuil .kbmb-history{
  padding: 16px 14px 15px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(170, 158, 139, .14) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(247, 243, 236, .70)) !important;
  box-shadow:
    0 14px 32px rgba(92, 82, 67, .08),
    0 1px 0 rgba(255, 255, 255, .72) inset !important;
}

.kbmb-deuil .kbmb-history-title{
  margin-bottom: 12px !important;
  font-family: "Cormorant Garamond", "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif !important;
  font-size: 16px !important;
  line-height: 1.08 !important;
  letter-spacing: .01em !important;
  color: #3E4652 !important;
}

.kbmb-deuil .kbmb-history-list{
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

.kbmb-deuil .kbmb-history-item{
  padding: 11px 2px 10px !important;
  border-top: 1px solid rgba(170, 158, 139, .10) !important;
  background: transparent !important;
}

.kbmb-deuil .kbmb-history-item:first-child{
  border-top: 0 !important;
  padding-top: 0 !important;
}

.kbmb-deuil .kbmb-history-when{
  margin-bottom: 4px !important;
  font-size: 11px !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: rgba(122, 116, 108, .80) !important;
}

.kbmb-deuil .kbmb-history-text{
  font-size: 13px !important;
  line-height: 1.48 !important;
  color: rgba(54, 65, 78, .90) !important;
}

.kbmb-deuil .kbmb-history-subject{
  margin-top: 4px !important;
  font-size: 13px !important;
  line-height: 1.42 !important;
  font-weight: 600 !important;
  color: #394554 !important;
}

/* =========================================================
   DEUIL — MICRO-AJUSTEMENTS FINAUX
   Titres, journal, bloc d’arrivées et séparateur photo.
   ========================================================= */

.kbmb-deuil .kbmb-journal-item{
  padding: 25px 22px 19px !important;
  border-color: rgba(171, 157, 136, .20) !important;
  background:
    radial-gradient(100% 120% at 0% 0%, rgba(214, 190, 121, .12), transparent 56%),
    radial-gradient(120% 140% at 100% 0%, rgba(176, 188, 210, .08), transparent 60%),
    linear-gradient(180deg, rgba(255, 253, 248, .98), rgba(248, 242, 233, .86)) !important;
  box-shadow:
    0 16px 36px rgba(78, 68, 56, .10),
    0 1px 0 rgba(255, 255, 255, .86) inset,
    0 0 0 1px rgba(170, 158, 139, .06) !important;
}

.kbmb-deuil .kbmb-journal-card{
  box-shadow:
    0 24px 58px rgba(84, 73, 60, .12),
    0 1px 0 rgba(255, 255, 255, .70) inset,
    0 0 0 1px rgba(255, 255, 255, .24) inset !important;
}

.kbmb-deuil .kbmb-journal-card::after{
  inset: 8px !important;
  border-color: rgba(196, 180, 153, .22) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .28), rgba(255, 255, 255, .08)),
    radial-gradient(80% 120% at 0% 0%, rgba(212, 175, 55, .09), transparent 60%),
    radial-gradient(90% 140% at 100% 20%, rgba(86, 199, 255, .05), transparent 62%) !important;
  opacity: .96 !important;
}

.kbmb-deuil .kbmb-journal-card::before{
  left: -25px !important;
  top: -18px !important;
  bottom: -18px !important;
  width: 5px !important;
  opacity: .98 !important;
  background: linear-gradient(
    to bottom,
    rgba(212, 175, 55, 0),
    rgba(212, 175, 55, .62),
    rgba(176, 183, 194, .28),
    rgba(212, 175, 55, 0)
  ) !important;
}

.kbmb-deuil .kbmb-journal-title,
.kbmb-deuil .kbmb-journal-card h4,
.kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
  margin: 9px 0 7px !important;
  font-size: clamp(25px, 2.45vw, 31px) !important;
  line-height: 1.16 !important;
}

.kbmb-deuil .kbmb-journal-excerpt{
  margin: 0 0 7px 0 !important;
  font-size: 15px !important;
  line-height: 1.64 !important;
}

.kbmb-deuil .kbmb-journal-excerpt--sealed{
  color: rgba(44, 62, 80, .66) !important;
}

.kbmb-deuil .kbmb-history{
  padding: 17px 15px 16px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(170, 158, 139, .16) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(247, 243, 236, .74)) !important;
  box-shadow:
    0 16px 34px rgba(92, 82, 67, .09),
    0 1px 0 rgba(255, 255, 255, .72) inset !important;
  backdrop-filter: blur(10px) !important;
}

.kbmb-deuil .kbmb-history-title{
  margin-bottom: 11px !important;
  font-family: "Cormorant Garamond", "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif !important;
  font-size: 16px !important;
  line-height: 1.08 !important;
  letter-spacing: .01em !important;
  color: #3E4652 !important;
}

.kbmb-deuil .kbmb-history-item{
  padding: 12px 4px 11px !important;
  border-top: 1px solid rgba(170, 158, 139, .10) !important;
  background: transparent !important;
}

.kbmb-deuil .kbmb-history-item:first-child{
  border-top: 0 !important;
  padding-top: 0 !important;
}

.kbmb-deuil .kbmb-history-when{
  margin-bottom: 4px !important;
  font-size: 11px !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: rgba(122, 116, 108, .80) !important;
}

.kbmb-deuil .kbmb-history-text{
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: rgba(54, 65, 78, .90) !important;
}

.kbmb-deuil .kbmb-history-subject{
  margin-top: 4px !important;
  font-size: 13px !important;
  line-height: 1.42 !important;
  font-weight: 600 !important;
  color: #394554 !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-section-title::after{
  min-width: clamp(72px, 22vw, 300px) !important;
  margin: 0 16px 0 18px !important;
  background: rgba(120, 105, 85, .22) !important;
  opacity: 1 !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-section-subtitle{
  margin-top: 1px !important;
  max-width: 48ch !important;
  color: #7C756D !important;
  line-height: 1.42 !important;
}

/* =========================================================
   DEUIL — TITRES SECTIONS
   Correction lisibilité titres sur glass.
   ========================================================= */

.kbmb-deuil .kbmb-section-title{
  font-size: clamp(20px, 2vw, 24px) !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  color: rgba(212, 175, 55, .85) !important;
  text-shadow:
    0 0 8px rgba(212, 175, 55, .15),
    0 1px 2px rgba(0, 0, 0, .25) !important;
}

.kbmb-deuil .kbmb-section-title .kbmb-info{
  color: rgba(122, 116, 108, .72) !important;
  text-shadow: none !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title,
.kbmb-deuil .kbmb-section--journal .kbmb-section-title{
  overflow: visible !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title::before,
.kbmb-deuil .kbmb-section--journal .kbmb-section-title::before{
  font-size: clamp(20px, 2vw, 24px) !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  color: rgba(212, 175, 55, .85) !important;
  text-shadow:
    0 0 8px rgba(212, 175, 55, .15),
    0 1px 2px rgba(0, 0, 0, .25) !important;
}

/* =========================================================
   DEUIL — JOURNAL COMPACT SCALABLE
   Version visuelle: 2026.04.07.4
   Note: rendu dense, sobre et extensible sur structure groupée par date.
   ========================================================= */

.kbmb-deuil .kbmb-section--journal{
  --kb-journal-well: rgba(245, 242, 237, .74);
  --kb-journal-well-strong: rgba(251, 249, 245, .82);
  --kb-journal-surface: rgba(250, 248, 244, .96);
  --kb-journal-surface-strong: rgba(255, 253, 249, .98);
  --kb-journal-column-surface: rgba(255, 253, 249, .44);
  --kb-journal-border: rgba(116, 110, 100, .12);
  --kb-journal-border-strong: rgba(116, 110, 100, .18);
  --kb-journal-column-border: rgba(116, 110, 100, .08);
  --kb-journal-line: rgba(174, 168, 159, .34);
  --kb-journal-ink: #4b4740;
  --kb-journal-muted: rgba(75, 71, 64, .68);
  --kb-journal-accent: #9c8757;
  --kb-journal-accent-soft: rgba(156, 135, 87, .12);
  --kb-journal-column-shadow: 0 10px 24px rgba(78, 70, 58, .035);
  --kb-journal-shadow:
    0 16px 34px rgba(78, 70, 58, .08),
    0 3px 10px rgba(78, 70, 58, .035);
  --kb-journal-shadow-strong:
    0 20px 42px rgba(78, 70, 58, .10),
    0 4px 12px rgba(78, 70, 58, .04);
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header{
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 18px !important;
  align-items: end !important;
  margin-bottom: 22px !important;
  padding: 0 0 8px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top{
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  min-width: 0 !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::after{
  content: "" !important;
  flex: 1 1 auto !important;
  min-width: 48px !important;
  height: 1px !important;
  background: linear-gradient(
    90deg,
    rgba(176, 168, 157, .24),
    rgba(176, 168, 157, .14) 58%,
    rgba(176, 168, 157, 0)
  ) !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title{
  position: relative !important;
  min-height: clamp(30px, 3vw, 42px) !important;
  width: auto !important;
  overflow: visible !important;
  white-space: normal !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::before{
  justify-content: flex-start !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: clamp(26px, 2.6vw, 34px) !important;
  line-height: 1 !important;
  font-weight: 500 !important;
  letter-spacing: -.045em !important;
  color: #5f584d !important;
  text-shadow: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle{
  margin: 0 !important;
  max-width: none !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  font-style: normal !important;
  text-align: right !important;
  color: var(--kb-journal-muted) !important;
}

.kbmb-deuil .kbmb-card--journal{
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.kbmb-deuil .kbmb-journal{
  display: block !important;
  margin-top: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 14px 14px 16px !important;
  border: 1px solid rgba(118, 110, 99, .08) !important;
  border-radius: 28px !important;
  background: linear-gradient(
    180deg,
    var(--kb-journal-well-strong),
    rgba(246, 243, 238, .52) 58%,
    rgba(243, 239, 233, .42)
  ) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .54),
    0 18px 38px rgba(83, 74, 62, .045) !important;
}

.kbmb-deuil .kbmb-history{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-list{
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: clamp(260px, 22vw, 300px) !important;
  grid-template-columns: none !important;
  justify-content: start !important;
  gap: 20px !important;
  align-items: start !important;
  width: 100% !important;
  padding: 4px 2px 10px !important;
  margin-top: 0 !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  overscroll-behavior-x: contain !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-behavior: smooth !important;
  scroll-padding-inline: 0 !important;
  scroll-snap-type: x mandatory !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(156, 135, 87, .34) rgba(95, 87, 77, .08) !important;
}

.kbmb-deuil .kbmb-journal-list::-webkit-scrollbar{
  height: 10px !important;
}

.kbmb-deuil .kbmb-journal-list::-webkit-scrollbar-track{
  background: rgba(95, 87, 77, .08) !important;
  border-radius: 999px !important;
}

.kbmb-deuil .kbmb-journal-list::-webkit-scrollbar-thumb{
  background: rgba(156, 135, 87, .34) !important;
  border-radius: 999px !important;
}

.kbmb-deuil .kbmb-journal-list::-webkit-scrollbar-thumb:hover{
  background: rgba(156, 135, 87, .48) !important;
}

.kbmb-deuil .kbmb-journal-list::before{
  content: none !important;
}

.kbmb-deuil .kbmb-journal-day{
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  width: clamp(260px, 22vw, 300px) !important;
  min-width: clamp(260px, 22vw, 300px) !important;
  max-width: 300px !important;
  padding: 10px 10px 12px !important;
  border: 1px solid var(--kb-journal-column-border) !important;
  border-radius: 22px !important;
  background: linear-gradient(
    180deg,
    var(--kb-journal-column-surface),
    rgba(246, 243, 238, .18)
  ) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .38),
    var(--kb-journal-column-shadow) !important;
  scroll-snap-align: start !important;
  scroll-snap-stop: always !important;
}

.kbmb-deuil .kbmb-journal-day-head{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 26px !important;
}

.kbmb-deuil .kbmb-journal-day-head::after{
  content: "" !important;
  flex: 1 1 auto !important;
  height: 1px !important;
  background: linear-gradient(
    90deg,
    rgba(174, 168, 159, .28),
    rgba(174, 168, 159, .10)
  ) !important;
}

.kbmb-deuil .kbmb-journal-day-date{
  display: inline-block !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  letter-spacing: -.01em !important;
  color: #696258 !important;
  white-space: nowrap !important;
}

.kbmb-deuil .kbmb-journal-letters{
  display: grid !important;
  gap: 12px !important;
}

.kbmb-deuil .kbmb-journal-item{
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.kbmb-deuil .kbmb-journal-item::before{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-item.is-just-arrived .kbmb-journal-card{
  animation: none !important;
}

.kbmb-deuil .kbmb-journal-wrap{
  position: relative !important;
  min-height: 100% !important;
  padding-top: 0 !important;
}

.kbmb-deuil .kbmb-journal-rail{
  position: absolute !important;
  left: 10px !important;
  top: -10px !important;
  width: 1px !important;
  height: 10px !important;
  background: linear-gradient(
    180deg,
    var(--kb-journal-line),
    rgba(176, 168, 157, 0)
  ) !important;
}

.kbmb-deuil .kbmb-journal-dot{
  position: absolute !important;
  top: -4px !important;
  left: 50% !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: var(--kb-journal-accent) !important;
  transform: translateX(-50%) !important;
  box-shadow: 0 0 0 6px var(--kb-journal-accent-soft) !important;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-dot{
  background: #8c7544 !important;
  box-shadow: 0 0 0 7px rgba(140, 117, 68, .14) !important;
}

.kbmb-deuil .kbmb-journal-card{
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  min-height: 0 !important;
  margin: 0 !important;
  margin-left: 0 !important;
  padding: 14px 14px 13px !important;
  border-radius: 16px !important;
  border: 1px solid var(--kb-journal-border) !important;
  background: linear-gradient(180deg, var(--kb-journal-surface-strong), var(--kb-journal-surface)) !important;
  box-shadow:
    var(--kb-journal-shadow),
    inset 0 1px 0 rgba(255, 255, 255, .58) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
}

.kbmb-deuil .kbmb-journal-card::before{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-card::after{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-card{
  border-color: var(--kb-journal-border-strong) !important;
  box-shadow:
    var(--kb-journal-shadow-strong),
    inset 0 1px 0 rgba(255, 255, 255, .66) !important;
  transform: none !important;
}

.kbmb-deuil .kbmb-journal-ribbon{
  position: static !important;
  margin: 0 0 10px !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(129, 120, 109, .12) !important;
  background: rgba(95, 87, 77, .06) !important;
  color: rgba(95, 87, 77, .78) !important;
  box-shadow: none !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 9.5px !important;
  font-weight: 600 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.kbmb-deuil .kbmb-journal-top{
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  width: 100% !important;
  margin: -2px 0 8px !important;
  padding-right: 28px !important;
  position: static !important;
}

.kbmb-deuil .kbmb-journal-date{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-date::before{
  display: none !important;
}

.kbmb-deuil .kbmb-journal-date-full{
  display: none !important;
}

.kbmb-deuil .kbmb-badge--posted{
  display: inline-flex !important;
  align-items: center !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(164, 138, 82, .16) !important;
  background: rgba(164, 138, 82, .08) !important;
  color: #7f6b44 !important;
  box-shadow: none !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 9.5px !important;
  font-weight: 600 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal,
.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
  top: 12px !important;
  right: 12px !important;
  width: 28px !important;
  height: 28px !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal{
  border: 1px solid rgba(153, 136, 97, .22) !important;
  background: radial-gradient(
    circle at 35% 35%,
    #ece2c5 0%,
    #c8b27e 66%,
    #9b8658 100%
  ) !important;
  color: rgba(74, 67, 56, .72) !important;
  box-shadow:
    0 7px 16px rgba(89, 82, 73, .08),
    0 0 0 4px rgba(153, 136, 97, .07) !important;
}

.kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal span{
  font-size: 10px !important;
  opacity: .72 !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
  border: 1px solid rgba(127, 108, 81, .24) !important;
  background:
    radial-gradient(circle at 34% 30%, rgba(255, 248, 240, .22) 0%, transparent 28%),
    radial-gradient(circle at 58% 62%, #b39a70 0%, #8c7553 62%, #6a5744 100%) !important;
  box-shadow:
    0 7px 16px rgba(89, 82, 73, .08),
    0 0 0 4px rgba(127, 108, 81, .07) !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax::before{
  border-color: rgba(255, 245, 232, .16) !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax::after{
  font-size: 8px !important;
  color: rgba(255, 247, 238, .80) !important;
  text-shadow: none !important;
}

.kbmb-deuil .kbmb-journal-title,
.kbmb-deuil .kbmb-journal-card h4,
.kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
  margin: 0 0 8px !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: clamp(17px, 1.5vw, 21px) !important;
  line-height: 1.18 !important;
  font-weight: 500 !important;
  letter-spacing: -.02em !important;
  color: var(--kb-journal-ink) !important;
  text-shadow: none !important;
}

.kbmb-deuil .kbmb-journal-item.is-latest .kbmb-journal-title{
  font-size: clamp(17px, 1.5vw, 21px) !important;
}

.kbmb-deuil .kbmb-journal-excerpt{
  margin: 0 0 8px !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: var(--kb-journal-muted) !important;
}

.kbmb-deuil .kbmb-journal-excerpt--sealed{
  color: rgba(79, 73, 63, .60) !important;
  font-style: normal !important;
}

.kbmb-deuil .kbmb-journal-seal-hint,
.kbmb-deuil .kbmb-journal-seal-wait{
  margin: 0 0 6px !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
  color: var(--kb-journal-muted) !important;
}

.kbmb-deuil .kbmb-journal-seal-form{
  margin-top: 8px !important;
}

.kbmb-deuil .kbmb-journal-open-letter,
.kbmb-deuil .kbmb-journal-seal-btn{
  margin: 6px 0 0 !important;
  padding: 8px 11px !important;
  border-radius: 999px !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
  box-shadow: none !important;
  transform: none !important;
}

.kbmb-deuil .kbmb-journal-open-letter{
  border: 1px solid rgba(95, 87, 77, .14) !important;
  background: rgba(95, 87, 77, .06) !important;
  color: #4d483f !important;
}

.kbmb-deuil .kbmb-journal-open-letter:hover{
  background: rgba(95, 87, 77, .10) !important;
}

.kbmb-deuil .kbmb-journal-seal-btn{
  border: 1px solid rgba(164, 138, 82, .18) !important;
  background: linear-gradient(
    180deg,
    rgba(241, 236, 226, .98),
    rgba(227, 220, 205, .94)
  ) !important;
  color: #5b5143 !important;
}

.kbmb-deuil .kbmb-journal-seal-btn[disabled]{
  opacity: .58 !important;
  background: rgba(231, 227, 220, .78) !important;
  color: rgba(91, 81, 67, .56) !important;
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-journal-seal-btn.is-unlocked{
  box-shadow: none !important;
}

.kbmb-deuil .kbmb-journal-ritual{
  margin-top: auto !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(176, 168, 157, .16) !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 10px !important;
  line-height: 1.45 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  color: rgba(95, 87, 77, .56) !important;
}

@media (max-width: 1080px){
  .kbmb-deuil .kbmb-section--journal .kbmb-section-header{
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle{
    max-width: none !important;
    justify-self: start !important;
    text-align: left !important;
  }

  .kbmb-deuil .kbmb-journal{
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 12px 12px 14px !important;
  }

  .kbmb-deuil .kbmb-journal-list{
    grid-auto-columns: clamp(260px, 32vw, 300px) !important;
    gap: 18px !important;
  }

  .kbmb-deuil .kbmb-journal-day{
    width: clamp(260px, 32vw, 300px) !important;
    min-width: clamp(260px, 32vw, 300px) !important;
    padding: 9px 9px 11px !important;
  }
}

@media (max-width: 760px){
  .kbmb-deuil .kbmb-section--journal .kbmb-section-header{
    margin-bottom: 18px !important;
    padding-bottom: 0 !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::after{
    display: none !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-title{
    min-height: 28px !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-title::before{
    font-size: clamp(24px, 7vw, 30px) !important;
  }

  .kbmb-deuil .kbmb-journal-list{
    gap: 16px !important;
    padding-top: 2px !important;
    padding-bottom: 8px !important;
    grid-auto-columns: clamp(260px, 84vw, 300px) !important;
    scroll-snap-type: x mandatory !important;
  }

  .kbmb-deuil .kbmb-journal-day{
    gap: 10px !important;
    width: clamp(260px, 84vw, 300px) !important;
    min-width: clamp(260px, 84vw, 300px) !important;
    max-width: 300px !important;
    padding: 8px 8px 10px !important;
  }

  .kbmb-deuil .kbmb-journal-rail{
    display: none !important;
  }

  .kbmb-deuil .kbmb-journal-day-head{
    min-height: 22px !important;
  }

  .kbmb-deuil .kbmb-journal-day-date{
    font-size: 12px !important;
  }

  .kbmb-deuil .kbmb-journal-card{
    min-height: auto !important;
    padding: 13px 13px 12px !important;
  }

  .kbmb-deuil .kbmb-journal-top{
    position: static !important;
    margin: -2px 0 8px !important;
    padding-right: 24px !important;
  }

  .kbmb-deuil .kbmb-journal-ribbon{
    margin-bottom: 8px !important;
  }

  .kbmb-deuil .kbmb-journal-card:not(.is-sealed) .kbmb-journal-seal,
  .kbmb-deuil .kbmb-journal-card.is-sealed .kbmb-journal-wax{
    top: 11px !important;
    right: 11px !important;
    width: 26px !important;
    height: 26px !important;
  }

  .kbmb-deuil .kbmb-journal-title,
  .kbmb-deuil .kbmb-journal-card h4,
  .kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
    font-size: 16px !important;
  }

  .kbmb-deuil .kbmb-journal-excerpt{
    font-size: 12.5px !important;
  }

  .kbmb-deuil .kbmb-journal-open-letter,
  .kbmb-deuil .kbmb-journal-seal-btn{
    font-size: 10.5px !important;
    padding: 7px 10px !important;
  }
}

/* =========================================================
   DEUIL — HEADERS D'ÉCRITURE ET JOURNAL
   Version visuelle: 2026.04.07.6
   Note: structure claire gauche/droite pour le journal
   et meilleure hiérarchie du bloc d’écriture.
   ========================================================= */

.kbmb-deuil .kbmb-section--letters .kbmb-section-header{
  padding-top: 16px !important;
  margin-bottom: 18px !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-header > div:first-child{
  min-width: 0 !important;
  width: 100% !important;
  text-align: center !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title{
  min-height: clamp(32px, 3vw, 40px) !important;
  overflow: visible !important;
  white-space: normal !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-subtitle{
  margin-top: 5px !important;
  max-width: none !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 12.5px !important;
  line-height: 1.5 !important;
  font-style: normal !important;
  font-weight: 500 !important;
  color: rgba(80, 73, 63, .68) !important;
  text-align: center !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header{
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: 0 2px 10px !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header > div:first-child{
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  text-align: left !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top{
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 16px !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::after{
  content: "" !important;
  flex: 1 1 auto !important;
  min-width: 56px !important;
  height: 1px !important;
  background: linear-gradient(
    90deg,
    rgba(176, 168, 157, .28),
    rgba(176, 168, 157, .12) 68%,
    rgba(176, 168, 157, 0)
  ) !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title{
  position: static !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: visible !important;
  clip-path: none !important;
  white-space: nowrap !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::after{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle{
  flex: 0 1 34ch !important;
  max-width: 34ch !important;
  margin: 2px 0 0 !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 12.5px !important;
  line-height: 1.5 !important;
  font-style: normal !important;
  font-weight: 500 !important;
  text-align: right !important;
  color: rgba(85, 77, 67, .68) !important;
}

@media (max-width: 760px){
  .kbmb-deuil .kbmb-section--letters .kbmb-section-subtitle{
    font-size: 12px !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-header{
    display: block !important;
    gap: 0 !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-header__top{
    gap: 12px !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::after{
    display: none !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-subtitle{
    max-width: none !important;
    margin-top: 6px !important;
    text-align: left !important;
  }
}

/* =========================================================
   DEUIL — TITLE SYSTEM
   Version visuelle: 2026.04.07.9
   Note: base typographique unique sur les vrais h3
   avec helper visuel restaure pour le journal.
   ========================================================= */

.kbmb-deuil{
  --kb-widget-title-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --kb-widget-title-size: clamp(18px, 1.7vw, 21px);
  --kb-widget-title-weight: 500;
  --kb-widget-title-tracking: -.025em;
  --kb-widget-title-color: #554d43;
  --kb-widget-title-line: 1.12;
}

.kbmb-deuil .section-title,
.kbmb-deuil .kbmb-section-title{
  font-family: var(--kb-widget-title-family) !important;
  font-size: var(--kb-widget-title-size) !important;
  line-height: var(--kb-widget-title-line) !important;
  font-weight: var(--kb-widget-title-weight) !important;
  letter-spacing: var(--kb-widget-title-tracking) !important;
  color: var(--kb-widget-title-color) !important;
  text-shadow: none !important;
  filter: none !important;
  opacity: 1 !important;
  -webkit-text-fill-color: currentColor !important;
  -webkit-font-smoothing: antialiased !important;
  text-rendering: geometricPrecision !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title,
.kbmb-deuil .kbmb-section--journal .kbmb-section-title,
.kbmb-deuil .kbmb-section--photos .kbmb-section-title{
  font-family: var(--kb-widget-title-family) !important;
  font-size: var(--kb-widget-title-size) !important;
  line-height: var(--kb-widget-title-line) !important;
  font-weight: var(--kb-widget-title-weight) !important;
  letter-spacing: var(--kb-widget-title-tracking) !important;
  color: var(--kb-widget-title-color) !important;
}

.kbmb-deuil .kbmb-section-title .kbmb-info{
  color: rgba(111, 103, 92, .68) !important;
  text-shadow: none !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title{
  display: block !important;
  width: 100% !important;
  min-height: 24px !important;
  margin: 0 !important;
  text-align: center !important;
  white-space: normal !important;
  overflow: visible !important;
}

.kbmb-deuil .kbmb-section--letters .kbmb-section-title::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-header__top::after{
  content: none !important;
  display: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title{
  display: flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 24px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  clip-path: none !important;
  text-align: left !important;
  white-space: nowrap !important;
  overflow: visible !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::before{
  content: none !important;
}

.kbmb-deuil .kbmb-section--journal .kbmb-section-title::after{
  content: "" !important;
  display: block !important;
  flex: 1 1 auto !important;
  min-width: clamp(48px, 18vw, 240px) !important;
  height: 1px !important;
  margin: 0 14px 0 16px !important;
  background: rgba(120, 105, 85, .18) !important;
}

@media (max-width: 760px){
  .kbmb-deuil{
    --kb-widget-title-size: clamp(18px, 5.4vw, 20px);
  }

  .kbmb-deuil .kbmb-section--letters .kbmb-section-title,
  .kbmb-deuil .kbmb-section--journal .kbmb-section-title{
    white-space: normal !important;
  }

  .kbmb-deuil .kbmb-section--journal .kbmb-section-title::after{
    display: none !important;
  }
}

/* =========================================================
   DEUIL — TRACE DESIGN PARITY
   Reprend le langage visuel clair de l'espace Trace.
   ========================================================= */

.kbmb-deuil .kbmb-card--letters{
  width: 100% !important;
  max-width: none !important;
  background: rgba(255, 255, 255, 0.42) !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  box-shadow:
    0 22px 44px rgba(44, 62, 80, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

.kbmb-deuil .kbmb-label,
.kbmb-deuil .kbmb-label--subtle,
.kbmb-deuil .kbmb-label--small,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-label{
  color: rgba(46, 59, 75, 0.62) !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

.kbmb-deuil .kbmb-input,
.kbmb-deuil .kbmb-textarea,
.kbmb-deuil .kbmb-input[type="file"],
.kbmb-deuil .kbmb-input--subject{
  width: 100% !important;
  border-radius: 14px !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  background: rgba(255, 255, 255, 0.42) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
  color: #334155 !important;
}

.kbmb-deuil .kbmb-input,
.kbmb-deuil .kbmb-input--subject{
  min-height: 52px !important;
  padding: 14px 16px !important;
  font-size: 0.96rem !important;
}

.kbmb-deuil .kbmb-textarea{
  min-height: 260px !important;
  padding: 20px !important;
  border-radius: 18px !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  resize: vertical !important;
}

.kbmb-deuil .kbmb-input::placeholder,
.kbmb-deuil .kbmb-textarea::placeholder,
.kbmb-deuil .kbmb-input--subject::placeholder{
  color: rgba(100, 116, 139, 0.72) !important;
}

.kbmb-deuil .kbmb-input:focus,
.kbmb-deuil .kbmb-textarea:focus,
.kbmb-deuil .kbmb-input[type="file"]:focus,
.kbmb-deuil .kbmb-input--subject:focus,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-note-input:focus{
  outline: none !important;
  border-color: rgba(255, 255, 255, 0.34) !important;
  background: rgba(255, 255, 255, 0.48) !important;
  box-shadow:
    0 0 0 1px rgba(212, 175, 55, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

.kbmb-deuil .kbmb-letter-photos-field{
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  background: rgba(255, 255, 255, 0.36) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-card--photos{
  padding: 18px 18px 20px !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255, 255, 255, 0.55) !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,0.55), transparent 58%),
    radial-gradient(circle at 100% 0%, rgba(245,215,120,0.16), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,0.56), rgba(248,250,252,0.46)) !important;
  box-shadow: 0 18px 40px rgba(15,23,42,0.10) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions{
  gap: 8px !important;
}

.kbmb-deuil .kbmb-form-actions .kb-btn,
.kbmb-deuil .kbmb-journal-open-letter,
.kbmb-deuil .kbmb-journal-seal-btn,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn{
  min-height: 44px !important;
  padding: 10px 18px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.48) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.56)) !important;
  color: #56687b !important;
  box-shadow:
    0 0 0 1px rgba(212, 175, 55, 0.10),
    0 16px 32px rgba(44, 62, 80, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.56) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  transition: transform .14s ease, box-shadow .14s ease, background .14s ease, color .14s ease, border-color .14s ease !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.34);
}

.kbmb-deuil .kbmb-form-actions .kb-btn:hover,
.kbmb-deuil .kbmb-journal-open-letter:hover,
.kbmb-deuil .kbmb-journal-seal-btn:hover,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn:hover{
  transform: translateY(-1px) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.64)) !important;
  box-shadow:
    0 0 0 1px rgba(212, 175, 55, 0.14),
    0 20px 38px rgba(44, 62, 80, 0.14),
    0 0 24px rgba(212, 175, 55, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.60) !important;
  color: #d4af37 !important;
  border-color: rgba(255, 255, 255, 0.58) !important;
}

@media (max-width: 900px){
  .kb-ux-container > .kbmb-widget.kb-section--deuil,
  .kb-ux-container > .kbmb-widget.kb-section--deuil.kb-wrap,
  .kbmb-deuil.kbmb-widget.kbmb-glass{
    width: 100% !important;
    max-width: 100% !important;
    margin: 20px auto !important;
    padding: 20px !important;
    border-radius: 20px;
  }
}

.kbmb-deuil .kbmb-journal-seal-btn[disabled],
.kbmb-deuil .kbmb-form-actions .kb-btn[disabled],
.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn[disabled]{
  box-shadow: none !important;
  cursor: not-allowed !important;
  opacity: 0.68 !important;
  transform: none !important;
}

/* =========================================================
   DEUIL — WIDTH PARITY WITH TRACE
   Unifie la largeur des zones principales pour éviter
   l'effet "resserré" des cartes Journal / Photos.
   ========================================================= */

.kbmb-deuil.kbmb-widget.kbmb-glass,
.kbmb-deuil-inner.kbmb-deuil--v2,
.kbmb-deuil .kbmb-card--letters,
.kbmb-deuil .kbmb-card--journal,
.kbmb-deuil .kbmb-card--photos,
.kbmb-deuil .kbmb-section--letters,
.kbmb-deuil .kbmb-section--journal,
.kbmb-deuil .kbmb-section--photos,
.kbmb-deuil .kbmb-journal{
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

@media (hover: hover) and (pointer: fine) {
  .kbmb-deuil.kbmb-widget.kbmb-glass,
  .kbmb-deuil .kbmb-card--letters,
  .kbmb-deuil .kbmb-card--journal,
  .kbmb-deuil .kbmb-card--photos,
  .kbmb-deuil .kbmb-journal-card,
  .kbmb-deuil .kbmb-photo-polaroid,
  .kbmb-deuil .kbmb-form-actions .kb-btn,
  .kbmb-deuil .kbmb-journal-open-letter,
  .kbmb-deuil .kbmb-journal-seal-btn,
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn{
    transition: transform .28s cubic-bezier(.22, 1, .36, 1), box-shadow .28s ease, border-color .28s ease, background .28s ease, color .28s ease;
    will-change: transform;
  }

  .kbmb-deuil.kbmb-widget.kbmb-glass:hover{
    transform: translateY(-3px);
  }

  .kbmb-deuil .kbmb-card--letters:hover,
  .kbmb-deuil .kbmb-card--journal:hover,
  .kbmb-deuil .kbmb-card--photos:hover,
  .kbmb-deuil .kbmb-journal-card:hover,
  .kbmb-deuil .kbmb-photo-polaroid:hover{
    transform: translateY(-3px);
  }

  .kbmb-deuil .kbmb-form-actions .kb-btn:hover,
  .kbmb-deuil .kbmb-journal-open-letter:hover,
  .kbmb-deuil .kbmb-journal-seal-btn:hover,
  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn:hover{
    transform: translateY(-1px);
  }
}

.kbmb-deuil .kbmb-journal-list{
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: clamp(360px, 28vw, 440px) !important;
  grid-template-columns: none !important;
  justify-content: start !important;
  align-items: start !important;
  gap: 18px !important;
  padding: 4px 2px 10px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  overscroll-behavior-x: contain !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x mandatory !important;
}

.kbmb-deuil .kbmb-journal-day{
  width: clamp(360px, 28vw, 440px) !important;
  min-width: clamp(360px, 28vw, 440px) !important;
  max-width: clamp(360px, 28vw, 440px) !important;
}

/* Retiré : ces surcharges conflictuelles écrasaient la grille 2 colonnes et le max-width 190px. */

@media (max-width: 1080px){
  .kbmb-deuil .kbmb-journal-list{
    grid-auto-columns: clamp(320px, 42vw, 380px) !important;
  }

  .kbmb-deuil .kbmb-journal-day{
    width: clamp(320px, 42vw, 380px) !important;
    min-width: clamp(320px, 42vw, 380px) !important;
    max-width: clamp(320px, 42vw, 380px) !important;
  }
}

@media (max-width: 720px){
  .kbmb-deuil .kbmb-journal-day{
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .kbmb-deuil .kbmb-section--photos .kbmb-photos-grid{
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
    max-width: 100% !important;
  }
}
