/* =========================================================
   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;
}

.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
   ========================================================= */

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

  border-radius: 26px;
  border: 1px solid rgba(44,62,80,.12);
  background: rgba(255,255,255,.58);
  box-shadow: 0 18px 50px rgba(44,62,80,.12);
  backdrop-filter: blur(10px);

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

.kbmb-deuil .kbmb-crossing-steps::before{
  content:"";
  position:absolute;
  left: 22px;
  right: 22px;
  top: 20px;
  height: 78px;
  pointer-events:none;
  background:
    radial-gradient(120% 140% at 50% 130%,
      transparent 52%,
      rgba(212,175,55,.70) 53%,
      rgba(212,175,55,.28) 56%,
      transparent 62%
    );
  filter: drop-shadow(0 10px 18px rgba(212,175,55,.20));
  opacity: .95;
}

.kbmb-deuil .kbmb-crossing-steps::after{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: 26px;
  pointer-events:none;
  background:
    radial-gradient(60% 90% at 22% 0%, rgba(212,175,55,.12), transparent 62%),
    radial-gradient(70% 110% at 85% 18%, rgba(86,199,255,.10), transparent 66%);
  opacity: .90;
}

.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;
}

.kbmb-deuil .kbmb-crossing-step .dot{
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: rgba(44,62,80,.18);
  border: 1px solid rgba(44,62,80,.14);
  box-shadow: 0 8px 20px rgba(44,62,80,.10);
}

.kbmb-deuil .kbmb-crossing-step .label{
  font-size: 12.5px;
  line-height: 1.15;
  color: rgba(44,62,80,.72);
  letter-spacing: .2px;
  white-space: nowrap;
}

.kbmb-deuil .kbmb-crossing-step.is-on .label{
  color: rgba(44,62,80,.92);
  font-weight: 700;
}

@keyframes kbBridgePulse{
  0%,100% { transform: translateY(0); opacity: .88; }
  50%     { transform: translateY(-1px); opacity: 1; }
}

.kbmb-deuil .kbmb-crossing-step.is-on .dot{
  background: #d4af37;
  border-color: rgba(212,175,55,.65);
  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;
}

@media (max-width: 560px){
  .kbmb-deuil .kbmb-crossing-steps{
    flex-direction: column;
    gap: 12px;
    padding: 18px 16px;
    margin: 10px 12px 12px 12px;
  }
  .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;
  }
}

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

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

  border-radius: 22px;
  border: 1px solid rgba(44,62,80,.16);
  background: rgba(255,255,255,.64);
  box-shadow: 0 18px 54px rgba(44,62,80,.12);
  backdrop-filter: blur(10px);
}

.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-card::before{
  content:"";
  position:absolute;
  left: -26px;
  top: -18px;
  bottom: -18px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(
    to bottom,
    rgba(212,175,55,.00),
    rgba(212,175,55,.36),
    rgba(212,175,55,.18),
    rgba(212,175,55,.00)
  );
  opacity: .9;
}

.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: 14px;
  height: 14px;
  border-radius: 999px;
  background: #d4af37;
  border: 1px solid rgba(212,175,55,.55);
  box-shadow:
    0 14px 34px rgba(212,175,55,.25),
    0 0 0 8px rgba(212,175,55,.12);
}

.kbmb-deuil .kbmb-journal-title,
.kbmb-deuil .kbmb-journal-card h4,
.kbmb-deuil .kbmb-journal-card .kbmb-letter-subject{
  font-weight: 700;
  letter-spacing: .2px;
  color: rgba(44,62,80,.92);
}

.kbmb-deuil .kbmb-journal-date,
.kbmb-deuil .kbmb-journal-card .kbmb-date,
.kbmb-deuil .kbmb-journal-card time{
  color: rgba(44,62,80,.60);
  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,.22);
  background: rgba(212,175,55,.10);
  color: rgba(44,62,80,.82);
}

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

@media (max-width: 560px){
  .kbmb-deuil .kbmb-journal-card{
    margin-left: 38px;
    padding: 16px 16px 14px 16px;
  }
  .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: 22px;
}

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

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid{
  width: 100%;
  max-width: 340px;
  margin: 0 auto;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-inner{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(255,255,255,.50);
  box-shadow: 0 14px 34px rgba(44,62,80,.14);
}

.kbmb-deuil .kbmb-section--photos .kb-photo-thumb--large{
  border-radius: 16px;
  display: block;
  width: 100%;
  height: auto;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-caption{
  padding: 12px 14px 14px 14px;
  background: rgba(255,250,243,.72);
  border-top: 1px solid rgba(44,62,80,.08);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 13px;
  line-height: 1.25;
  color: rgba(44,62,80,.85);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-tags:empty{
  display: none;
}

.kbmb-deuil .kbmb-section--photos .kbmb-tag-chip{
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(44,62,80,.12);
  background: rgba(255,255,255,.55);
  color: rgba(44,62,80,.85);
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions{
  display: flex;
  flex-direction: row;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid-actions .kb-btn,
.kbmb-deuil .kbmb-section--photos .kbmb-photo-tags-form .kb-btn,
.kbmb-deuil .kbmb-section--photos .kbmb-form--photo-upload .kb-btn{
  border-radius: 999px !important;
  padding: 10px 16px;
  font-weight: 500;
}

.kbmb-deuil .kbmb-section--photos .kbmb-btn--danger{
  border: 1px solid rgba(236,62,80,.28);
  background: rgba(236,62,80,.08);
  color: #ec3e50;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid--favorite .kbmb-photo-polaroid-inner{
  border-color: rgba(212,175,55,.45);
  box-shadow: 0 16px 38px rgba(212,175,55,.18);
}

/* Drawer tags */
.kbmb-deuil .kbmb-section--photos .kbmb-photo-tags-form{
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(255,255,255,.45);
  display: none;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-polaroid.is-tags-open .kbmb-photo-tags-form{
  display: block;
}

.kbmb-deuil .kbmb-section--photos .kbmb-input--tags{
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(44,62,80,.12);
  background: rgba(255,255,255,.75);
  padding: 10px 12px;
  margin: 8px 0 10px 0;
}

.kbmb-deuil .kbmb-section--photos .kbmb-photo-upload{
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(44,62,80,.08);
}

.kbmb-deuil .kbmb-section--photos .kbmb-form--photo-upload{
  padding: 14px 14px 16px 14px;
  border-radius: 22px;
  border: 1px solid rgba(44,62,80,.10);
  background: rgba(255,250,243,.55);
}

@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: 420px;
  }
}