/* =============================================
   BLOG INDEX
============================================= */

.blog-container {
  max-width: var(--project-w);
  width: 100%;
  margin: var(--margin-main);
  padding: var(--pad);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.blog-container h1,
#blogTitle {
  font-family: var(--font-display);
  font-size: var(--font-size-2xl);
  font-weight: 600;
  text-align: center;
  margin-bottom: 2rem;
  color: var(--txt-main);
  position: relative;
  padding-bottom: 0.6rem;
}

.blog-container h1::after,
#blogTitle::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 52px;
  height: 3px;
  background: var(--txt-accent);
  border-radius: 2px;
}

/* ─── Post grid — identičan posts-grid ──────── */

.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--project-gap);
  width: 100%;
  align-items: stretch;
}

/* ─── Post kartica — kao project-card ───────── */

.post-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: var(--txt-main);
  background: var(--bg-card);
  border-radius: var(--r-l);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-s);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--trans-med), box-shadow var(--trans-med);
}

.post-image {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: var(--r-l) var(--r-l) 0 0;
  background: var(--bg-card);
}

.post-image img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform var(--trans-med);
}

.post-content {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 0.4rem;
  border-top: 1px solid var(--border);
}

.post-title {
  font-family: var(--font-display);
  font-size: var(--font-size-l);
  font-weight: 400;
  color: var(--txt-main);
  line-height: var(--lh-tight);
  text-align: center;
}

.post-excerpt {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  color: var(--txt-2);
  line-height: var(--lh-base);
  flex: 1;
  text-align: center;
}

.post-meta {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  color: var(--txt-2);
  display: flex;
  justify-content: space-between;
  padding-top: 0.4rem;
  border-top: 1px solid var(--border);
  opacity: 0.8;
}

/* ─── Paginacija ─────────────────────────────── */

.pagination {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin: 2rem 0;
}

.page-btn {
  padding: 0.5rem 1rem;
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  border-radius: var(--r-m);
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--txt-2);
  cursor: pointer;
  transition: background var(--trans-fast), color var(--trans-fast), border-color var(--trans-fast);
}

.page-btn.active {
  background: var(--txt-accent);
  color: var(--white);
  border-color: var(--txt-accent);
  font-weight: 700;
}

.page-btn:disabled {
  opacity: 0.4;
  cursor: default;
}

/* ─── Hover ──────────────────────────────────── */

@media (hover: hover) and (pointer: fine) {
  .post-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-m);
  }

  .post-card:hover .post-image img {
    transform: scale(1.05);
  }

  .page-btn:hover:not(:disabled) {
    background: var(--btn-accent-h);
    color: var(--white);
    border-color: var(--btn-accent-h);
  }
}

/* =============================================
   BLOG POST STRANICA
============================================= */

.blog-post-container {
  max-width: var(--content-w);
  width: 100%;
  margin: var(--margin-main);
  padding: var(--pad);
}

.back-link {
  text-align: left !important;
  display: inline-block;
  margin-bottom: 1.5rem;
  font-family: var(--font-body);
  font-weight: 700;
  color: var(--txt-accent);
  text-decoration: none;
  transition: color var(--trans-fast);
}

.article h1 {
  font-family: var(--font-display);
  font-size: var(--font-size-2xl);
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--txt-main);
  line-height: var(--lh-tight);
}

.article-meta {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  color: var(--txt-2);
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}

/* ─── Article content ────────────────────────── */

.article-content {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--lh-base);
  color: var(--txt-main);
  text-align: justify;
}

.article-content h2 {
  font-family: var(--font-display);
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: var(--txt-main);
  margin: 3rem 0 0.7rem;
}

.article-content h3 {
  font-family: var(--font-display);
  font-size: var(--font-size-l);
  font-weight: 600;
  color: var(--txt-main);
  margin: 2rem 0 0.5rem;
}

.article-content p {
  margin-bottom: 0.7rem;
  color: var(--txt-2);
}

.article-content strong { font-weight: 700; color: var(--txt-main); }

.article-content em {
  font-style: italic;
  color: var(--txt-2);
}

.article-content a {
  color: var(--txt-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.article-content ul,
.article-content ol {
  margin: 1rem 0 1rem 1.5rem;
  line-height: var(--lh-base);
  color: var(--txt-2);
}

.article-content li { margin-bottom: 0.5rem; }

.article-content img {
  width: 100%;
  height: auto;
  border-radius: var(--r-l);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-m);
  margin: 1.5rem 0;
  display: block;
  object-fit: cover;
}

/* ─── Image gallery ──────────────────────────── */

.image-row { columns: 300px; }

.image-row img {
  display: inline-block;
  width: 100%;
  height: auto;
  border-radius: var(--r-l);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-s);
  margin: 0 0 1rem;
}

/* ─── Figure & caption ───────────────────────── */

.article-content figure { margin: 2rem 0; text-align: center; }
.article-content figure img { margin: 0; }

.article-content figcaption {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--font-size-s);
  color: var(--txt-accent);
  margin-top: 0.5rem;
}

/* ─── Hover (post stranica) ──────────────────── */

@media (hover: hover) and (pointer: fine) {
  .back-link:hover {
    color: var(--txt-accent-l);
    text-decoration: underline;
  }

  #submitBtn:hover:not(:disabled) {
    background: var(--btn-accent-h);
    color: var(--white);
    border-color: var(--btn-accent-h);
  }
}

/* =============================================
   KOMENTARI
============================================= */

.comments-section {
  margin: 5rem 0 2rem;
  background: var(--bg-card);
  padding: 1.5rem;
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-s);
  border: 1px solid var(--border);
}

.comments-header {
  font-family: var(--font-display);
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin-bottom: 1.5rem;
  color: var(--txt-main);
}

/* ─── Comment form ───────────────────────────── */

.comment-form {
  background: var(--bg-main);
  margin: 1rem 0;
  padding: 1.5rem;
  border-radius: var(--r-l);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-s);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.comment-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.comment-form input,
.comment-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: var(--r-m);
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--txt-main);
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  transition: border-color var(--trans-fast), background var(--trans-fast);
}

.comment-form input:focus,
.comment-form textarea:focus {
  border-color: var(--txt-accent);
  outline: none;
  background: var(--bg-card-h);
}

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

#submitBtn {
  align-self: flex-start;
  padding: 0.75rem 2rem;
  border-radius: 999px;
  border: none;
  background: var(--txt-accent);
  color: var(--white);
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: 700;
  cursor: pointer;
  transition: background var(--trans-fast);
}

#submitBtn:disabled {
  opacity: 0.5;
  cursor: default;
}

.success-msg,
.error-msg {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  padding: 0.5rem 0.75rem;
  border-radius: var(--r-m);
  display: none;
}

.success-msg.show {
  display: block;
  background: var(--color-success-bg);
  color: var(--color-success-txt);
}

.error-msg.show {
  display: block;
  background: var(--color-error-bg);
  color: var(--color-error-txt);
}

#turnstile-container {
  display: flex;
  transition: opacity var(--trans-fast), transform var(--trans-fast);
}

#turnstile-container.hidden {
  opacity: 0;
  transform: scale(0.98);
  pointer-events: none;
}

/* ─── Comments list ──────────────────────────── */

.comments-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.comments-list .comment {
  background: var(--bg-main);
  padding: 0.85rem 1rem;
  border-radius: var(--r-m);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-s);
}

.comments-list .comment-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.35rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--border);
}

.comments-list .comment-author {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--font-size-s);
  color: var(--txt-accent);
}

.comments-list .comment-date {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  color: var(--txt-2);
  white-space: nowrap;
}

.comments-list .comment-text {
  font-family: var(--font-body);
  font-size: var(--font-size-s);
  line-height: var(--lh-base);
  color: var(--txt-main);
  margin-top: 0.25rem;
}

/* =============================================
   RESPONSIVE
============================================= */

@media (max-width: 600px) {
  .comment-form .form-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .post-image {
    aspect-ratio: 16 / 10;
  }
}
