.elementor-103501 .elementor-element.elementor-element-70bc172{--display:flex;--background-transition:0.3s;}/* Start custom CSS */.bilan-img {
  overflow: hidden;
  border-radius: 18px;
}

.bilan-img img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  object-position: left center;
}

.hero {
  position: relative;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

/* Dégradé sombre pour garder le texte lisible */
.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(
      90deg,
      rgba(20, 14, 12, 0.78) 0%,
      rgba(20, 14, 12, 0.52) 48%,
      rgba(20, 14, 12, 0.18) 100%
    );
  pointer-events: none;
}

.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.hero > .wrap {
  position: relative;
  z-index: 2;
}

.cta-wrap {
  display: flex;
  justify-content: center;
  margin-top: 2.5rem;
  padding: 4rem 1.5rem;
}

.cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 16px 40px;
  border-radius: 100px;
  background: #1a1411;
  color: #fff;
  font-family: "Jost", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid rgba(183, 117, 100, 0.35);
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.5);
  transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.cta:hover {
  background: #241b17;
  border-color: rgba(183, 117, 100, 0.6);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.6);
  color: #fff;
}

.cta:active {
  transform: translateY(0);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.5);
}
#protoHint{
  display:none;
  cursor:pointer;
  margin:18px auto 0;
  max-width:520px;
  padding:16px 22px;
  text-align:center;
  background:#1d1d1b;
  border:1px solid #9C917C;
  border-radius:14px;
  box-shadow:0 0 0 0 rgba(156,145,124,.45);
  animation:phPulse 2.4s ease-in-out infinite;
  transition:transform .2s ease, box-shadow .2s ease;
}
#protoHint.show{ display:block; }
#protoHint:hover{ transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.25); }

#phLabel{
  display:block;
  font-size:16px;
  font-weight:600;
  color:#fff;
  letter-spacing:.2px;
}
#phSub{
  display:inline-block;
  margin-top:6px;
  font-size:13.5px;
  color:#D9C9A6;
}
#phSub::after{
  content:"\2304"; /* chevron bas */
  display:inline-block;
  margin-left:8px;
  font-weight:700;
  animation:phBob 1.4s ease-in-out infinite;
}

@keyframes phPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(156,145,124,.40); }
  50%{ box-shadow:0 0 0 6px rgba(156,145,124,0); }
}
@keyframes phBob{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(3px); }
}

@media (prefers-reduced-motion: reduce){
  #protoHint{ animation:none; }
  #phSub::after{ animation:none; }
}/* End custom CSS */