/* ============================================================
   Sentimind — Sidebar Components
   기념일 카드, 감정 어휘 성장, 회고 카드, 감정 예보
   ============================================================ */

/* ===== AI Relationship Anniversary Card ===== */
.anniversary-card {
  background: linear-gradient(135deg, var(--color-surface) 0%, rgba(196, 139, 108, 0.08) 100%);
  border: 1px solid rgba(196, 139, 108, 0.25);
  overflow: hidden;
  position: relative;
}
.anniversary-card[hidden] { display: none; }
.anniversary-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary), #F4A261, var(--color-primary));
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.anniversary-card-inner {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}
.anniversary-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
  line-height: 1;
}
.anniversary-body {
  flex: 1;
  min-width: 0;
}
.anniversary-title {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.25rem;
  letter-spacing: 0.02em;
}
.anniversary-message {
  font-family: var(--font-diary);
  font-size: 0.85rem;
  color: var(--color-text);
  line-height: 1.5;
}

[data-theme="dark"] .anniversary-card {
  background: linear-gradient(135deg, var(--color-surface) 0%, rgba(251, 146, 60, 0.05) 100%);
  border-color: rgba(251, 146, 60, 0.15);
}

/* ===== Emotion Vocabulary Growth Card ===== */
.emotion-vocab-card[hidden] { display: none; }
.emotion-vocab-inner { padding: 0.25rem 0; }
.emotion-vocab-count {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}
.emotion-vocab-number {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1;
}
.emotion-vocab-label {
  font-size: 0.9rem;
  color: var(--color-text-secondary);
}
.emotion-vocab-bar {
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
  margin-bottom: 0.6rem;
}
.emotion-vocab-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  transition: transform 0.2s;
  cursor: default;
  position: relative;
}
.emotion-vocab-dot:hover {
  transform: scale(1.3);
  z-index: 1;
}
.emotion-vocab-dot[title]::after {
  content: attr(title);
  position: absolute;
  bottom: 110%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-text);
  color: var(--color-bg);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.7rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s;
}
.emotion-vocab-dot:hover[title]::after { opacity: 1; }
.emotion-vocab-message {
  font-size: 0.85rem;
  color: var(--color-text-secondary);
  line-height: 1.5;
}

/* ===== 1개월 전 오늘의 마음 회고 카드 ===== */
.memory-card[hidden] { display: none; }
.memory-card {
  background: linear-gradient(135deg, var(--color-surface) 0%, rgba(196, 139, 108, 0.06) 100%);
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}
.memory-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary-light, #D4A574), var(--color-primary));
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.memory-card-inner {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding-top: 0.25rem;
}
.memory-card-emoji {
  font-size: 1.8rem;
  line-height: 1;
  flex-shrink: 0;
}
.memory-card-body {
  flex: 1;
  min-width: 0;
}
.memory-card-emotion {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.25rem;
}
.memory-card-text {
  font-size: 0.82rem;
  color: var(--color-text-secondary);
  line-height: 1.55;
  font-family: var(--font-diary);
  word-break: break-word;
}
.memory-card-date {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 0.3rem;
}
[data-theme="dark"] .memory-card {
  background: linear-gradient(135deg, var(--color-surface) 0%, rgba(251, 146, 60, 0.04) 100%);
}

/* ===== AI 감정 예보 카드 ===== */
.forecast-card[hidden] { display: none; }
.forecast-content { text-align: center; }
.forecast-icon {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 0.3rem;
}
.forecast-message {
  font-family: var(--font-diary);
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: var(--leading-relaxed);
  margin: 0 0 0.5rem;
}
.forecast-tip {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0;
}

