/* ==========================================================================
   Easter egg — Cochon caché (concours 10 ans)
   ========================================================================== */

/* ── Cochon discret en bas de la section histoire ── */
.easter-egg-pig {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, -10%);
  width: clamp(44px, 5.5vw, 70px);
  height: auto;
  padding: 0;
  margin: 0;
  background: none;
  border: 0;
  cursor: pointer;
  opacity: 0.45;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.25));
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.35s ease;
  z-index: 1;
}

.easter-egg-pig img {
  display: block;
  width: 100%;
  height: auto;
  pointer-events: none;
}

.easter-egg-pig:hover,
.easter-egg-pig:focus-visible {
  transform: translate(-50%, -260%) scale(4) rotate(-8deg);
  opacity: 1;
  z-index: 5;
  outline: none;
}

.easter-egg-pig:focus-visible {
  outline: 2px dashed rgba(230, 16, 93, 0.6);
  outline-offset: 4px;
  border-radius: 50%;
}

@media (max-width: 768px) {
  .easter-egg-pig {
    width: 42px;
    transform: translate(-50%, -10%);
  }
  .easter-egg-pig:hover,
  .easter-egg-pig:focus-visible {
    transform: translate(-50%, -210%) scale(3.2) rotate(-8deg);
  }
}

/* ── Overlay easter-egg ── */
.overlay-egg {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.35s ease;
}

.overlay-egg.is-open {
  pointer-events: auto;
  opacity: 1;
}

.overlay-egg__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 58, 71, 0.7);
  backdrop-filter: blur(4px);
}

.overlay-egg__wrap {
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: clamp(2rem, 4vh, 3rem) clamp(1.5rem, 4vw, 3rem);
  max-width: min(520px, 90vw);
  width: 100%;
  text-align: center;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.25);
  transform: translateY(20px) scale(0.95);
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}

.overlay-egg.is-open .overlay-egg__wrap {
  transform: translateY(0) scale(1);
}

.overlay-egg__close {
  position: absolute;
  top: 0.6rem;
  right: 0.9rem;
  background: none;
  border: 0;
  font-size: 2rem;
  line-height: 1;
  color: #222221;
  cursor: pointer;
  transition: color 0.3s, transform 0.3s;
}

.overlay-egg__close:hover {
  color: #E6105D;
  transform: rotate(90deg);
}

.overlay-egg__pig {
  display: block;
  width: clamp(90px, 16vh, 140px);
  height: auto;
  margin: 0 auto 1.2rem;
  animation: overlay-egg-bounce 0.9s cubic-bezier(0.34, 1.56, 0.64, 1) 0.1s both;
}

@keyframes overlay-egg-bounce {
  0%   { transform: scale(0) rotate(-20deg); opacity: 0; }
  60%  { transform: scale(1.1) rotate(6deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}

.overlay-egg__title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.6rem, 3.5vh, 2.4rem);
  color: #E6105D;
  font-weight: 400;
  margin: 0 0 0.8rem;
  line-height: 1.15;
}

.overlay-egg__message {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(0.95rem, 1.8vh, 1.05rem);
  color: #222221;
  line-height: 1.5;
  margin: 0 0 1.6rem;
}

.overlay-egg__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  background: #E6105D;
  color: #fff;
  text-decoration: none;
  padding: 0.85rem 1.6rem;
  border-radius: 999px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  transition: background 0.3s, transform 0.3s;
}

.overlay-egg__cta:hover {
  background: #c00d50;
  transform: translateY(-2px);
}

.overlay-egg__cta svg {
  transition: transform 0.3s;
}

.overlay-egg__cta:hover svg {
  transform: translateX(3px);
}
