/* ============================================================
   Zentus blog — index + cikk-sablon alapstílus (a zentus.css tokenjeire).
   P2 baseline; a Pencil-tervhez finomítva a következő körben.
   Nincs side-stripe, nincs gradient-text. Kontraszt ≥4.5:1.
   ============================================================ */
.blog-page {
  /* AA-biztos másodlagos szöveg a Soft Tech BG-n (mint a jogi oldalakon) */
  --blog-muted: #5E6578;
}
.blog-container { width: 100%; max-width: 1120px; margin-inline: auto; padding-inline: var(--gutter); }

/* ---------------- INDEX: hero ---------------- */
.blog-hero { padding: 88px var(--gutter) 32px; }
.blog-hero .blog-container { padding-inline: 0; }
.blog-eyebrow { display: block; color: var(--blue-link); font-size: 12px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; margin-bottom: 14px; }
.blog-h1 { color: var(--navy); font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem); font-weight: 700; letter-spacing: -1px; line-height: 1.1; max-width: 18ch; }
.blog-sub { margin-top: 16px; color: var(--text); font-size: 18px; line-height: 1.6; max-width: 60ch; }

.blog-search { margin-top: 26px; max-width: 460px; }
.blog-search-input {
  width: 100%; font-family: var(--font); font-size: 15px; color: var(--text);
  padding: 13px 16px; border: 1px solid var(--border); border-radius: var(--r-btn);
  background: var(--white);
}
.blog-search-input:focus-visible { outline: none; box-shadow: var(--focus-ring); border-color: var(--blue); }

.blog-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.chip {
  display: inline-flex; align-items: center; gap: 7px; min-height: 36px;
  padding: 7px 14px; border-radius: 999px; border: 1px solid var(--border);
  background: var(--white); color: var(--navy); font-size: 14px; font-weight: 500;
  transition: border-color 0.15s ease, color 0.15s ease;
}
.chip:hover { border-color: var(--blue); color: var(--blue-link); }
.chip:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.chip-count { color: var(--blog-muted); font-size: 12px; font-weight: 600; }
.chip--soon { opacity: 0.6; cursor: default; }
.chip-soon { color: var(--blog-muted); font-size: 11px; letter-spacing: 0.3px; }

/* ---------------- INDEX: featured ---------------- */
.blog-featured-wrap { padding-top: 16px; }
.featured-card {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 0;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--r-card);
  overflow: hidden; transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.featured-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.featured-card:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.featured-cover { background: var(--bg-deep); }
.featured-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.featured-body { padding: 32px; display: flex; flex-direction: column; gap: 12px; }
.featured-title { color: var(--navy); font-size: 26px; font-weight: 700; letter-spacing: -0.5px; line-height: 1.18; }
.featured-desc { color: var(--text); font-size: 15px; line-height: 1.6; }
.card-meta { color: var(--blog-muted); font-size: 13px; margin-top: auto; }

/* ---------------- INDEX: rács ---------------- */
.blog-grid-wrap { padding-block: 36px 80px; }
.blog-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.post-card {
  display: flex; flex-direction: column;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--r-card);
  overflow: hidden; transition: box-shadow 0.2s ease, transform 0.2s ease;
}
/* a szűrő a [hidden] attribútumot állítja — felül kell írnia a display:flex-et */
.post-card[hidden] { display: none !important; }
.blog-featured-wrap[hidden] { display: none !important; }
.post-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.post-card:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.post-cover { aspect-ratio: 16 / 9; background: var(--bg-deep); }
.post-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.post-card-body { padding: 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.post-title { color: var(--navy); font-size: 19px; font-weight: 600; letter-spacing: -0.3px; line-height: 1.25; }
.post-desc { color: var(--text); font-size: 14px; line-height: 1.55; }

/* ---- badge (index + cikk) ---- */
.article-badge {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; border-radius: 999px; font-size: 11px; font-weight: 600;
  letter-spacing: 0.4px; color: var(--blue-link); background: rgba(24,132,240,0.08);
}
.article-badge svg { flex: none; }

/* ---------------- CIKK ---------------- */
.article { padding: 40px var(--gutter) 88px; }
.article-container { max-width: 720px; margin-inline: auto; }

.breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; color: var(--blog-muted); font-size: 13px; margin-bottom: 24px; }
.breadcrumb a { color: var(--blue-link); border-radius: 4px; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb a:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.breadcrumb [aria-current="page"] { color: var(--blog-muted); }

.article-h1 { color: var(--navy); font-size: clamp(1.9rem, 1.4rem + 2vw, 2.6rem); font-weight: 700; letter-spacing: -1px; line-height: 1.12; margin: 14px 0 0; }
.article-lead { color: var(--text); font-size: 19px; line-height: 1.55; margin-top: 16px; }
.article-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; color: var(--blog-muted); font-size: 14px; margin-top: 18px; }
.article-author { color: var(--navy); font-weight: 600; }

.article-cover { margin: 28px 0 8px; border-radius: var(--r-card); overflow: hidden; background: var(--bg-deep); aspect-ratio: 16 / 9; }
.article-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- próza (markdown) ---- */
.article-body { color: var(--text); font-size: 17px; line-height: 1.72; }
.article-body > * { max-width: 68ch; }
.article-body h2 { color: var(--navy); font-size: 26px; font-weight: 600; letter-spacing: -0.4px; line-height: 1.2; margin: 48px 0 14px; scroll-margin-top: 96px; }
.article-body h3 { color: var(--navy); font-size: 20px; font-weight: 600; margin: 32px 0 10px; scroll-margin-top: 96px; }
.article-body p { margin: 0 0 18px; }
.article-body ul, .article-body ol { margin: 0 0 18px; padding-left: 22px; }
.article-body ul { list-style: disc; }
.article-body ol { list-style: decimal; }
.article-body li { margin-bottom: 8px; }
.article-body li::marker { color: var(--blog-muted); }
.article-body strong { color: var(--navy); font-weight: 600; }
.article-body a { color: var(--blue-link); border-radius: 4px; }
.article-body a:hover { text-decoration: underline; }
.article-body a:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.article-body hr { border: 0; height: 1px; background: var(--border); margin: 28px 0; max-width: none; }
/* idézet: háttér-tint, NEM side-stripe */
.article-body blockquote {
  margin: 0 0 18px; padding: 18px 22px; border-radius: 16px;
  background: rgba(24,132,240,0.05); color: var(--navy); font-size: 18px; line-height: 1.6;
}
.article-body blockquote p { margin: 0; }
/* kód: sötét felület, monospace */
.article-body :not(pre) > code {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 0.88em;
  background: rgba(48,60,96,0.08); color: var(--navy); padding: 2px 6px; border-radius: 6px;
}
.article-body pre {
  background: var(--graphite); color: var(--ice); border-radius: 14px;
  padding: 18px 20px; overflow-x: auto; margin: 0 0 18px; max-width: none;
}
.article-body pre code { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 14px; line-height: 1.6; }

/* ---- szerzői doboz (ODxDK): fotó balra, név+szerep egy sorban, bio alatta,
   LinkedIn-gomb jobbra, függőlegesen középre ---- */
.author-box { display: flex; align-items: center; gap: 18px; margin: 48px 0 0; padding: 22px 24px; border: 1px solid var(--border); border-radius: var(--r-card); background: var(--white); }
.author-photo { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; flex: none; border: 1px solid var(--border); }
.author-text { flex: 1 1 auto; min-width: 0; }
.author-name { color: var(--navy); font-weight: 700; font-size: 16px; }
.author-role { color: var(--blog-muted); font-weight: 500; }
.author-bio { color: var(--text); font-size: 14px; line-height: 1.55; margin: 5px 0 0; }
.author-linkbtn {
  flex: none; display: inline-flex; align-items: center; gap: 8px; align-self: center;
  padding: 9px 16px; border: 1px solid var(--border); border-radius: var(--r-btn);
  color: var(--blue-link); font-size: 14px; font-weight: 600; background: var(--white);
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.author-linkbtn:hover { background: var(--blue-btn); color: var(--white); border-color: var(--blue-btn); }
.author-linkbtn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* ---- kapcsolódó (UDgct): teljes kártya-anatómia (borító-overlay + byline + nyíl),
   a rácsoldali kártyákkal azonos, csak kompaktabb tipográfiával ---- */
.related { margin-top: 56px; }
.related .blog-section-head { margin-bottom: 20px; }
.related-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 18px; }
.related-grid .post-card-body { padding: 16px 16px 14px; gap: 8px; }
.related-grid .post-title { font-size: 15.5px; line-height: 1.3; }
.related-grid .post-desc { font-size: 13px; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.related-grid .post-card-foot { padding-top: 4px; }
.related-grid .byline-avatar { width: 26px; height: 26px; }
.related-grid .byline-name { font-size: 12px; }
.related-grid .byline-meta { font-size: 11px; }
.related-grid .post-arrow { width: 30px; height: 30px; }
.related-grid .post-cover-cat { font-size: 9.5px; padding: 3px 8px; }
.related-grid .post-cover-num { font-size: 9.5px; }

/* ---------------- reszponzív ---------------- */
@media (max-width: 860px) {
  .featured-card { grid-template-columns: 1fr; }
  .featured-cover { aspect-ratio: 16 / 9; }
  .blog-grid { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .blog-hero { padding-top: 56px; }
  .article { padding-top: 28px; }
  .article-body { font-size: 16px; }
}
@media (prefers-reduced-motion: reduce) {
  .featured-card, .post-card, .related-card { transition: none; }
  .featured-card:hover, .post-card:hover { transform: none; }
}

/* ============================================================
   P3 — cikk: RÖVIDEN, TOC+megosztás, CTA, hírlevél, kód-Másolás
   ============================================================ */

/* a fejléc-blokk a 720-as olvasási oszlopra, de a média-modulok szélesebbek */
.article-container { max-width: 1140px; }
.breadcrumb, .article-badge, .article-h1, .article-lead, .article-meta,
.article-summary { max-width: 720px; }

/* RÖVIDEN — halvány kék tint + teljes vékony border, 16px radius, NEM side-stripe */
.article-summary {
  margin: 24px 0 8px; padding: 20px 22px;
  border: 1px solid var(--border); background: rgba(24,132,240,0.05); border-radius: 16px;
}
.article-summary-label {
  display: block; color: var(--blue-link); font-size: 12px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase; margin-bottom: 8px;
}
.article-summary p { margin: 0; color: var(--navy); font-size: 16px; line-height: 1.6; max-width: none; }

/* kétoszlopos törzs: bal sticky TOC + megosztás | jobb body */
.article-layout {
  display: grid; grid-template-columns: 200px minmax(0, 1fr); gap: 44px;
  align-items: start; margin: 24px auto 0; max-width: 940px;
}
.article-aside { position: sticky; top: 92px; display: flex; flex-direction: column; gap: 24px; }

/* TOC kártya: keret + „TARTALOM" fejléc ikonnal (desktopon statikus, mobilon nyitható) */
.toc { border: 1px solid var(--border); border-radius: 16px; background: var(--white); overflow: hidden; }
.toc-head {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  font-family: var(--font); background: none; border: 0; border-bottom: 1px solid var(--border);
  padding: 12px 16px; cursor: default;
}
.toc-head-label { display: inline-flex; align-items: center; gap: 8px; color: var(--navy); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
.toc-chevron { display: none; color: var(--blog-muted); transition: transform 0.2s ease; }
.toc-head:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.toc-nav { padding: 12px 16px; }
.toc-nav ol { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px;
  border-left: 1px solid var(--border); }
.toc-nav a {
  display: block; padding: 7px 0 7px 14px; margin-left: -1px; border-left: 2px solid transparent;
  color: var(--blog-muted); font-size: 13.5px; line-height: 1.4;
}
.toc-nav a:hover { color: var(--navy); }
.toc-nav a.is-active { color: var(--blue-link); font-weight: 600; border-left-color: var(--blue); }
.toc-nav a:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 4px; }

.article-share { display: flex; flex-direction: column; gap: 12px; padding: 4px 2px; }
.share-label { color: var(--navy); font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
.article-share-icons { display: flex; gap: 8px; flex-wrap: wrap; }
.share-btn {
  display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px;
  border-radius: 10px; border: 1px solid var(--border); background: var(--white); color: var(--navy);
  cursor: pointer; transition: color 0.15s ease, border-color 0.15s ease;
}
.share-btn:hover { color: var(--blue-link); border-color: var(--blue); }
.share-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.share-btn.is-copied { color: var(--success); border-color: var(--success); }

/* kód-Másolás gomb */
.article-body pre { position: relative; }
.code-copy {
  position: absolute; top: 10px; right: 10px; font-family: var(--font); font-size: 12px;
  color: var(--ice); background: rgba(250,251,253,0.1); border: 1px solid rgba(250,251,253,0.18);
  border-radius: 8px; padding: 5px 10px; cursor: pointer;
}
.code-copy:hover { background: rgba(250,251,253,0.18); }
.code-copy:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(216,240,240,0.4); }

/* cikk-CTA blokk / MidCTA (twipx) — tinted kék sáv, szöveg balra, gomb jobbra
   (csak geoLandingUrl mellett renderel) */
.article-cta {
  max-width: 720px; margin: 40px 0 0; padding: 22px 26px; display: flex; flex-wrap: wrap;
  align-items: center; justify-content: space-between; gap: 24px;
  border: 1px solid rgba(24,132,240,0.16); background: rgba(24,132,240,0.04); border-radius: 16px;
}
.article-cta-text { margin: 0; color: var(--navy); font-size: 17px; font-weight: 600; letter-spacing: -0.2px; line-height: 1.35; max-width: 46ch; }
.article-cta-btn {
  flex: none; display: inline-flex; align-items: center; gap: 8px; padding: 12px 18px;
  border-radius: var(--r-btn); background: var(--blue-btn); color: var(--white);
  font-size: 14px; font-weight: 700; box-shadow: 0 4px 14px rgba(24,132,240,0.2);
  transition: background 0.18s ease;
}
.article-cta-btn:hover { background: var(--blue); }
.article-cta-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.article-cta-btn svg { flex: none; }

/* hírlevél */
/* Split kártya: sötét bal panel (badge) + fehér jobb panel (form) */
.newsletter {
  max-width: 720px; margin: 44px auto 0; display: grid; grid-template-columns: 270px 1fr;
  border: 1px solid var(--border); border-radius: var(--r-card-lg, 20px); overflow: hidden; background: var(--white);
}
/* Index hírlevél-szekció (FQ123) — szélesebb panel (1080) + bőséges levegő a footerig */
.blog-newsletter-wrap { padding-top: 88px; padding-bottom: 96px; }
.blog-newsletter-wrap .newsletter { max-width: 1080px; margin: 0 auto; grid-template-columns: 380px 1fr; box-shadow: 0 20px 50px rgba(24,132,240,0.10); }
.blog-newsletter-wrap .newsletter-aside { padding: 48px; }
.blog-newsletter-wrap .newsletter-aside-text { font-size: 26px; }
.blog-newsletter-wrap .newsletter-main { padding: 48px; }
.newsletter-aside {
  background: linear-gradient(135deg, #303C60 0%, #1A1F2E 100%); color: var(--ice); padding: 32px 28px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 18px; justify-content: center;
}
.newsletter-aside-top { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
.newsletter-icon {
  width: 48px; height: 48px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center;
  background: rgba(24,132,240,0.2); color: var(--blue-ice);
}
.newsletter-badge {
  display: inline-flex; align-items: center; padding: 5px 11px; border-radius: 999px;
  background: rgba(24,132,240,0.2); color: var(--blue-ice);
  font-size: 11px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase;
}
.newsletter-aside-text { margin: 0; color: var(--ice); font-size: 20px; font-weight: 700; letter-spacing: -0.4px; line-height: 1.2; }
.newsletter-main { padding: 36px 36px 30px; }
.newsletter-form { display: flex; flex-direction: column; gap: 14px; }
.newsletter-title { color: var(--navy); font-size: 22px; font-weight: 700; letter-spacing: -0.4px; line-height: 1.15; }
.newsletter-text { color: var(--blog-muted); font-size: 14px; line-height: 1.5; }
.newsletter-label { display: block; color: var(--navy); font-size: 13px; font-weight: 600; margin-bottom: -4px; }
.newsletter-row { display: flex; gap: 10px; flex-wrap: wrap; }
.newsletter-input {
  flex: 1 1 220px; min-height: 44px; font-family: var(--font); font-size: 15px; color: var(--text);
  padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-btn); background: var(--white);
}
.newsletter-input:focus-visible { outline: none; box-shadow: var(--focus-ring); border-color: var(--blue); }
.newsletter-submit { min-height: 44px; }
.newsletter-consent { display: flex; align-items: flex-start; gap: 9px; color: var(--text); font-size: 13.5px; line-height: 1.5; }
.newsletter-consent input { margin-top: 3px; width: 17px; height: 17px; flex: none; accent-color: var(--blue); }
.newsletter-consent a { color: var(--blue-link); }
.newsletter-consent a:hover { text-decoration: underline; }
.newsletter-consent a:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 4px; }
.newsletter-msg { margin: 0; font-size: 13.5px; min-height: 1.2em; }
.newsletter-msg.is-error { color: var(--error); }
.newsletter-msg.is-success { color: var(--success); }
.newsletter-msg.is-sending { color: var(--blog-muted); }
.newsletter-form.is-success .newsletter-row,
.newsletter-form.is-success .newsletter-consent { display: none; }

/* a body/cikk-vég elemek a 720 oszlopra */
/* a cikk-vég modulok szélesebbek és középre igazítva (a Pencil szerint) */
.article-cta, .author-box, .related, .article-container .newsletter { max-width: 1100px; margin-inline: auto; }
/* a cikkbeli hírlevél az index-szel azonos széles elrendezést kap */
.article-container .newsletter { grid-template-columns: 380px 1fr; box-shadow: 0 20px 50px rgba(24,132,240,0.10); }
.article-container .newsletter .newsletter-aside { padding: 48px; }
.article-container .newsletter .newsletter-aside-text { font-size: 26px; }
.article-container .newsletter .newsletter-main { padding: 48px; }

/* TIPP callout (ha a tartalom .tipp/.callout osztályt használ) */
.article-body .tipp, .article-body .callout {
  border: 1px solid var(--border); background: rgba(24,132,240,0.05); border-radius: 16px;
  padding: 16px 18px; margin: 0 0 18px; max-width: 68ch;
}

@media (max-width: 900px) {
  .article-container { max-width: 720px; }
  .article-layout { grid-template-columns: 1fr; gap: 0; }
  .article-aside { position: static; gap: 14px; margin-bottom: 8px; }
  .toc-head { cursor: pointer; }
  .toc-chevron { display: block; }
  .toc-head[aria-expanded="true"] .toc-chevron { transform: rotate(180deg); }
  .toc-head[aria-expanded="false"] { border-bottom: 0; }
  .toc-head[aria-expanded="false"] + .toc-nav { display: none; }
  .toc-nav { padding: 4px 14px 12px; }
  .toc-nav ol { border-left: 0; }
  .toc-nav a { border-left: 0; padding-left: 0; }
  .article-share { order: 2; }
}

/* ---- Pagefind keresési találatok (index) ---- */
.blog-search { position: relative; }
.blog-search-results {
  position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: 30;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--r-card);
  box-shadow: var(--sh-lg); padding: 8px; max-height: 64vh; overflow-y: auto;
}
.blog-search-result { display: block; padding: 12px 14px; border-radius: 12px; }
.blog-search-result:hover { background: var(--bg); }
.blog-search-result:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.blog-search-result-title { display: block; color: var(--navy); font-weight: 600; font-size: 15px; line-height: 1.3; }
.blog-search-result-excerpt { display: block; color: var(--blog-muted); font-size: 13px; line-height: 1.5; margin-top: 3px; }
.blog-search-result-excerpt mark { background: rgba(24,132,240,0.18); color: var(--navy); padding: 0 2px; border-radius: 3px; }
.blog-search-empty { margin: 0; padding: 12px 14px; color: var(--blog-muted); font-size: 14px; }

/* ============================================================
   Cikk-sablon parity: középre rendezett fejléc + avatar, RÖVIDEN a borító
   fölött, borító-overlay (címke + felirat), kapcsolódó kártyák borítóval.
   ============================================================ */
.article-head { max-width: 680px; margin: 0 auto; text-align: center; }
.article-head .article-badge { display: inline-flex; }
.article-head .article-h1 { margin-top: 16px; }
.article-head .article-lead { margin-top: 16px; margin-inline: auto; }
.article-byline { display: inline-flex; align-items: center; gap: 12px; margin-top: 24px; text-align: left; }
.article-byline-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex: none; border: 1px solid var(--border); }
.article-byline-text { display: flex; flex-direction: column; }
.article-byline-name { color: var(--navy); font-weight: 600; font-size: 14px; line-height: 1.3; }
.article-byline-meta { color: var(--blog-muted); font-size: 13px; }

/* RÖVIDEN — a borító FÖLÖTT, erősebb kék tint + ikonos caps-felirat */
.article-summary { max-width: 720px; margin: 30px auto 20px; background: rgba(24,132,240,0.07); border-color: rgba(24,132,240,0.2); }
.article-summary-label { display: inline-flex; align-items: center; gap: 7px; }
.article-summary-label svg { color: var(--blue); flex: none; }

/* Borító (qxrw2) — lebegő kód-chip (bal felül) + alsó felirat-overlay sötét scrimmel */
.article-cover { position: relative; max-width: 1100px; margin: 0 auto 40px; overflow: hidden; border-radius: var(--r-card-lg, 20px); }
.article-cover img { display: block; width: 100%; height: auto; border-radius: inherit; }
.article-cover-scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(to top, rgba(13,16,24,0.82) 0%, rgba(13,16,24,0.12) 42%, rgba(13,16,24,0) 70%);
}
/* lebegő kód-chip (PXttP) */
.article-cover-code {
  position: absolute; top: 18px; left: 18px; z-index: 2; display: flex; flex-direction: column; gap: 4px;
  padding: 13px 17px; border-radius: 10px; background: rgba(26,31,46,0.66); border: 1px solid rgba(255,255,255,0.08);
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 12px; line-height: 1.35;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); pointer-events: none;
}
.article-cover-code .cc-line { white-space: nowrap; }
.cc-ok { color: #A8E0B4; }
.cc-warn { color: #FFD08A; }
.cc-bad { color: #FF9F9F; }
.cc-ice { color: #D8F0F0; }
.cc-blue { color: #7DB8FF; }
/* alsó felirat (FgZTe): kis caps-címke + nagyobb fehér heading */
.article-cover-foot {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; margin: 0; padding: 30px 24px 18px;
  display: flex; flex-direction: column; gap: 7px;
}
.article-cover-tag { color: var(--blue-ice); font-size: 11px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; }
.article-cover-cap { margin: 0; color: var(--white); font-size: 17px; font-weight: 600; letter-spacing: -0.2px; line-height: 1.35; max-width: 46ch; }

/* Kapcsolódó kártyák borítóval */
.related-card { padding: 0; overflow: hidden; gap: 0; }
.related-cover { aspect-ratio: 16 / 9; background: var(--bg-deep); }
.related-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.related-card-body { padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }

@media (max-width: 640px) {
  .article-byline { margin-top: 18px; }
  .article-cover-cap { font-size: 14.5px; }
  .article-cover-foot { padding: 24px 16px 14px; }
  .article-cover-code { top: 12px; left: 12px; padding: 10px 13px; font-size: 10.5px; gap: 3px; }
}

/* ============================================================
   Markdown-komponensek: idézet (nagy glif), TIPP callout, kódblokk fejléccel
   ============================================================ */
/* Idézet (sx0OA) — nagy nyitó idézőjel-glif, tinted kék kártya, navy félkövér szöveg */
.article-body blockquote {
  position: relative; margin: 0 0 22px; padding: 26px 32px 26px 64px; max-width: none;
  background: rgba(24,132,240,0.04); border: 0; border-radius: 18px;
}
.article-body blockquote::before {
  content: "\201E"; position: absolute; left: 24px; top: 14px;
  font-family: Georgia, "Times New Roman", serif; font-size: 72px; line-height: 1;
  color: var(--blue); opacity: 0.4;
}
.article-body blockquote p { color: var(--navy); font-size: 19px; font-weight: 600; line-height: 1.45; letter-spacing: -0.3px; margin: 0 0 8px; }
.article-body blockquote p:last-child { margin: 0; }
/* TIPP callout (Mh4AQ) — halvány kék kártya, kék lekerekített ikon-doboz + „TIPP" címke */
.article-body .callout-tipp {
  display: flex; align-items: flex-start; gap: 14px;
  border: 1px solid rgba(24,132,240,0.2); background: rgba(24,132,240,0.04);
  border-radius: 14px; padding: 20px; margin: 0 0 18px; max-width: 68ch;
}
.callout-tipp-ic { position: relative; flex: none; width: 36px; height: 36px; border-radius: 10px; background: var(--blue); }
.callout-tipp-ic::before {
  content: ""; position: absolute; inset: 0; margin: auto; width: 18px; height: 18px; background: #fff;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18h6M10 22h4M15.09 14c.18-.98.65-1.74 1.41-2.5A4.65 4.65 0 0 0 18 8 6 6 0 0 0 6 8c0 1 .23 2.23 1.5 3.5A4.61 4.61 0 0 1 8.91 14'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18h6M10 22h4M15.09 14c.18-.98.65-1.74 1.41-2.5A4.65 4.65 0 0 0 18 8 6 6 0 0 0 6 8c0 1 .23 2.23 1.5 3.5A4.61 4.61 0 0 1 8.91 14'/%3E%3C/svg%3E") center/contain no-repeat;
}
.callout-tipp-tx { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.callout-tipp-label { color: var(--blue-link); font-size: 10px; font-weight: 700; letter-spacing: 1.2px; }
.article-body .callout-tipp p { margin: 0; color: var(--navy); font-size: 14px; line-height: 1.6; }
.article-body .callout-tipp p + p { margin-top: 8px; }
.article-body .callout-tipp strong { color: var(--navy); }
.article-body .callout-tipp code { background: rgba(24,132,240,0.1); color: var(--blue-link); padding: 1px 5px; border-radius: 5px; font-size: 0.92em; }

/* Összehasonlító kártyák (P2A6t) — két oszlop, fejléc-pötty + check-pontok */
.article-body .compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 0 0 22px; }
.article-body .compare-card { display: flex; flex-direction: column; gap: 14px; padding: 22px; background: var(--white); border: 1px solid var(--border); border-radius: 18px; }
.article-body .compare-head { display: flex; align-items: center; gap: 10px; }
.compare-dot { width: 12px; height: 12px; border-radius: 50%; flex: none; }
.compare-card--blue .compare-dot { background: var(--blue); }
.compare-card--navy .compare-dot { background: var(--navy); }
.compare-name { color: var(--navy); font-size: 17px; font-weight: 700; letter-spacing: -0.3px; }
.article-body .compare-sub { margin: 0; color: var(--blog-muted); font-size: 13px; line-height: 1.5; }
.article-body .compare-points { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.article-body .compare-points li { position: relative; margin: 0; padding-left: 24px; color: var(--text); font-size: 14px; line-height: 1.5; }
.article-body .compare-points li::before {
  content: ""; position: absolute; left: 0; top: 3px; width: 15px; height: 15px;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/contain no-repeat;
}
.compare-card--blue .compare-points li::before { background: var(--blue); }
.compare-card--navy .compare-points li::before { background: var(--navy); }
@media (max-width: 640px) {
  .article-body .compare-grid { grid-template-columns: 1fr; }
}

/* Képes ábra felirattal (g4a5Ao) — lekerekített kép + középre zárt dőlt felirat */
.article-body .article-figure { margin: 0 0 22px; display: flex; flex-direction: column; gap: 10px; max-width: none; }
.article-body .article-figure img { width: 100%; height: auto; display: block; border: 1px solid var(--border); border-radius: 14px; background: var(--bg-deep); }
.article-body .article-figure figcaption { margin: 0; color: var(--blog-muted); font-size: 13px; font-style: italic; line-height: 1.5; text-align: center; }
.article-body .article-figure figcaption code { font-style: normal; background: rgba(24,132,240,0.08); color: var(--blue-link); padding: 1px 5px; border-radius: 5px; font-size: 0.92em; }
/* Kódblokk — sötét felület, fejléc-sor (nyelv) + Másol gomb */
.article-body .code-block { margin: 0 0 18px; border-radius: 14px; overflow: hidden; background: var(--graphite); max-width: none; }
.code-block-head { display: flex; align-items: center; gap: 12px; padding: 9px 10px 9px 14px; background: rgba(250,251,253,0.04); border-bottom: 1px solid rgba(250,251,253,0.06); }
.code-dots { display: inline-flex; align-items: center; gap: 6px; flex: none; }
.code-dot { width: 11px; height: 11px; border-radius: 50%; background: #ff5f56; }
.code-dot:nth-child(2) { background: #ffbd2e; }
.code-dot:nth-child(3) { background: #27c93f; }
.code-lang { color: var(--ice); font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 11.5px; letter-spacing: 0.6px; text-transform: uppercase; opacity: 0.66; }
.code-block-head .code-copy { margin-left: auto; }
.article-body .code-block pre { margin: 0; border-radius: 0; background: transparent; padding: 16px 18px; }
/* a Másol gomb a fejlécben (nem lebeg) */
.code-block-head .code-copy { position: static; top: auto; right: auto; }

/* Hírlevél split kártya — mobilon egymás alá */
/* A hírlevél-panel már tableten/keskeny ablakon (≤860) stackeljen 1 oszlopra
   — a 380px-es sötét aside + űrlap 2 oszlopban e fölött fér csak el rendesen.
   Egyező specificitás (0,2,0) kell, mert a .blog-newsletter-wrap .newsletter
   felülírja a sima .newsletter-t. */
@media (max-width: 860px) {
  /* a blogposzt newslettere a .article-container .newsletter (0,2,0) szabályt
     kapja, a listáé a .blog-newsletter-wrap .newsletter-t — mindkettőt stackelni
     kell, egyező specificitással. */
  .newsletter,
  .blog-newsletter-wrap .newsletter,
  .article-container .newsletter { grid-template-columns: 1fr; }
  /* stackelt nézet: az aside BAL-igazított, az ikon + eyebrow EGY SORban felül,
     a cím alatta 1 sorban. */
  .newsletter-aside,
  .blog-newsletter-wrap .newsletter-aside,
  .article-container .newsletter .newsletter-aside { flex-direction: column; align-items: flex-start; justify-content: flex-start; text-align: left; gap: 14px; padding: 28px; }
  .newsletter-aside-top { flex-direction: row; align-items: center; gap: 12px; }
  .blog-newsletter-wrap .newsletter-main,
  .article-container .newsletter .newsletter-main { padding: 28px; }
  .blog-newsletter-wrap .newsletter-aside-text,
  .article-container .newsletter .newsletter-aside-text { font-size: 22px; }
}
@media (max-width: 620px) {
  .blog-newsletter-wrap .newsletter-aside,
  .blog-newsletter-wrap .newsletter-main,
  .article-container .newsletter .newsletter-aside,
  .article-container .newsletter .newsletter-main { padding: 22px; }
  .blog-newsletter-wrap .newsletter-aside-text,
  .article-container .newsletter .newsletter-aside-text { font-size: 20px; }
}

/* ============================================================
   INDEX REBUILD (Pencil Blog_Index): hero-sáv, szűrősáv, szekció-fejlécek,
   kiemelt szerzői sorral, kártya-anatómia overlay+monogram+nyíllal, sort, load-more.
   ============================================================ */
/* overflow-x: clip a vízjelnek (vízszintes túllógás levágva), de overflow-y
   marad visible, hogy a kereső-dropdown a hero alá / a legfölső rétegbe kilóghasson. */
.blog-hero { position: relative; overflow-x: clip; padding: 100px var(--gutter) 80px; background: linear-gradient(180deg, #F2F3F7 0%, #E9EEF8 100%); z-index: 2; }
.blog-hero-wm { position: absolute; height: auto; opacity: 0.06; pointer-events: none; }
.blog-hero-wm--right { top: -60px; right: max(-40px, calc(50% - 560px)); width: 440px; }
.blog-hero-inner { position: relative; max-width: 900px; margin-inline: auto; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 24px; }
.blog-hero .blog-eyebrow { margin-bottom: 0; text-transform: uppercase; letter-spacing: 1.4px; font-weight: 700; }
.blog-hero .blog-h1 { max-width: 880px; margin-inline: auto; font-size: clamp(2.1rem, 1.5rem + 2.6vw, 3.375rem); letter-spacing: -1.4px; line-height: 1.05; }
.blog-hero .blog-sub { max-width: 640px; margin-inline: auto; font-size: 18px; line-height: 1.55; }
.blog-search { position: relative; width: 480px; max-width: 100%; margin: 2px auto 0; }
.blog-search-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--blog-muted); display: inline-flex; pointer-events: none; }
.blog-search-input { padding-left: 46px; box-shadow: var(--sh-sm); }

/* szűrősáv: fehér sáv a hero alatt */
.blog-filterbar { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 16px var(--gutter); }
.blog-filterbar .blog-chips { max-width: 1120px; margin-inline: auto; margin-top: 0; justify-content: center; }
.chip { font-family: var(--font); cursor: pointer; }
.chip--all { color: var(--white); background: var(--navy); border-color: var(--navy); }
.chip.is-active { color: var(--white); background: var(--navy); border-color: var(--navy); }
.chip.is-active .chip-count { color: rgba(216,240,240,0.7); }
.chip.is-active:hover { color: var(--white); }

/* szekció-fejlécek */
.blog-section { padding-top: 48px; }
.blog-section-head { margin-bottom: 22px; }
.blog-section-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.blog-section-eyebrow { display: inline-flex; align-items: center; gap: 7px; color: var(--blue-link); font-size: 12px; font-weight: 600; letter-spacing: 1.4px; text-transform: uppercase; }
.blog-section-eyebrow--star { color: var(--warning); }
.blog-section-eyebrow--dot::before, .blog-eyebrow--dot::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex: none; }
.blog-eyebrow--dot { display: inline-flex; align-items: center; gap: 8px; }
.blog-section-title { color: var(--navy); font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2rem); font-weight: 700; letter-spacing: -0.6px; margin-top: 8px; }
.blog-sort { display: inline-flex; align-items: center; gap: 8px; color: var(--blog-muted); font-size: 14px; }
.blog-sort-label { white-space: nowrap; }
/* egyedi rendezés-legördülő — lekerekített gomb + lekerekített panel, oldalstílusban */
.sortdd { position: relative; }
.sortdd-btn {
  font-family: var(--font); display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-size: 14px; font-weight: 500; color: var(--navy); padding: 9px 12px 9px 14px;
  border: 1px solid var(--border); border-radius: var(--r-btn); background: var(--white);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.sortdd-btn:hover { border-color: var(--blue-ice); }
.sortdd-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.sortdd-chevron { color: var(--blog-muted); transition: transform 0.18s ease; }
.sortdd-btn[aria-expanded="true"] .sortdd-chevron { transform: rotate(180deg); }
.sortdd-panel {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 30; min-width: 100%; margin: 0; padding: 6px; list-style: none;
  background: var(--white); border: 1px solid var(--border); border-radius: 14px; box-shadow: var(--sh-lg);
}
.sortdd-panel[hidden] { display: none; }
.sortdd-opt {
  display: block; padding: 9px 12px; border-radius: 9px; cursor: pointer; white-space: nowrap;
  font-size: 14px; font-weight: 500; color: var(--navy);
}
.sortdd-opt:hover { background: var(--bg); }
.sortdd-opt.is-selected { background: var(--blue-btn); color: var(--white); }
.sortdd-opt:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* szerzői sor (kiemelt + kártya) */
.card-byline { display: flex; align-items: center; gap: 10px; }
.byline-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; flex: none; border: 1px solid var(--border); }
.byline-monogram { width: 32px; height: 32px; border-radius: 50%; flex: none; display: inline-flex; align-items: center; justify-content: center; background: rgba(24,132,240,0.1); color: var(--blue-link); font-size: 11px; font-weight: 700; letter-spacing: 0.3px; }
.byline-text { display: flex; flex-direction: column; line-height: 1.25; }
.byline-name { color: var(--navy); font-weight: 600; font-size: 13.5px; }
.byline-meta { color: var(--blog-muted); font-size: 12.5px; }

/* kiemelt kártya: byline + „Elolvasom →" */
.featured-body { gap: 14px; }
.featured-readmore { display: inline-flex; align-items: center; gap: 7px; color: var(--blue-link); font-size: 14px; font-weight: 600; margin-top: 2px; }
.featured-card:hover .featured-readmore { gap: 11px; }
.cover-label { position: absolute; top: 14px; left: 14px; z-index: 2; padding: 5px 11px; border-radius: 999px; background: rgba(26,31,46,0.72); color: var(--ice); font-size: 11px; font-weight: 600; letter-spacing: 0.5px; }
.cover-caption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 26px 18px 14px; color: var(--white); font-size: 13px; line-height: 1.45; background: linear-gradient(to top, rgba(26,31,46,0.82), rgba(26,31,46,0)); }
.featured-cover { position: relative; }

/* kártya-anatómia: cover overlay-sáv + foot (byline + kör-nyíl) */
.post-cover { position: relative; }
.post-cover-bar { position: absolute; top: 0; left: 0; right: 0; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 12px; }
.post-cover-cat { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; background: rgba(26,31,46,0.66); color: var(--ice); font-size: 10.5px; font-weight: 600; letter-spacing: 0.4px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.post-cover-cat svg { flex: none; }
.post-cover-num { color: rgba(255,255,255,0.92); font-size: 10.5px; font-weight: 600; letter-spacing: 0.4px; text-shadow: 0 1px 3px rgba(26,31,46,0.6); }
.post-card-body { gap: 12px; }
.post-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 6px; }
.post-arrow { width: 36px; height: 36px; border-radius: 50%; flex: none; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--border); color: var(--navy); transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease; }
.post-card:hover .post-arrow { background: var(--blue-btn); color: var(--white); border-color: var(--blue-btn); }

/* load more */
.blog-loadmore { display: flex; justify-content: center; margin-top: 36px; }
.blog-loadmore[hidden] { display: none; }

@media (max-width: 860px) {
  .blog-hero-wm--right { width: 220px; top: -20px; }
  .blog-hero { padding-top: 72px; padding-bottom: 56px; }
}
@media (max-width: 640px) {
  .blog-filterbar .blog-chips { justify-content: flex-start; flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; -ms-overflow-style: none; }
  .blog-filterbar .blog-chips::-webkit-scrollbar { display: none; }
  .blog-filterbar .blog-chips .chip { flex: none; }
  .blog-section-head--row { align-items: flex-start; }
}
