/* ======================================================
   MA JOLIE CIRE - TEASER PREMIUM
   Page temporaire avant ouverture publique
====================================================== */

@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Newsreader:opsz,wght@6..72,500;6..72,600&display=swap");

:root {
  --teaser-bg: #fdf8f7;
  --teaser-text: #5a5a5a;
  --teaser-title: #332829;
  --teaser-muted: #8b7d7d;
  --teaser-line: #9a9a95;
  --teaser-pink: #ef98a7;
  --teaser-coral: #f2aaa3;
  --teaser-peach: #f6d5af;
  --teaser-gold: #c99a4c;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--teaser-bg);
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--teaser-text);
  font-family: "Manrope", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 50% 22%, rgba(255, 255, 255, 0.72), transparent 36%),
    linear-gradient(180deg, #fdf8f7 0%, #fbf1ef 100%);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.teaser-main {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: clamp(32px, 6vw, 76px) 20px;
}

.teaser-content {
  width: min(100%, 760px);
  display: grid;
  justify-items: center;
  text-align: center;
}

.teaser-logo-stage {
  position: relative;
  width: clamp(220px, 34vw, 390px);
  aspect-ratio: 1;
  margin-bottom: clamp(26px, 4vw, 42px);
}

.teaser-logo-final,
.teaser-logo-overlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.teaser-logo-final {
  display: block;
  object-fit: contain;
  opacity: 0;
  transform: translateY(8px) scale(0.985);
}

.teaser-logo-overlay {
  pointer-events: none;
}

.teaser-page.is-loaded .teaser-logo-final {
  animation: teaser-final-logo 1.2s cubic-bezier(0.22, 1, 0.36, 1) 3.55s forwards;
}

.teaser-page.is-complete .teaser-logo-final {
  opacity: 1;
  transform: none;
}

.teaser-page.is-complete .teaser-logo-overlay {
  opacity: 0;
}

.teaser-overlay-wreath {
  color: var(--teaser-line);
  stroke: currentColor;
  stroke-width: 2.5;
  opacity: 0.74;
}

.teaser-draw,
.teaser-word-line,
.teaser-word-underline {
  fill: none;
  stroke-dasharray: 900;
  stroke-dashoffset: 900;
}

.teaser-page.is-loaded .teaser-draw-left {
  animation: teaser-draw 2.8s ease-out 0.18s forwards;
}

.teaser-page.is-loaded .teaser-draw-right {
  animation: teaser-draw 2.8s ease-out 0.42s forwards;
}

.teaser-leaves {
  opacity: 0;
  transform: scale(0.94);
  transform-origin: center;
}

.teaser-page.is-loaded .teaser-leaves-left {
  animation: teaser-soft-pop 1.25s ease-out 1.22s forwards;
}

.teaser-page.is-loaded .teaser-leaves-right {
  animation: teaser-soft-pop 1.25s ease-out 1.42s forwards;
}

.teaser-overlay-watercolor {
  opacity: 0;
  transform: scale(0.92);
  transform-origin: 250px 306px;
}

.teaser-overlay-watercolor path {
  filter: blur(0.3px);
}

.teaser-overlay-watercolor path:nth-child(1) {
  fill: var(--teaser-pink);
  opacity: 0.62;
}

.teaser-overlay-watercolor path:nth-child(2) {
  fill: var(--teaser-peach);
  opacity: 0.58;
}

.teaser-overlay-watercolor path:nth-child(3) {
  fill: var(--teaser-coral);
  opacity: 0.48;
}

.teaser-page.is-loaded .teaser-overlay-watercolor {
  animation: teaser-watercolor 1.8s ease-out 1.55s forwards;
}

.teaser-overlay-candle {
  fill: none;
  stroke: var(--teaser-gold);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0;
  transform: translateY(8px);
}

.teaser-overlay-candle ellipse {
  fill: rgba(255, 248, 236, 0.72);
}

.teaser-overlay-flame {
  fill: rgba(212, 106, 106, 0.86);
  stroke: none;
  transform-origin: 252px 170px;
}

.teaser-page.is-loaded .teaser-overlay-candle {
  animation: teaser-candle 1.1s ease-out 2.35s forwards;
}

.teaser-overlay-wordmark {
  fill: none;
  stroke: #4e5a56;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0;
  transform: translateY(10px);
}

.teaser-word-underline {
  stroke-width: 4;
}

.teaser-page.is-loaded .teaser-overlay-wordmark {
  animation: teaser-wordmark 1.05s ease-out 2.8s forwards;
}

.teaser-page.is-loaded .teaser-word-line {
  animation: teaser-draw 1.1s ease-out 2.8s forwards;
}

.teaser-page.is-loaded .teaser-word-underline {
  animation: teaser-draw 0.95s ease-out 3.05s forwards;
}

.teaser-page.is-loaded .teaser-logo-overlay {
  animation: teaser-overlay-out 0.85s ease-out 4.1s forwards;
}

.teaser-page.is-loaded .teaser-contact {
  animation: teaser-contact-in 0.9s ease-out 4.1s forwards;
}

.teaser-content h1 {
  max-width: 15ch;
  margin: 0;
  color: var(--teaser-title);
  font-family: "Newsreader", Georgia, serif;
  font-size: clamp(2.25rem, 6vw, 4.65rem);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: 0;
}

.teaser-content p {
  max-width: 38rem;
  margin: clamp(16px, 2.4vw, 24px) 0 0;
  color: var(--teaser-text);
  font-size: clamp(1rem, 2vw, 1.2rem);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.015em;
}

.teaser-contact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px clamp(22px, 4vw, 34px);
  margin-top: clamp(24px, 4vw, 38px);
  opacity: 0;
  transform: translateY(10px);
}

.teaser-contact a {
  position: relative;
  display: inline-grid;
  gap: 6px;
  color: var(--teaser-title);
  text-decoration: none;
}

.teaser-contact a + a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(clamp(22px, 4vw, 34px) / -2);
  width: 1px;
  height: 34px;
  background: rgba(201, 154, 76, 0.38);
  transform: translateY(-50%);
}

.teaser-contact span {
  color: var(--teaser-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
}

.teaser-contact strong {
  font-size: clamp(0.95rem, 1.8vw, 1.08rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.teaser-page.is-complete .teaser-contact {
  opacity: 1;
  transform: none;
}

@keyframes teaser-draw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes teaser-soft-pop {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes teaser-watercolor {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes teaser-candle {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes teaser-wordmark {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes teaser-final-logo {
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes teaser-overlay-out {
  to {
    opacity: 0;
  }
}

@keyframes teaser-contact-in {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 640px) {
  .teaser-main {
    padding: 34px 18px;
  }

  .teaser-logo-stage {
    width: min(72vw, 280px);
    margin-bottom: 28px;
  }

  .teaser-content h1 {
    max-width: 12ch;
  }

  .teaser-content p {
    max-width: 18rem;
  }

  .teaser-contact {
    gap: 16px;
  }

  .teaser-contact a {
    width: 100%;
  }

  .teaser-contact a + a::before {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .teaser-logo-final,
  .teaser-logo-overlay,
  .teaser-draw,
  .teaser-leaves,
  .teaser-overlay-watercolor,
  .teaser-overlay-candle,
  .teaser-overlay-wordmark,
  .teaser-contact,
  .teaser-word-line,
  .teaser-word-underline {
    animation: none !important;
    transform: none;
  }

  .teaser-logo-final,
  .teaser-contact {
    opacity: 1;
  }

  .teaser-logo-overlay {
    opacity: 0;
  }
}
