/* ==========================================================================
   Pallér Blog – napilap / kraft papír dizájn
   Scope: csak .pb- prefixes osztályokra hat. Globális szelektor (body, h1,
   .container) TILOS. A globális header/footer érintetlen.
   ========================================================================== */

/* ── Root wrapper ─────────────────────────────────────────────────────────── */
.pb-page {
  --pb-kraft:       #F2E8D0;
  --pb-ink:         #1A1410;
  --pb-ink-soft:    #3A2E1F;
  --pb-meta:        #5A4A2F;
  --pb-rust:        #C8461B;
  --pb-yellow:      #E8B84C;
  --pb-placeholder: #D4C5A0;

  --pb-serif:   'Playfair Display', Georgia, 'Times New Roman', serif;
  --pb-sans:    'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --pb-mono:    'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

  background: var(--pb-kraft);
  background-image:
    radial-gradient(ellipse 55% 40% at 18% 12%, rgba(170,130,70,0.12) 0%, transparent 65%),
    radial-gradient(ellipse 50% 35% at 82% 22%, rgba(140,105,55,0.09)  0%, transparent 65%),
    radial-gradient(ellipse 60% 40% at 50% 60%, rgba(120,90,50,0.08)   0%, transparent 70%),
    radial-gradient(ellipse 35% 28% at 12% 82%, rgba(180,140,80,0.10)  0%, transparent 65%),
    radial-gradient(ellipse 40% 30% at 92% 78%, rgba(150,115,65,0.09)  0%, transparent 65%);
  color: var(--pb-ink);
  font-family: var(--pb-sans);
  line-height: 1.6;
  padding: 0 0 3.5rem;
}

.pb-page a { color: inherit; }
.pb-page img { max-width: 100%; height: auto; display: block; }

.pb-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* ── Kiadás-fejléc (dátum + kiadás-szám) ─────────────────────────────────── */
.pb-issue {
  max-width: 1180px;
  margin: 0 auto;
  padding: 1.1rem 2rem .7rem;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--pb-ink);
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--pb-ink);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.pb-issue > span { white-space: nowrap; }

/* ── Masthead ────────────────────────────────────────────────────────────── */
.pb-masthead {
  max-width: 1180px;
  margin: 0 auto;
  padding: 2.4rem 2rem 1.6rem;
  text-align: center;
  position: relative;
}
.pb-masthead h1 {
  font-family: var(--pb-serif);
  font-weight: 900;
  font-style: normal;
  font-size: clamp(58px, 14vw, 184px);
  letter-spacing: -0.025em;
  line-height: 0.94;
  color: var(--pb-ink);
  margin: 0 0 .9rem;
}
.pb-tagline {
  font-family: var(--pb-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(14px, 1.4vw, 18px);
  color: var(--pb-ink-soft);
  max-width: 620px;
  margin: 0 auto 1.2rem;
  line-height: 1.55;
}
.pb-masthead-rule {
  border: none;
  border-top: 3px double var(--pb-ink);
  max-width: 1180px;
  margin: 0 auto;
}

/* ── Szerszám-dekor (SVG row) ────────────────────────────────────────────── */
.pb-tools {
  max-width: 1180px;
  margin: 1.2rem auto 0;
  padding: 0 2rem;
  text-align: center;
}
.pb-tools svg {
  width: 240px;
  height: 36px;
  opacity: 0.55;
}

/* ── Rovat-fejléc („Rovatok” vékony vonallal) ────────────────────────────── */
.pb-rovatok-head {
  max-width: 1180px;
  margin: 2rem auto 1.1rem;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.pb-rovatok-head::before,
.pb-rovatok-head::after {
  content: '';
  flex: 1;
  border-top: 1px solid var(--pb-ink);
}
.pb-rovatok-head span {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--pb-ink);
  white-space: nowrap;
}

/* ── Kategória gombok ────────────────────────────────────────────────────── */
.pb-kat-row {
  max-width: 1180px;
  margin: 0 auto 1.6rem;
  padding: 0 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.pb-kat-btn {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  padding: 10px 18px;
  background: transparent;
  border: 1px solid var(--pb-ink);
  color: var(--pb-ink);
  font-family: var(--pb-serif);
  font-weight: 400;
  font-size: 15px;
  line-height: 1;
  text-decoration: none;
  transition: background .15s, color .15s;
  cursor: pointer;
}
.pb-kat-btn:hover,
.pb-kat-btn.is-active {
  background: var(--pb-ink);
  color: var(--pb-kraft);
}
.pb-kat-roman {
  font-family: var(--pb-mono);
  font-weight: 500;
  font-size: 11px;
  color: var(--pb-rust);
  letter-spacing: 0.04em;
}
.pb-kat-btn:hover .pb-kat-roman,
.pb-kat-btn.is-active .pb-kat-roman { color: var(--pb-yellow); }

/* ── Kiemelt cikk ────────────────────────────────────────────────────────── */
.pb-featured {
  max-width: 1180px;
  margin: 2.4rem auto 0;
  padding: 2.2rem 2rem 2.4rem;
  border-top: 1px solid var(--pb-ink);
  border-bottom: 1px solid var(--pb-ink);
  position: relative;
}
.pb-featured-ribbon {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--pb-yellow);
  color: var(--pb-ink);
  padding: 5px 18px;
  font-family: var(--pb-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
}
.pb-featured-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 44px;
  align-items: start;
}
.pb-featured-meta {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-rust);
  margin-bottom: 14px;
}
.pb-featured-title {
  font-family: var(--pb-serif);
  font-weight: 900;
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--pb-ink);
  margin: 0 0 1rem;
}
.pb-featured-title a { color: inherit; text-decoration: none; }
.pb-featured-title a:hover { color: var(--pb-rust); }
.pb-featured-lead {
  font-family: var(--pb-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 19px;
  line-height: 1.6;
  color: var(--pb-ink-soft);
  margin: 0 0 1.2rem;
}
.pb-featured-lead::first-letter {
  font-family: var(--pb-serif);
  font-weight: 900;
  font-style: normal;
  font-size: 3.2em;
  line-height: 0.9;
  color: var(--pb-rust);
  float: left;
  margin: 0.08em 0.10em 0 0;
}
.pb-featured-byline {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-meta);
}
.pb-featured-imgwrap {
  border: 1px solid var(--pb-ink);
  background: var(--pb-placeholder);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.pb-featured-imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pb-placeholder-stripes {
  width: 100%;
  height: 100%;
  background-color: var(--pb-placeholder);
  background-image: repeating-linear-gradient(45deg,
    transparent 0 10px,
    rgba(26,20,16,0.10) 10px 11px);
}

/* ── 3-oszlopos grid ─────────────────────────────────────────────────────── */
.pb-grid {
  max-width: 1180px;
  margin: 0 auto;
  padding: 48px 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
}
.pb-grid-card {
  padding-right: 18px;
  border-right: 1px solid var(--pb-ink);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}
.pb-grid-card:nth-child(3n),
.pb-grid-card:last-child { border-right: none; padding-right: 0; }
.pb-grid-card-imgwrap {
  border: 1px solid var(--pb-ink);
  background: var(--pb-placeholder);
  width: 100%;
  height: 170px;
  overflow: hidden;
  margin-bottom: 16px;
}
.pb-grid-card-imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pb-grid-card-kat {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-rust);
  margin-bottom: 8px;
}
.pb-grid-card-title {
  font-family: var(--pb-serif);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.18;
  color: var(--pb-ink);
  margin: 0 0 10px;
}
.pb-grid-card:hover .pb-grid-card-title { color: var(--pb-rust); }
.pb-grid-card-excerpt {
  font-family: var(--pb-sans);
  font-size: 14px;
  line-height: 1.58;
  color: var(--pb-ink-soft);
  margin: 0 0 14px;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pb-grid-card-byline {
  font-family: var(--pb-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-meta);
  margin-top: auto;
}

/* ── Üres állapot ────────────────────────────────────────────────────────── */
.pb-empty {
  max-width: 720px;
  margin: 3rem auto;
  padding: 3rem 2rem;
  text-align: center;
  border: 1px solid var(--pb-ink);
  font-family: var(--pb-serif);
  font-style: italic;
  font-size: 17px;
  color: var(--pb-ink-soft);
}

/* ── Lapozó ──────────────────────────────────────────────────────────────── */
.pb-pager {
  max-width: 1180px;
  margin: 0 auto;
  padding: 1rem 2rem 2.5rem;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  font-family: var(--pb-mono);
  font-size: 13px;
}
.pb-pager a,
.pb-pager span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 12px;
  border: 1px solid var(--pb-ink);
  background: transparent;
  color: var(--pb-ink);
  text-decoration: none;
  font-weight: 500;
  letter-spacing: 0.06em;
}
.pb-pager a:hover { background: var(--pb-ink); color: var(--pb-kraft); }
.pb-pager .is-active { background: var(--pb-ink); color: var(--pb-kraft); }
.pb-pager .is-disabled { opacity: .25; pointer-events: none; }

/* ==========================================================================
   Cikk oldal
   ========================================================================== */

.pb-article {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 2rem;
}

.pb-breadcrumb {
  padding: 1rem 0 .8rem;
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-ink-soft);
}
.pb-breadcrumb a {
  color: var(--pb-ink-soft);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.pb-breadcrumb a:hover { color: var(--pb-rust); border-bottom-color: var(--pb-rust); }

.pb-hero {
  text-align: center;
  padding: 1.6rem 0 2.2rem;
  position: relative;
}
.pb-hero::after {
  content: '';
  display: block;
  border-top: 3px double var(--pb-ink);
  margin-top: 2rem;
}
.pb-hero-kat {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pb-rust);
  margin-bottom: 1.2rem;
}
.pb-hero h1 {
  font-family: var(--pb-serif);
  font-weight: 900;
  font-size: clamp(36px, 6vw, 72px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--pb-ink);
  margin: 0 auto 1rem;
  max-width: 920px;
  text-transform: none;
}
.pb-hero-lead {
  font-family: var(--pb-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(17px, 1.7vw, 21px);
  line-height: 1.58;
  color: var(--pb-ink-soft);
  max-width: 720px;
  margin: 0 auto 1.4rem;
}
.pb-hero-byline {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pb-meta);
}

.pb-cover {
  max-width: 960px;
  margin: 0 auto 2.2rem;
  border: 1px solid var(--pb-ink);
  background: var(--pb-placeholder);
  overflow: hidden;
}
.pb-cover img { width: 100%; display: block; }
.pb-cover-placeholder { width: 100%; aspect-ratio: 16 / 9; }

/* Tartalom tipográfia */
.pb-content {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px 0;
  font-family: var(--pb-sans);
  font-size: 18px;
  line-height: 1.7;
  color: var(--pb-ink);
}
.pb-content p { margin: 0 0 1.2em; }
.pb-content p:first-of-type::first-letter {
  font-family: var(--pb-serif);
  font-weight: 900;
  font-size: 3.2em;
  line-height: 0.9;
  color: var(--pb-rust);
  float: left;
  margin: 0.08em 0.10em 0 0;
}
.pb-content h2 {
  font-family: var(--pb-serif);
  font-weight: 700;
  font-size: 32px;
  line-height: 1.2;
  color: var(--pb-ink);
  margin: 2.1em 0 .65em;
  text-transform: none;
  position: relative;
  padding-bottom: 10px;
}
.pb-content h2::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 60px;
  height: 1px;
  background: var(--pb-rust);
}
.pb-content h3 {
  font-family: var(--pb-serif);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.25;
  color: var(--pb-ink);
  margin: 1.6em 0 .55em;
  text-transform: none;
}
.pb-content a { color: var(--pb-rust); text-decoration: underline; text-underline-offset: 3px; }
.pb-content a:hover { color: var(--pb-ink); }
.pb-content strong { color: var(--pb-ink); font-weight: 600; }
.pb-content blockquote {
  margin: 1.6em 0;
  padding: 0.4em 0 0.4em 20px;
  border-left: 3px solid var(--pb-rust);
  font-family: var(--pb-serif);
  font-style: italic;
  font-size: 21px;
  line-height: 1.55;
  color: var(--pb-ink-soft);
}
.pb-content ul,
.pb-content ol { margin: 0 0 1.2em; padding-left: 1.5em; }
.pb-content ul { list-style: none; }
.pb-content ul li { position: relative; margin-bottom: .45em; }
.pb-content ul li::before {
  content: '•';
  position: absolute;
  left: -1em;
  top: 0;
  color: var(--pb-rust);
  font-weight: 700;
}
.pb-content ol li { margin-bottom: .45em; }
.pb-content ol li::marker { color: var(--pb-rust); font-weight: 600; }
.pb-content img {
  max-width: 100%;
  height: auto;
  border: 1px solid var(--pb-ink);
  margin: 1.6em 0 .4em;
  display: block;
}
.pb-content figure { margin: 1.6em 0; }
.pb-content figure img { margin-bottom: .5em; }
.pb-content figcaption {
  font-family: var(--pb-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--pb-meta);
  text-align: center;
}
.pb-content hr {
  border: none;
  border-top: 1px solid var(--pb-ink);
  max-width: 120px;
  margin: 2.2em auto;
}
/* Interjú cikkek végén – „Tovább X profiljára" CTA gomb. Az inline stílus
   adja a default állapotot; ez a hover-override (!important nélkül nem tudja
   felülírni a .pb-content a:hover-t és az inline background:transparent-et). */
.pb-content .pb-profil-cta a {
  transition: background .18s ease, color .18s ease !important;
}
.pb-content .pb-profil-cta a:hover {
  background: #1A1410 !important;
  color: #F2E8D0 !important;
}
.pb-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.4em 0;
  font-size: 15px;
}
.pb-content th {
  text-align: left;
  padding: 10px 12px;
  border-bottom: 2px solid var(--pb-ink);
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-ink);
}
.pb-content td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(26,20,16,0.15);
  color: var(--pb-ink-soft);
}
.pb-content code {
  font-family: var(--pb-mono);
  font-size: 0.92em;
  background: rgba(26,20,16,0.08);
  padding: 2px 6px;
  border-radius: 0;
}
.pb-content pre {
  font-family: var(--pb-mono);
  font-size: 14px;
  background: rgba(26,20,16,0.06);
  border: 1px solid rgba(26,20,16,0.2);
  padding: 14px 16px;
  overflow-x: auto;
  margin: 1.4em 0;
}
.pb-content pre code { background: none; padding: 0; }

/* Cikk láb */
.pb-article-foot {
  max-width: 720px;
  margin: 0 auto;
  padding: 1.6rem 0 0;
  border-top: 1px solid var(--pb-ink);
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-meta);
  text-align: center;
}

.pb-back-btn-wrap { text-align: center; padding: 2rem 0 3rem; }
.pb-back-btn {
  display: inline-block;
  padding: 12px 28px;
  border: 1px solid var(--pb-ink);
  color: var(--pb-ink);
  background: transparent;
  font-family: var(--pb-serif);
  font-size: 15px;
  font-weight: 400;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.pb-back-btn:hover { background: var(--pb-ink); color: var(--pb-kraft); }

/* Kapcsolódó cikkek (cikk alján, ha van) */
.pb-related {
  max-width: 1180px;
  margin: 2rem auto 0;
  padding: 2.4rem 2rem 0;
  border-top: 1px solid var(--pb-ink);
}
.pb-related-head {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--pb-ink);
  text-align: center;
  margin: 0 0 1.6rem;
}

/* ── Admin preview banner, megosztás, reklám – megörökölt funkciók ────────── */
.pb-preview-banner {
  background: var(--pb-yellow);
  color: var(--pb-ink);
  padding: 10px 2rem;
  font-family: var(--pb-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid var(--pb-ink);
}
.pb-preview-banner a {
  color: var(--pb-ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
}

.pb-share {
  max-width: 720px;
  margin: 2rem auto 0;
  padding: 1.4rem 0;
  border-top: 1px solid var(--pb-ink);
  border-bottom: 1px solid var(--pb-ink);
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}
.pb-share-label {
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pb-meta);
}
.pb-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  background: transparent;
  border: 1px solid var(--pb-ink);
  color: var(--pb-ink);
  font-family: var(--pb-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s, color .15s;
  line-height: 1;
}
.pb-share-btn:hover { background: var(--pb-ink); color: var(--pb-kraft); }

.pb-ai-note {
  max-width: 720px;
  margin: 1.6rem auto 0;
  padding: 0;
  font-family: var(--pb-mono);
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pb-meta);
  text-align: center;
  opacity: 0.5;
}

.pb-ad-slot { max-width: 720px; margin: 1.2rem auto; }
.pb-ad-slot a { text-decoration: none !important; }

/* ==========================================================================
   Reszponzív breakpointok
   ========================================================================== */

/* Tablet: 3-col → 2-col */
@media (max-width: 1024px) {
  .pb-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .pb-grid-card { padding-right: 16px; }
  .pb-grid-card:nth-child(3n) { border-right: 1px solid var(--pb-ink); padding-right: 16px; }
  .pb-grid-card:nth-child(2n),
  .pb-grid-card:last-child { border-right: none; padding-right: 0; }
}

/* Mobile: minden 1-col, vertikális vonalak → alsó vonalak */
@media (max-width: 768px) {
  .pb-inner,
  .pb-issue,
  .pb-masthead,
  .pb-tools,
  .pb-rovatok-head,
  .pb-kat-row,
  .pb-featured,
  .pb-grid,
  .pb-pager,
  .pb-article,
  .pb-related { padding-left: 1.25rem; padding-right: 1.25rem; }

  .pb-issue { font-size: 10px; letter-spacing: 0.14em; gap: .5rem; }
  .pb-masthead { padding-top: 1.6rem; padding-bottom: 1.1rem; }
  .pb-tagline { font-size: 14px; }

  .pb-rovatok-head { margin-top: 1.5rem; }
  .pb-kat-row { gap: 8px; }
  .pb-kat-btn { padding: 8px 14px; font-size: 14px; }

  .pb-featured { padding-top: 2rem; padding-bottom: 1.8rem; }
  .pb-featured-grid { grid-template-columns: 1fr; gap: 24px; }
  .pb-featured-ribbon { font-size: 9.5px; padding: 4px 14px; }

  .pb-grid {
    grid-template-columns: 1fr;
    gap: 32px;
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .pb-grid-card,
  .pb-grid-card:nth-child(3n),
  .pb-grid-card:nth-child(2n) {
    border-right: none;
    padding-right: 0;
    border-bottom: 1px solid var(--pb-ink);
    padding-bottom: 32px;
  }
  .pb-grid-card:last-child { border-bottom: none; padding-bottom: 0; }
  .pb-grid-card-imgwrap { height: 200px; }

  .pb-hero { padding-top: 1.2rem; padding-bottom: 1.8rem; }
  .pb-content { padding: 32px 0; font-size: 17px; }
  .pb-content h2 { font-size: 26px; }
  .pb-content h3 { font-size: 20px; }
  .pb-content blockquote { font-size: 19px; padding-left: 16px; }

  .pb-preview-banner {
    flex-direction: column;
    gap: .5rem;
    padding: 10px 1.25rem;
    text-align: center;
  }
}

/* Kis mobil finomhangolás */
@media (max-width: 380px) {
  .pb-issue { font-size: 9.5px; }
  .pb-tagline { font-size: 13px; }
  .pb-kat-btn { padding: 7px 12px; font-size: 13px; gap: 6px; }
  .pb-kat-roman { font-size: 10px; }
  .pb-featured-meta,
  .pb-featured-byline,
  .pb-hero-byline,
  .pb-grid-card-kat,
  .pb-grid-card-byline { font-size: 10px; letter-spacing: 0.1em; }
  .pb-featured-title { font-size: 26px; }
  .pb-grid-card-title { font-size: 20px; }
}

/* ── Élő olvasó-számláló widget ───────────────────────────────────────────── */
.pb-olvasok {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 150;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px 7px 10px;
  background: #F2E8D0;
  border: 1px solid rgba(90, 74, 47, 0.32);
  border-radius: 999px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.18), 0 6px 18px rgba(0, 0, 0, 0.22);
  color: #5A4A2F;
  font-family: 'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  line-height: 1;
  opacity: 1;
  transition: opacity .6s ease, transform .2s ease;
  pointer-events: none;
  user-select: none;
}
.pb-olvasok.pb-olvasok-idle {
  opacity: 0.55;
}
.pb-olvasok.pb-olvasok-bump {
  transform: scale(1.04);
}
.pb-olvasok-fig {
  width: 14px;
  height: 18px;
  color: #5A4A2F;
  flex: 0 0 auto;
}
.pb-olvasok-fig .pb-olvasok-leg-l {
  transform-origin: 12px 17px;
  animation: pb-olvasok-step-l 0.9s ease-in-out infinite;
}
.pb-olvasok-fig .pb-olvasok-leg-r {
  transform-origin: 12px 17px;
  animation: pb-olvasok-step-r 0.9s ease-in-out infinite;
}
.pb-olvasok-fig .pb-olvasok-arm-l {
  transform-origin: 12px 10px;
  animation: pb-olvasok-step-r 0.9s ease-in-out infinite;
}
.pb-olvasok-fig .pb-olvasok-arm-r {
  transform-origin: 12px 10px;
  animation: pb-olvasok-step-l 0.9s ease-in-out infinite;
}
@keyframes pb-olvasok-step-l {
  0%, 100% { transform: rotate(-16deg); }
  50%      { transform: rotate( 16deg); }
}
@keyframes pb-olvasok-step-r {
  0%, 100% { transform: rotate( 16deg); }
  50%      { transform: rotate(-16deg); }
}
.pb-olvasok-szam {
  font-weight: 600;
  font-size: 12px;
  color: #1A1410;
}
@media (max-width: 480px) {
  .pb-olvasok {
    right: 10px;
    bottom: 10px;
    padding: 6px 10px 6px 8px;
    font-size: 10px;
  }
  .pb-olvasok-szam { font-size: 11px; }
}
@media (prefers-reduced-motion: reduce) {
  .pb-olvasok-fig * { animation: none !important; }
  .pb-olvasok { transition: opacity .3s ease; }
}
