/* ============================================================
   Beauty Animations — Re:Body 装飾アニメーション
   ============================================================ */

/* ── 出現アニメーション ── */

/* ふんわり上から(Beauty定番) */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition:
    opacity 0.8s cubic-bezier(0.25, 0.1, 0.25, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* 左からフェードイン */
.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition:
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}

/* 右からフェードイン */
.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition:
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}

/* 拡大しながら出現 */
.reveal-bloom {
  opacity: 0;
  transform: scale(0.92);
  transition:
    opacity 0.8s cubic-bezier(0.25, 0.1, 0.25, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-bloom.visible {
  opacity: 1;
  transform: scale(1);
}

/* 遅延クラス */
.delay-100 { transition-delay: 0.1s; }
.delay-200 { transition-delay: 0.2s; }
.delay-300 { transition-delay: 0.3s; }
.delay-400 { transition-delay: 0.4s; }
.delay-500 { transition-delay: 0.5s; }

/* ── ループアニメーション ── */

/* キラキラ(CTA強調) */
@keyframes shimmer {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 1; }
}
.shimmer { animation: shimmer 2.5s ease-in-out infinite; }

/* ふわふわ浮遊 */
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-10px); }
}
.float { animation: float 3.5s ease-in-out infinite; }

/* ゆらゆら */
@keyframes sway {
  0%, 100% { transform: rotate(-3deg); }
  50%       { transform: rotate(3deg); }
}
.sway { animation: sway 5s ease-in-out infinite; }

/* ゆっくり回転(花びら装飾等) */
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.spin-slow { animation: spin-slow 25s linear infinite; }
.spin-slow-reverse { animation: spin-slow 25s linear infinite reverse; }

/* 点滅(新着バッジ等) */
@keyframes blink-soft {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}
.blink-soft { animation: blink-soft 1.8s ease-in-out infinite; }

/* ── カウントアップ(数値見せる演出) ── */
.count-up { transition: all 0.5s ease-out; }

/* ── ホバーエフェクト ── */

/* カード持ち上がり */
.hover-lift {
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.3s ease;
}
.hover-lift:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(232,114,154,0.18);
}

/* ボタン押し込み */
.hover-press {
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.hover-press:active {
  transform: translateY(2px);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
}

/* ── モーション軽減 ── */
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-left, .reveal-right, .reveal-bloom {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .shimmer, .float, .sway, .spin-slow, .spin-slow-reverse, .blink-soft {
    animation: none;
  }
}
