/* ==========================================================================
   COMMENTS
   ========================================================================== */
.comments {
  margin-top: clamp(56px, 8vw, 96px);
  padding-top: clamp(40px, 6vw, 64px);
  padding-bottom: clamp(80px, 10vw, 140px);
  border-top: 1px solid var(--line);
}
.comments__head {
  margin-bottom: clamp(32px, 4vw, 48px);
  display: grid;
  gap: 12px;
}
.comments__title {
  font-family: var(--ff-ar-display);
  font-weight: 500;
  font-size: var(--step-3);
  line-height: 1.1;
  letter-spacing: -.01em;
  margin: 0;
}
:root[lang="en"] .comments__title {
  font-family: var(--ff-en-display);
  font-weight: 400;
  letter-spacing: -.02em;
}
.comments__closed {
  color: var(--fg-muted);
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  letter-spacing: .04em;
  padding: 20px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

/* ============ List ============ */
.comment-list,
.comment-list .children {
  list-style: none;
  padding: 0;
  margin: 0;
}
.comment-list > li.comment-item {
  padding: clamp(20px, 2.5vw, 32px) 0;
  border-top: 1px solid var(--line);
}
.comment-list > li.comment-item:last-child {
  border-bottom: 1px solid var(--line);
}
.comment-list .children {
  margin-top: clamp(20px, 2.5vw, 32px);
  padding-inline-start: clamp(20px, 3vw, 48px);
  border-inline-start: 2px solid var(--line);
}
.comment-list .children > li.comment-item {
  padding: clamp(16px, 2vw, 24px) 0;
  border-top: 1px solid var(--line);
}
.comment-list .children > li.comment-item:first-child { border-top: 0; }

.comment-body {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: clamp(14px, 2vw, 22px);
  align-items: start;
}

.comment__avatar-img {
  border-radius: 50%;
  width: 48px;
  height: 48px;
  display: block;
  background: var(--panel);
}

.comment__content {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.comment__meta {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  color: var(--fg-muted);
  letter-spacing: .03em;
}
.comment__author {
  font-family: var(--ff-ar-body);
  font-weight: 500;
  font-size: var(--step-0);
  color: var(--fg);
  letter-spacing: 0;
}
:root[lang="en"] .comment__author { font-family: var(--ff-en-body); }
.comment__date a {
  color: var(--fg-muted);
  transition: color .25s var(--ease);
}
.comment__date a:hover { color: var(--accent); }
.comment__awaiting {
  color: var(--accent);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .08em;
  padding: 2px 8px;
  border: 1px dashed var(--accent);
  border-radius: 999px;
}

.comment__text {
  color: var(--fg-soft);
  font-size: var(--step-0);
  line-height: 1.65;
  text-wrap: pretty;
}
.comment__text p { margin: 0 0 12px; }
.comment__text p:last-child { margin-bottom: 0; }
.comment__text a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.comment__text a:hover { color: var(--contrast-2); }
.comment__text blockquote {
  margin: 12px 0;
  padding-inline-start: 16px;
  border-inline-start: 2px solid var(--accent);
  color: var(--fg);
  font-style: italic;
}
.comment__text code {
  font-family: var(--ff-mono);
  font-size: 0.92em;
  background: var(--panel);
  padding: 1px 6px;
  border-radius: 4px;
}

.comment__actions {
  display: flex;
  align-items: center;
  gap: 18px;
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  letter-spacing: .04em;
}
.comment__reply .comment-reply-link,
.comment__edit a {
  color: var(--fg-muted);
  padding: 4px 10px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
  text-decoration: none;
}
.comment__reply .comment-reply-link:hover,
.comment__edit a:hover {
  color: #fff;
  background: var(--accent);
  border-color: var(--accent);
}

.comments__pagination {
  margin-top: clamp(32px, 4vw, 48px);
  display: flex;
  gap: 12px;
  justify-content: center;
}
.comments__pagination .page-numbers {
  padding: 8px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: var(--fg-soft);
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.comments__pagination .page-numbers.current,
.comments__pagination .page-numbers:hover {
  color: #fff;
  background: var(--accent);
  border-color: var(--accent);
}

/* ============ Form ============ */
.comment-respond {
  margin-top: clamp(56px, 8vw, 96px);
  padding-top: clamp(40px, 6vw, 64px);
  border-top: 1px solid var(--line);
}
#reply-title {
  font-family: var(--ff-ar-display);
  font-weight: 500;
  font-size: var(--step-2);
  letter-spacing: -.01em;
  margin: 0 0 20px;
}
:root[lang="en"] #reply-title { font-family: var(--ff-en-display); font-weight: 400; letter-spacing: -.02em; }

#cancel-comment-reply-link {
  display: inline-block;
  margin-inline-start: 14px;
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  color: var(--fg-muted);
}
#cancel-comment-reply-link:hover { color: var(--accent); }

.comment-notes {
  margin-bottom: 24px;
}

.comment-form {
  display: grid;
  gap: 18px;
}
.comment-form label {
  display: block;
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  letter-spacing: .04em;
  color: var(--fg-muted);
  margin-bottom: 8px;
}
.comment-form label .req { color: var(--accent); }

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 14px 16px;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  font-family: var(--ff-ar-body);
  font-size: var(--step-0);
  line-height: 1.5;
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
:root[lang="en"] .comment-form input,
:root[lang="en"] .comment-form textarea { font-family: var(--ff-en-body); }

.comment-form textarea {
  resize: vertical;
  min-height: 160px;
}

.comment-form input:focus,
.comment-form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);
}

.comment-form .comment-form-author,
.comment-form .comment-form-email,
.comment-form .comment-form-url,
.comment-form .comment-form-comment {
  margin: 0;
}

.comment-form-cookies-consent {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  color: var(--fg-muted);
  letter-spacing: .02em;
  margin: 0;
}
.comment-form-cookies-consent input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
}
.comment-form-cookies-consent label {
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
}

.form-submit {
  margin: 6px 0 0;
}
.form-submit .submit,
.form-submit input[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  border: 0;
  font-family: var(--ff-ar-body);
  font-weight: 500;
  font-size: var(--step-0);
  cursor: pointer;
  transition: transform .25s var(--ease), background .25s var(--ease);
}
:root[lang="en"] .form-submit .submit,
:root[lang="en"] .form-submit input[type="submit"] { font-family: var(--ff-en-body); }

.form-submit .submit:hover,
.form-submit input[type="submit"]:hover {
  background: var(--contrast);
  transform: translateY(-1px);
}

.logged-in-as,
.must-log-in {
  font-family: var(--ff-mono);
  font-size: var(--step--1);
  color: var(--fg-muted);
  letter-spacing: .03em;
}
.logged-in-as a,
.must-log-in a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (max-width: 640px) {
  .comment-body {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .comment__avatar-img { width: 40px; height: 40px; }
  .comment__actions { flex-wrap: wrap; }
}

/* Grid form fields side-by-side on wider viewports */
@media (min-width: 680px) {
  .comment-form {
    grid-template-columns: 1fr 1fr;
  }
  .comment-form .comment-notes,
  .comment-form .comment-form-comment,
  .comment-form .comment-form-url,
  .comment-form .comment-form-cookies-consent,
  .comment-form .form-submit,
  .comment-form .logged-in-as,
  .comment-form .must-log-in {
    grid-column: 1 / -1;
  }
}
