/* ImageResizerly — blog: listing + artykul. Na zmiennych z app.css (motyw ciemny gratis). */

/* ===== HERO listingu ===== */
.blog-hero { padding: 56px 0 28px; text-align: center; }
.blog-hero-title { font-size: 2.2rem; font-weight: 800; letter-spacing: -.02em; margin: 14px 0 10px; }
.blog-hero-sub { font-size: 1.05rem; color: var(--text-muted); max-width: 620px; margin: 0 auto; line-height: 1.6; }

/* ===== Siatka kafelkow ===== */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.blog-grid--3 { margin-top: 18px; }
@media (max-width: 900px) { .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: transform .15s, box-shadow .15s, border-color .15s; }
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--accent-mid); }
.blog-card-link { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; }
.blog-card-img { aspect-ratio: 16 / 9; overflow: hidden; background: var(--bg-secondary); }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card-img--ph { display: flex; align-items: center; justify-content: center; color: var(--text-light);
  background: linear-gradient(135deg, var(--accent-light), var(--bg-secondary)); }
.blog-card-body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.blog-card-meta { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: var(--text-muted); }
.blog-card-title { font-size: 1.16rem; font-weight: 700; line-height: 1.32; letter-spacing: -.01em; margin: 2px 0; }
.blog-card-excerpt { font-size: .92rem; color: var(--text-muted); line-height: 1.55; flex: 1; }
.blog-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px;
  font-size: .8rem; color: var(--text-light); margin-top: 6px; }
.blog-card-author { font-weight: 600; color: var(--text-muted); }

.blog-cat { display: inline-block; font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--accent); background: var(--accent-light); padding: 3px 9px; border-radius: 20px; }
.blog-dot { color: var(--text-light); }

/* ===== Pusty stan ===== */
.blog-empty { text-align: center; padding: 60px 20px; color: var(--text-light); }
.blog-empty svg { margin-bottom: 14px; opacity: .6; }
.blog-empty p { font-size: 1.05rem; color: var(--text-muted); margin-bottom: 18px; }

/* ===== Paginacja ===== */
.blog-pager { display: flex; justify-content: center; gap: 8px; margin-top: 40px; }
.blog-pg { min-width: 38px; height: 38px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); border-radius: 9px; color: var(--text-muted); font-weight: 600; text-decoration: none; }
.blog-pg:hover { border-color: var(--accent); color: var(--accent); }
.blog-pg.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ===== ARTYKUL ===== */
.post-container { max-width: 1080px; }
.post { padding: 32px 0 56px; }
.post-crumb { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: .85rem;
  color: var(--text-muted); margin-bottom: 20px; }
.post-crumb a { color: var(--text-muted); text-decoration: none; }
.post-crumb a:hover { color: var(--accent); }
.post-crumb-cur { color: var(--text-light); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 320px; }

.post-head { max-width: 760px; }
.post-title { font-size: 2.35rem; font-weight: 800; letter-spacing: -.025em; line-height: 1.15; margin: 12px 0 14px; }
.post-lead { font-size: 1.18rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 16px; }
.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 9px; font-size: .88rem; color: var(--text-light); }
.post-author { font-weight: 600; color: var(--text-muted); }
.post-updated { font-style: italic; }

.post-hero { margin: 26px 0 6px; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); }
.post-hero img { width: 100%; display: block; }

.post-ainote { font-size: .82rem; color: var(--text-light); background: var(--bg-secondary);
  border: 1px dashed var(--border); border-radius: 9px; padding: 8px 13px; margin: 18px 0 0; }

/* layout TOC + tresc */
.post-layout { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 48px; margin-top: 30px; align-items: start; }
@media (max-width: 940px) { .post-layout { grid-template-columns: 1fr; gap: 22px; } }

.post-toc { position: sticky; top: 86px; }
@media (max-width: 940px) { .post-toc { position: static; } }
.post-toc-box { border-left: 2px solid var(--border); padding-left: 16px; }
.post-toc-title { font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-light); margin-bottom: 10px; }
.post-toc nav { display: flex; flex-direction: column; gap: 7px; }
.post-toc a { font-size: .87rem; color: var(--text-muted); text-decoration: none; line-height: 1.4; }
.post-toc a:hover { color: var(--accent); }
.post-toc a.toc-l3 { padding-left: 14px; font-size: .83rem; color: var(--text-light); }

/* ===== Typografia tresci (prose) ===== */
.prose { max-width: 760px; font-size: 1.06rem; line-height: 1.75; color: var(--text); }
.prose > p { margin: 0 0 18px; }
.prose h2 { font-size: 1.6rem; font-weight: 800; letter-spacing: -.02em; line-height: 1.25;
  margin: 40px 0 14px; padding-top: 6px; scroll-margin-top: 86px; }
.prose h3 { font-size: 1.24rem; font-weight: 700; line-height: 1.3; margin: 28px 0 10px; scroll-margin-top: 86px; }
.prose ul, .prose ol { margin: 0 0 20px; padding-left: 24px; }
.prose li { margin: 0 0 9px; line-height: 1.7; }
.prose li::marker { color: var(--accent); }
.prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.prose a:hover { color: var(--accent-hover); }
.prose strong { font-weight: 700; color: var(--text); }
.prose code { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: .88em;
  background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 5px; padding: 1px 6px; }
.prose blockquote { margin: 22px 0; padding: 4px 0 4px 20px; border-left: 3px solid var(--accent);
  color: var(--text-muted); font-style: italic; }
.prose hr { border: none; border-top: 1px solid var(--border); margin: 34px 0; }

/* ===== CTA do narzedzia ===== */
.post-cta { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  margin: 36px 0 10px; padding: 20px 24px; border-radius: var(--radius-lg);
  background: var(--accent-light); border: 1px solid var(--accent-mid); }
.post-cta-txt { display: flex; flex-direction: column; gap: 3px; }
.post-cta-txt strong { font-size: 1.06rem; }
.post-cta-txt span { font-size: .9rem; color: var(--text-muted); }
/* CTA to <a class="btn-primary"> wewnatrz .prose — .prose a nadpisywaloby kolor
   tekstu na akcent (indygo na indygo = niewidoczny). Przywracamy wyglad przycisku. */
.post-cta .btn-primary,
.post-cta .btn-primary:hover { color: #fff; text-decoration: none; }

/* ===== Box autora (E-E-A-T) ===== */
.post-author-box { display: flex; gap: 16px; align-items: flex-start; margin: 40px 0 0;
  padding: 22px; border-radius: var(--radius-lg); background: var(--bg-card); border: 1px solid var(--border); }
.post-author-avatar { flex-shrink: 0; width: 50px; height: 50px; border-radius: 50%; background: var(--accent);
  color: #fff; font-weight: 800; font-size: .95rem; display: flex; align-items: center; justify-content: center; }
.post-author-name { font-weight: 700; font-size: 1rem; margin-bottom: 4px; }
.post-author-bio { font-size: .9rem; color: var(--text-muted); line-height: 1.6; margin: 0; }

/* ===== Powiazane + powrot ===== */
.post-related { max-width: 1080px; margin: 56px auto 0; }
.post-related .section-title { text-align: center; }
.post-back { margin-top: 40px; }
.post-back a { color: var(--text-muted); text-decoration: none; font-weight: 600; }
.post-back a:hover { color: var(--accent); }

/* ===== Sekcja "From our blog" na stronie glownej ===== */
.home-blog { padding: 64px 0; }
.home-blog-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 26px; flex-wrap: wrap; }
.home-blog-head .section-title { margin-bottom: 4px; }
.home-blog-all { color: var(--accent); font-weight: 600; text-decoration: none; white-space: nowrap; }
.home-blog-all:hover { text-decoration: underline; }
