:root {
   /* palet utama tafakkur */
  --leaf: #A7C7A3;   /* hijau alami, tenang */
  --gold: #C9B47E;   /* cahaya hangat, spiritual */
  --mist: #F3F5F2;   /* putih keabu lembut, netral */


  /* tambahan tone harmonis */
  --sage: #D9E2D5;   /* hijau muda lembut, netral dan natural */
  --fern: #B7C8A2;   /* hijau paku, sedikit lebih hidup dari leaf */
  --sand: #E8E1C5;   /* pasir hangat, penghubung gold ↔ mist */
  --clay: #D4C7A1;   /* tanah lembut, tone hangat reflektif */
  --linen: #EEEAE0;  /* krem susu lembut, latar ringan atau hover */
}

body {
  background: linear-gradient(to bottom right, #f8faf8, #edf3ef);
  font-family: 'Inter', sans-serif;
}

/* -----------------------
   ✦ Animasi Global
------------------------*/
.fade {
  opacity: 0;
  transform: translateY(15px);
  transition: opacity 1.2s ease, transform 1.2s ease;
}
.fade.show {
  opacity: 1;
  transform: translateY(0);
}

#btn {
  opacity: 0;
  transition: opacity 1s ease-in-out;
}
#btn.show {
  opacity: 1;
}

/* Dropdown */
#dropdown-other, #dropdown-user {
  min-width: 15rem;
}

/* Smooth appear */
.fade-smooth {
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSmooth 0.8s ease forwards;
}
@keyframes fadeSmooth {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Soft Shadow */
.shadow-soft {
  box-shadow: 0 4px 14px rgba(0,0,0,0.05);
}

/* -----------------------
   ✦ Mood Selector Animation
------------------------*/
@keyframes moodPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 rgba(0,0,0,0); }
  50% { transform: scale(1.08); box-shadow: 0 0 20px rgba(0,0,0,0.08); }
}
.peer:checked + div {
  animation: moodPulse 1.2s ease-in-out infinite;
}

/* -----------------------
   ✦ Image Hover
------------------------*/
img {
  transition: transform 0.3s ease, opacity 0.3s ease;
}
img:hover {
  opacity: 0.95;
}

/* -----------------------
   ✦ Subtle Animations
------------------------*/
@keyframes bounce-slow {
  0%, 100% { transform: translateY(0) scale(1.05); }
  50% { transform: translateY(-6px) scale(1.1); }
}
.animate-bounce-slow {
  animation: bounce-slow 2.5s infinite ease-in-out;
}

@keyframes fadeGlow {
  0%, 100% { opacity: 0.7; transform: scale(1); filter: drop-shadow(0 0 3px rgba(76,175,80,0.2)); }
  50% { opacity: 1; transform: scale(1.08); filter: drop-shadow(0 0 6px rgba(76,175,80,0.4)); }
}
.animate-fadeGlow {
  animation: fadeGlow 1s ease-in-out infinite;
}

@keyframes fadeInSlow {
  0% { opacity: 0; transform: translateY(10px); }
  100% { opacity: 1; transform: translateY(0); }
}
.animate-fadeInSlow {
  animation: fadeInSlow 0.8s ease-out forwards;
}

/* -----------------------
   ✦ Grid Animation (fix)
------------------------*/
/* ❌ Dulu ini yang bikin rusak layout:
   .grid, [class*="grid-cols-"] { display: grid !important; }
   Itu menimpa semua grid anak dari Tailwind.
*/

/* ✅ Perbaikan: hanya tambahkan animasi pada elemen grid,
   tanpa mengubah display bawaan Tailwind */
.grid > * {
  animation: fadeSmooth 0.6s ease forwards;
  opacity: 0;
}
.grid > *:nth-child(1) { animation-delay: 0.1s; }
.grid > *:nth-child(2) { animation-delay: 0.2s; }
.grid > *:nth-child(3) { animation-delay: 0.3s; }
.grid > *:nth-child(4) { animation-delay: 0.4s; }

.prose p {
    margin-bottom: .5rem;
}
.prose ul, .prose ol {
    margin-left: 1.25rem;
    margin-bottom: .75rem;
}
.prose strong {
    color: var(--night);
}
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(5px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-fadeIn {
    animation: fadeIn .4s ease-in-out;
}
.reaction-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 1.25rem;
    transition: all 0.2s ease;
    border-radius: 0.5rem;
    padding: 0.25rem 0.5rem;
}
.reaction-btn:hover::after {
    content: attr(title);
    position: absolute;
    background: rgba(255,255,255,0.95);
    color: #4b8b6f;
    font-size: 0.75rem;
    padding: 4px 8px;
    border-radius: 6px;
    top: -28px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}
.reflection-content {
    white-space: pre-line;
    word-break: break-word;
}
.reaction-btn.active {
    background: rgba(76,175,80,0.15);
    transform: scale(1.2);
}
.group > .absolute {
    pointer-events: none;
}
.journey-resonance-card {
  position: relative;
  overflow: hidden;
}

.journey-resonance-card::before,
.journey-resonance-card::after {
  content: '';
  position: absolute;
  border-radius: 9999px;
  opacity: 0.35;
  pointer-events: none;
}

.journey-resonance-card::before {
  width: 320px;
  height: 320px;
  top: -180px;
  left: -140px;
  background: radial-gradient(circle at center, rgba(16, 185, 129, 0.35), transparent 70%);
  filter: blur(2px);
  animation: journeyGlow 12s ease-in-out infinite alternate;
}

.journey-resonance-card::after {
  width: 260px;
  height: 260px;
  bottom: -160px;
  right: -120px;
  background: radial-gradient(circle at center, rgba(236, 72, 153, 0.3), transparent 70%);
  filter: blur(4px);
  animation: journeyGlow 14s ease-in-out infinite alternate-reverse;
}

.journey-floating-orb {
  position: absolute;
  top: -3rem;
  right: -2.5rem;
  font-size: clamp(4rem, 8vw, 8rem);
  opacity: 0.18;
  transform-origin: center;
  animation: floatOrb 10s ease-in-out infinite alternate;
}

.reaction-card {
  opacity: 0;
  transform: translateY(18px) scale(0.96);
  transition: opacity 0.6s ease, transform 0.6s ease, box-shadow 0.4s ease;
}

.reaction-card.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.reaction-card:hover {
  box-shadow: 0 20px 45px -25px rgba(34, 197, 94, 0.45);
}

@keyframes journeyGlow {
  from {
    transform: scale(0.95) translate3d(0, 0, 0);
    opacity: 0.25;
  }
  to {
    transform: scale(1.1) translate3d(12px, -6px, 0);
    opacity: 0.45;
  }
}

@keyframes floatOrb {
  from {
    transform: translate3d(0, 0, 0) rotate(-6deg);
  }
  to {
    transform: translate3d(-16px, 10px, 0) rotate(8deg);
  }
}

.journey-mood-card {
  position: relative;
  overflow: hidden;
}

.journey-mood-card::before,
.journey-mood-card::after {
  content: '';
  position: absolute;
  pointer-events: none;
  border-radius: 9999px;
  opacity: 0.28;
}

.journey-mood-card::before {
  top: -140px;
  right: -160px;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle at center, rgba(52, 211, 153, 0.35), transparent 70%);
  filter: blur(4px);
  animation: journeyGlow 16s ease-in-out infinite alternate;
}

.journey-mood-card::after {
  bottom: -180px;
  left: -120px;
  width: 240px;
  height: 240px;
  background: radial-gradient(circle at center, rgba(125, 211, 252, 0.32), transparent 70%);
  filter: blur(6px);
  animation: journeyGlow 18s ease-in-out infinite alternate-reverse;
}

.mood-weekly-bar {
  position: relative;
  transform-origin: bottom;
  opacity: 1;
  overflow: hidden;
  will-change: transform, box-shadow;
  transition: box-shadow 0.4s ease;
  min-height: 12px;
  height: calc(var(--mood-bar-level, 1) * 14px);
}

.mood-weekly-bar::after {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.35), transparent 70%);
  opacity: 0;
  transform: translateY(20%);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.group:hover .mood-weekly-bar {
  box-shadow: 0 18px 32px rgba(16, 185, 129, 0.25);
}

.group:hover .mood-weekly-bar::after {
  opacity: 1;
  transform: translateY(0);
}

.mood-weekly-bar.is-visible {
  animation: journeyMoodGrow 0.9s ease forwards;
}

@keyframes journeyMoodGrow {
  0% {
    transform: scaleY(0.2);
    opacity: 0;
  }
  65% {
    opacity: 1;
  }
  100% {
    transform: scaleY(1);
    opacity: 1;
  }
}

.mood-weekly-emoji {
  opacity: 1;
  left: 50%;
  transform: translate(-50%, 0);
  transition: transform 0.35s ease;
}

.group:hover .mood-weekly-emoji {
  transform: translate(-50%, -6px) scale(1.08);
}

.mood-weekly-label {
  opacity: 0;
  left: 50%;
  transform: translate(-50%, 8px);
  filter: blur(4px);
  transition: opacity 0.35s ease, transform 0.35s ease, filter 0.35s ease;
}

.group:hover .mood-weekly-label,
.mood-weekly-label.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
  filter: blur(0);
}
