/* ============================================================
   Feedback — Like/Dislike, Bookmark, Inline Form
   ============================================================ */

/* ── Action Bar (bookmark + like + dislike) ── */
.action-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-4) 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin: var(--space-8) 0 var(--space-6);
  flex-wrap: wrap;
}

.action-bar-label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-right: var(--space-2);
}

/* ── Feedback Buttons ── */
.feedback-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: var(--transition-colors), box-shadow var(--transition-base),
              transform var(--transition-fast);
  user-select: none;
}

.feedback-btn:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.feedback-btn:active { transform: translateY(0); }

/* Bookmark */
.bookmark-btn:hover {
  background: #fffbeb;
  border-color: #fde68a;
  color: var(--color-bookmark-active);
}

.bookmark-btn.active {
  background: #fffbeb;
  border-color: #fde68a;
  color: var(--color-bookmark-active);
}

/* Like */
.like-btn:hover {
  background: var(--color-primary-50);
  border-color: var(--color-primary-200);
  color: var(--color-like-active);
}

.like-btn.active {
  background: var(--color-primary-50);
  border-color: var(--color-primary-300);
  color: var(--color-like-active);
  font-weight: var(--weight-semibold);
}

/* Dislike */
.dislike-btn:hover {
  background: #fff1f2;
  border-color: #fecdd3;
  color: var(--color-dislike-active);
}

.dislike-btn.active {
  background: #fff1f2;
  border-color: #fecdd3;
  color: var(--color-dislike-active);
  font-weight: var(--weight-semibold);
}

/* ── Vote Count ── */
.feedback-count {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  min-width: 12px;
  text-align: center;
}

/* ── Pulse animation for new vote ── */
@keyframes pulse-feedback {
  0% { transform: scale(1); }
  50% { transform: scale(1.15); }
  100% { transform: scale(1); }
}
.feedback-btn.pulse { animation: pulse-feedback 0.3s ease; }

/* ── Inline Feedback Form ── */
.feedback-section {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-gray-50);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}

.feedback-section-title {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.feedback-section-sub {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

.feedback-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.feedback-form-row {
  display: flex;
  gap: var(--space-2);
}

.feedback-author {
  width: 100%;
  max-width: 100%;
  padding: 8px 12px;
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.feedback-form-row .feedback-author {
  flex: 0 0 auto;
  width: 200px;
}
.feedback-author:focus {
  border-color: var(--color-primary-400);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}
.feedback-author::placeholder { color: var(--color-text-subtle); }

.feedback-textarea {
  width: 100%;
  min-height: 100px;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  resize: vertical;
  outline: none;
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

.feedback-textarea::placeholder { color: var(--color-text-subtle); }

.feedback-textarea:focus {
  border-color: var(--color-primary-400);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

.feedback-form-actions {
  display: flex;
  justify-content: flex-end;
}

/* ── Submitted Comments List ── */
.feedback-comments {
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.feedback-comment-item {
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
  position: relative;
}

.feedback-comment-meta {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
  margin-bottom: var(--space-2);
  display: flex;
  align-items: center;
  gap: 6px;
}
.feedback-comment-author {
  font-weight: var(--weight-semibold);
  color: var(--color-primary-700);
}
.feedback-comment-dot { opacity: 0.5; }
.feedback-comment-text {
  color: var(--color-text);
  white-space: pre-wrap;
  word-break: break-word;
}

.feedback-comment-delete {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: var(--transition-colors);
  background: none;
  border: none;
}

.feedback-comment-delete:hover {
  background: var(--color-danger-light);
  color: var(--color-danger);
}

/* ── Feedback Collection Page ── */
.feedback-collection-group {
  margin-bottom: var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-bg);
}

.feedback-collection-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--color-gray-50);
  border-bottom: 1px solid var(--color-border);
  text-decoration: none;
  color: var(--color-text);
  transition: var(--transition-colors);
}
.feedback-collection-link:hover {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  text-decoration: none;
}

.feedback-collection-title {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
}

.feedback-collection-count {
  font-size: 11px;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-700);
  background: var(--color-primary-100);
  padding: 2px 10px;
  border-radius: var(--radius-full);
}

.feedback-collection-items {
  padding: var(--space-3) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.feedback-collection-item {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
}
.feedback-collection-item:last-child { border-bottom: none; }

/* ── Floating Feedback Widget ── */
.feedback-float {
  position: fixed;
  bottom: var(--space-8);
  right: var(--space-8);
  z-index: 200;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-2);
}

.feedback-float--above-fab {
  bottom: calc(var(--space-8) + 44px + var(--space-3));
}

/* 트리거 버튼 */
.feedback-float-trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: #fff;
  background: var(--color-primary-600);
  border: none;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  cursor: pointer;
  transition: background var(--transition-base), box-shadow var(--transition-base),
              transform var(--transition-fast);
}

.feedback-float-trigger:hover {
  background: var(--color-primary-700);
  box-shadow: var(--shadow-xl);
  transform: translateY(-2px);
}

.feedback-float.is-open .feedback-float-trigger {
  background: var(--color-gray-600);
}

/* 패널 */
.feedback-float-panel[hidden] { display: none; }

.feedback-float-panel {
  width: 340px;
  max-width: calc(100vw - var(--space-6));
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  animation: feedback-panel-in 0.15s ease;
}

@keyframes feedback-panel-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.feedback-float-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.feedback-float-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.feedback-float-close {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition-colors);
}

.feedback-float-close:hover {
  background: var(--color-gray-100);
  color: var(--color-text);
}

.feedback-float-votes {
  display: flex;
  gap: var(--space-2);
}

.feedback-float-divider {
  height: 1px;
  background: var(--color-border);
  margin: 0 calc(var(--space-1) * -1);
}

/* 빠른 피드백 버튼 */
.feedback-quick-btns {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.feedback-quick-btn {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: var(--transition-colors);
  user-select: none;
}

.feedback-quick-btn:hover {
  background: var(--color-gray-100);
  color: var(--color-text);
}

.feedback-quick-btn.selected {
  background: var(--color-primary-50);
  border-color: var(--color-primary-300);
  color: var(--color-primary-700);
}

/* ── Toast Notification ── */
.toast {
  position: fixed;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--color-gray-800);
  color: var(--color-text-inverse);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-toast);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
