/* ============================================================
   コメントセクション 共通スタイル
   全TOP3記事末尾に組み込み
   ============================================================ */

.comments-section {
  max-width: 900px;
  margin: 40px auto 60px;
  padding: 0 20px;
  font-family: 'Inter', 'Hiragino Sans', 'Yu Gothic', 'Meiryo', sans-serif;
}

.comments-section h2.comments-title {
  font-family: 'Lora', 'Hiragino Mincho ProN', 'Yu Mincho', Georgia, serif;
  font-size: 22px;
  font-weight: 600;
  color: #1A1915;
  margin-bottom: 18px;
  padding-left: 12px;
  border-left: 4px solid #E85A50;
  letter-spacing: -.005em;
}

.comments-count {
  font-size: 12px;
  color: #8E8B7E;
  margin-left: 10px;
  font-weight: 500;
}

/* ----- コメント一覧 ----- */
.comments-list {
  margin-bottom: 28px;
}

.comments-empty {
  background: #FBF7EE;
  border: 1px solid #E5E0CF;
  border-radius: 10px;
  padding: 24px;
  text-align: center;
  font-size: 14px;
  color: #5C594F;
  line-height: 1.7;
}

.comment-item {
  background: #fff;
  border: 1px solid #E5E0CF;
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 12px;
  box-shadow: 0 1px 4px rgba(26,25,21,.04);
}

.comment-item.is-reply {
  margin-left: 32px;
  background: #FBF3EF;
  border-color: #F4D9D2;
}

.comment-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.comment-nickname {
  font-size: 13px;
  font-weight: 700;
  color: #1A1915;
}

.comment-item.is-admin .comment-nickname {
  color: #C44539;
}

.comment-admin-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  background: #C44539;
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: .04em;
}

.comment-date {
  font-size: 11px;
  color: #8E8B7E;
}

.comment-body {
  font-size: 14px;
  color: #1A1915;
  line-height: 1.8;
  word-break: break-word;
}

/* ----- コメント投稿フォーム ----- */
.comment-form {
  background: #fff;
  border: 1px solid #E5E0CF;
  border-radius: 14px;
  padding: 20px 22px;
  box-shadow: 0 2px 10px rgba(26,25,21,.05);
}

.comment-form-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 12px;
  flex-wrap: wrap;
  gap: 8px;
}

.comment-form-title {
  font-size: 15px;
  font-weight: 700;
  color: #1A1915;
  margin: 0;
}

.comment-form-note {
  font-size: 11px;
  color: #8E8B7E;
}

.comment-form label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #5C594F;
  margin: 12px 0 4px;
}

.comment-form input[type="text"],
.comment-form textarea {
  width: 100%;
  font-family: inherit;
  font-size: 14px;
  color: #1A1915;
  border: 1px solid #D4CDB5;
  border-radius: 8px;
  padding: 10px 12px;
  background: #FAF9F5;
  box-sizing: border-box;
  transition: border-color .15s, background .15s;
}

.comment-form input[type="text"]:focus,
.comment-form textarea:focus {
  outline: none;
  border-color: #E85A50;
  background: #fff;
}

.comment-form textarea {
  min-height: 100px;
  resize: vertical;
  line-height: 1.7;
}

.comment-form-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 14px;
  padding: 11px 24px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  background: #E85A50;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: background .15s, transform .15s, box-shadow .15s;
}

.comment-form-submit:hover {
  background: #C44539;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(232,90,80,.30);
}

.comment-form-submit:disabled {
  background: #C9BDA3;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.comment-form-message {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.6;
  display: none;
}

.comment-form-message.is-success {
  background: #E8F5E9;
  color: #2E7D32;
  border: 1px solid #A5D6A7;
  display: block;
}

.comment-form-message.is-error {
  background: #FCE4EC;
  color: #C62828;
  border: 1px solid #F4C9C9;
  display: block;
}

.comment-form-disclaimer {
  margin-top: 14px;
  padding: 10px 14px;
  background: #FBF7EE;
  border-radius: 8px;
  font-size: 11px;
  color: #8E8B7E;
  line-height: 1.7;
}

@media (max-width: 600px) {
  .comments-section { padding: 0 14px; }
  .comment-item { padding: 12px 14px; }
  .comment-item.is-reply { margin-left: 18px; }
  .comment-form { padding: 16px; }
}
