@scope (.marketing-site) {
/* ===========================================================
   oweme. — blog.css   (buduje na assets/styles.css)
   =========================================================== */

/* placeholder obrazu — delikatne paski + monospace label */
.ph {
  position: relative; overflow: hidden; background: var(--cloud-2);
  background-image: repeating-linear-gradient(135deg, rgba(19,145,236,.07) 0 12px, transparent 12px 24px);
  display: grid; place-items: center;
}
.ph .ph-mark { color: var(--accent); opacity: .68; }
.ph.dark { background: #0d2236; background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 12px, transparent 12px 24px); }
.ph.dark .ph-mark { color: #bfe2fb; }

/* ── blog hero ── */
.blog-hero { position: relative; overflow: clip; }
.blog-hero .hero-sky { position: absolute; inset: 0; z-index: 0; background:
  radial-gradient(900px 420px at 80% -10%, var(--accent-tint), transparent 60%),
  linear-gradient(180deg, #fbfdff, #fff); pointer-events: none; }
.blog-hero .inner { position: relative; z-index: 2; padding-block: clamp(48px, 7vw, 88px) clamp(28px, 4vw, 44px); }
.blog-hero h1 { font-size: clamp(2.3rem, 5vw, 3.8rem); max-width: 16ch; }
.blog-hero h1 .accent { color: var(--accent); }
.blog-hero .sub { margin-top: 18px; font-size: clamp(1.05rem, 1.5vw, 1.25rem); color: var(--ink-2); max-width: 56ch; }

/* search */
.blog-search { display: flex; align-items: center; gap: 10px; margin-top: 28px; max-width: 520px;
  background: #fff; border: 1.5px solid var(--line-2); border-radius: 100px; padding: 6px 6px 6px 18px; box-shadow: var(--shadow-sm); }
.blog-search svg { color: var(--ink-3); flex: none; }
.blog-search input { flex: 1; border: 0; background: none; font-family: inherit; font-size: 15.5px; font-weight: 600; color: var(--ink); padding: 9px 0; }
.blog-search input:focus { outline: none; }
.blog-search input::placeholder { color: var(--ink-3); font-weight: 500; }

/* ── category filter ── */
.cat-bar { display: flex; gap: 10px; flex-wrap: wrap; padding-block: 6px; }
.cat {
  font-family: inherit; font-size: 14px; font-weight: 700; color: var(--ink-2);
  background: #fff; border: 1.5px solid var(--line); border-radius: 100px; padding: 10px 18px; cursor: pointer; transition: all .16s;
}
.cat:hover { border-color: var(--accent-soft); color: var(--accent-deep); }
.cat.on { background: var(--accent); border-color: var(--accent); color: #fff; box-shadow: 0 8px 18px -8px color-mix(in oklab, var(--accent) 65%, transparent); }

/* ── featured ── */
.featured-post {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(24px, 4vw, 48px); align-items: center;
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden;
}
.featured-post .fp-media { position: relative; min-height: 340px; height: 100%; }
.featured-post .fp-media .ph { position: absolute; inset: 0; }
.fp-flag { position: absolute; top: 18px; left: 18px; z-index: 3; background: var(--accent); color: #fff; font-size: 12px; font-weight: 800; letter-spacing: .04em; padding: 7px 14px; border-radius: 100px; }
.featured-post .fp-body { padding: clamp(26px, 3vw, 44px) clamp(26px, 3vw, 48px) clamp(26px, 3vw, 44px) 0; }
.post-meta { display: flex; align-items: center; gap: 12px; font-size: 13px; font-weight: 700; color: var(--ink-3); }
.post-meta .pill-cat { color: var(--accent-deep); background: var(--accent-tint); padding: 5px 12px; border-radius: 100px; }
.post-meta .dot-sep { width: 4px; height: 4px; border-radius: 50%; background: var(--line-2); }
.featured-post h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); margin: 16px 0 12px; }
.featured-post h2 a:hover { color: var(--accent-deep); }
.featured-post .excerpt {
  color: var(--ink-2); font-size: 16px; max-width: 52ch;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 4; overflow: hidden;
}
.author-row { display: flex; align-items: center; gap: 12px; margin-top: 24px; }
.author-row .av { width: 42px; height: 42px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 14px; flex: none; }
.author-row .an { font-size: 14px; font-weight: 700; }
.author-row .ar { font-size: 12.5px; color: var(--ink-3); font-weight: 600; }

/* ── post grid ── */
.post-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; align-items: stretch; }
.post-card {
  display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  min-width: 0; height: 100%; overflow: hidden; box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--accent-soft); }
.post-card .pc-media { position: relative; aspect-ratio: 16 / 9; overflow: hidden; background: var(--cloud-2); }
.post-card .pc-media img { transition: transform .35s ease; }
.post-card:hover .pc-media img { transform: scale(1.025); }
.post-card .pc-media .ph { position: absolute; inset: 0; }
.post-card .pc-cat { position: absolute; top: 14px; left: 14px; z-index: 3; background: rgba(255,255,255,.92); color: var(--accent-deep); border: 1px solid var(--accent-soft); font-size: 11.5px; font-weight: 800; padding: 5px 11px; border-radius: 100px; }
.post-card .pc-body { padding: 20px 20px 18px; display: flex; flex-direction: column; flex: 1; min-height: 208px; }
.post-card h3 {
  font-size: 1.16rem; line-height: 1.28; letter-spacing: -.02em;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden;
}
.post-card h3 a:hover { color: var(--accent-deep); }
.post-card .pc-ex {
  color: var(--ink-2); font-size: 14px; line-height: 1.62; margin-top: 10px; flex: 1;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden;
}
.post-card .pc-foot {
  display: flex; align-items: center; gap: 9px; margin-top: 18px; padding-top: 14px;
  border-top: 1px solid var(--line); font-size: 12px; font-weight: 650; color: var(--ink-3); white-space: nowrap;
}
.post-card .pc-foot .rt { display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }

.no-results { display: none; text-align: center; padding: 60px 20px; color: var(--ink-3); font-weight: 600; }
.no-results.show { display: block; }

/* ── load more ── */
.blog-more { display: flex; justify-content: center; margin-top: 44px; }

/* ── newsletter ── */
.newsletter { position: relative; overflow: hidden; }
.newsletter .glow { position: absolute; inset: 0; background: radial-gradient(700px 320px at 50% 0%, rgba(19,145,236,.4), transparent 65%); }
.newsletter .container { position: relative; z-index: 2; text-align: center; }
.newsletter h2 { color: #fff; font-size: clamp(1.8rem, 4vw, 2.8rem); max-width: 18ch; margin-inline: auto; }
.newsletter h2 .accent { color: #6dc1f7; }
.newsletter p { color: rgba(255,255,255,.72); font-size: clamp(1rem, 1.5vw, 1.18rem); margin: 16px auto 0; max-width: 48ch; }
.nl-form { display: flex; gap: 10px; max-width: 480px; margin: 28px auto 0; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); border-radius: 100px; padding: 7px 7px 7px 8px; }
.nl-form input { flex: 1; border: 0; background: none; font-family: inherit; font-size: 15.5px; font-weight: 600; color: #fff; padding: 11px 16px; }
.nl-form input:focus { outline: none; }
.nl-form input::placeholder { color: rgba(255,255,255,.5); }
.newsletter .nl-note { font-size: 13px; color: rgba(255,255,255,.5); margin-top: 16px; }
.nl-ok { display: none; color: #6dc1f7; font-weight: 700; margin-top: 20px; }
.nl-ok.show { display: block; }

/* ── responsive ── */
@media (max-width: 940px) {
  .post-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-post { grid-template-columns: 1fr; }
  .featured-post .fp-media { min-height: 240px; aspect-ratio: 16/9; }
  .featured-post .fp-body { padding: 28px clamp(22px,3vw,36px) 32px; }
}
@media (max-width: 620px) {
  .post-grid { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; }
  .nl-form { flex-direction: column; border-radius: 18px; background: none; border: 0; padding: 0; }
  .nl-form input { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); border-radius: 100px; }
}

/* ── telefony (≤480px) ── */
@media (max-width: 480px) {
  .blog-hero .inner { padding-block: clamp(32px,9vw,52px) 22px; }
  .blog-hero h1 { font-size: clamp(1.9rem, 8.5vw, 2.5rem); }
  .blog-search { margin-top: 22px; padding: 5px 5px 5px 16px; }
  .blog-search input { font-size: 15px; }
  .cat-bar { gap: 8px; }
  .cat { padding: 9px 15px; font-size: 13.5px; }
  .featured-post .fp-media { min-height: 200px; }
  .featured-post .fp-body { padding: 24px 22px 28px; }
  .featured-post h2 { font-size: 1.5rem; }
  .post-card .pc-body { min-height: 0; padding: 18px; }
  /* artykuł */
  .article-hero .inner { padding-block: 24px 16px; }
  .article-cover .ph { aspect-ratio: 16/10; }
  .article-cover-image { aspect-ratio: 16/10; }
  .prose p { font-size: 16.5px; }
  .prose h2 { margin-top: 36px; }
  .prose blockquote { padding: 18px 20px; font-size: 16.5px; }
  .editor-cta { align-items: stretch; flex-direction: column; padding: 20px; }
  .article-links > div { grid-template-columns: 1fr; }
  .author-box { grid-template-columns: 1fr; gap: 12px; padding: 22px; }
  .author-box .av { width: 48px; height: 48px; }
  .article-cta { padding: 28px 22px; }
  /* listy poziome (tweak) wracają do pionu na telefonie */
  :scope[data-grid="list"] .post-card { flex-direction: column; }
  :scope[data-grid="list"] .post-card .pc-media { width: 100%; max-width: none; aspect-ratio: 16/10; }
}

/* ===========================================================
   ARTICLE (blog-artykul.html)
   =========================================================== */
.article-hero { position: relative; overflow: clip; }
.article-hero .hero-sky { position: absolute; inset: 0; z-index: 0; background:
  radial-gradient(800px 360px at 78% -12%, var(--accent-tint), transparent 60%), linear-gradient(180deg,#fbfdff,#fff); pointer-events: none; }
.article-hero .inner { position: relative; z-index: 2; max-width: 760px; margin-inline: auto; padding-block: clamp(36px,5vw,64px) clamp(20px,3vw,32px); }
.breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--ink-3); margin-bottom: 22px; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--accent-deep); }
.breadcrumb .sep { opacity: .5; }
.article-hero h1 { font-size: clamp(2rem, 4.4vw, 3.1rem); }
.article-hero .post-meta { margin-top: 22px; }
.article-cover {
  max-width: 1000px; margin: 0 auto; border-radius: var(--radius-lg);
  border: 1px solid var(--line); overflow: hidden; background: var(--cloud-2);
  box-shadow: var(--shadow-sm);
}
.article-cover .ph { aspect-ratio: 21/9; border-radius: var(--radius-lg); border: 1px solid var(--line); }
.article-cover-image { display: block; width: 100%; aspect-ratio: 21/9; object-fit: cover; border-radius: inherit; }

.article-wrap { max-width: 760px; margin-inline: auto; }
.article-intro { display: grid; gap: 12px; margin-bottom: 8px; }
.article-lead { font-size: clamp(1.15rem, 1.7vw, 1.32rem); color: var(--ink); font-weight: 600; line-height: 1.55; margin-bottom: 8px; }

.prose { color: var(--ink); }
.prose > * + * { margin-top: 24px; }
.prose h2 { font-size: clamp(1.5rem, 2.6vw, 2rem); margin-top: 48px; }
.prose h3 { font-size: clamp(1.2rem, 2vw, 1.45rem); margin-top: 36px; }
.prose p { font-size: 17.5px; line-height: 1.75; color: var(--ink-2); }
.prose p strong { color: var(--ink); font-weight: 700; }
.prose a { color: var(--accent-deep); font-weight: 600; text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--accent-soft); }
.prose a:hover { text-decoration-color: var(--accent); }
.prose ul, .prose ol { padding-left: 4px; list-style: none; display: grid; gap: 12px; }
.prose ul li, .prose ol li { position: relative; padding-left: 32px; font-size: 17px; line-height: 1.65; color: var(--ink-2); }
.prose ul li::before { content: ""; position: absolute; left: 4px; top: 11px; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.prose ol { counter-reset: li; }
.prose ol li { counter-increment: li; }
.prose ol li::before { content: counter(li); position: absolute; left: 0; top: 1px; width: 24px; height: 24px; border-radius: 50%; background: var(--accent-tint); color: var(--accent-deep); font-size: 12.5px; font-weight: 800; display: grid; place-items: center; }
.prose blockquote { margin: 8px 0; padding: 22px 26px; background: var(--accent-tint); border-radius: var(--radius); border: 1px solid var(--accent-soft); font-size: 18px; font-weight: 600; color: var(--ink); }
.article-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); }
.article-table-wrap table { width: 100%; min-width: 520px; border-collapse: collapse; background: var(--white); }
.article-table-wrap th, .article-table-wrap td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.article-table-wrap th { color: var(--ink); background: var(--cloud); font-size: 13px; }
.article-table-wrap td { color: var(--ink-2); font-size: 15px; }
.article-table-wrap tbody tr:last-child td { border-bottom: 0; }
.editor-cta {
  display: flex; align-items: center; justify-content: space-between; gap: 22px;
  padding: 24px; border: 1px solid var(--accent-soft); border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--accent-tint), #fff);
}
.editor-cta span { display: block; margin-bottom: 5px; color: var(--accent-deep); font-size: 12px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; }
.editor-cta p { margin: 0; color: var(--ink); font-size: 17px; font-weight: 750; line-height: 1.45; }
.editor-cta .btn { flex: none; color: #fff; text-decoration: none; }
.article-faq details { padding: 0 18px; border: 1px solid var(--line); border-radius: 14px; background: var(--white); }
.article-faq details + details { margin-top: 10px; }
.article-faq summary { padding: 16px 0; cursor: pointer; color: var(--ink); font-weight: 750; }
.article-faq details p { margin: 0; padding: 0 0 18px; font-size: 15.5px; }
.article-links > div { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.article-links a { display: flex; justify-content: space-between; gap: 16px; padding: 15px 16px; border: 1px solid var(--line); border-radius: 14px; color: var(--ink); text-decoration: none; background: var(--white); }
.article-links a:hover { border-color: var(--accent-soft); color: var(--accent-deep); }
.article-tags { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 8px; }
.article-tags span { padding: 7px 11px; border-radius: 100px; background: var(--cloud); color: var(--ink-2); font-size: 12px; font-weight: 700; }
.prose .key { display: grid; gap: 8px; padding: 22px 24px; border-radius: var(--radius); background: var(--pos-tint); border: 1px solid #bce7d2; }
.prose .key .cap { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--pos); }
.prose .key p { font-size: 15.5px; color: var(--ink-2); }

/* share + author box */
.article-foot { max-width: 760px; margin: 48px auto 0; display: grid; gap: 28px; }
.author-box { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: 26px; background: var(--cloud); border: 1px solid var(--line); border-radius: var(--radius); }
.author-box .av { width: 56px; height: 56px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 18px; }
.author-box .an { font-size: 1.1rem; font-weight: 800; }
.author-box .ar { font-size: 13.5px; color: var(--ink-3); font-weight: 600; }
.author-box p { font-size: 14.5px; color: var(--ink-2); margin-top: 8px; }
.article-cta { text-align: center; padding: 34px; border-radius: var(--radius-lg); background: var(--ink); color: #fff; position: relative; overflow: hidden; }
.article-cta .glow { position: absolute; inset: 0; background: radial-gradient(500px 240px at 50% 0%, rgba(19,145,236,.4), transparent 65%); }
.article-cta > * { position: relative; z-index: 2; }
.article-cta h3 { font-size: clamp(1.4rem,3vw,1.9rem); color: #fff; max-width: 20ch; margin: 0 auto 8px; }
.article-cta p { color: rgba(255,255,255,.72); font-size: 15px; margin-bottom: 22px; }

.related { max-width: 1000px; margin: 0 auto; }

@media (max-width: 480px) {
  .article-cover-image { aspect-ratio: 16/10; }
  .editor-cta { align-items: stretch; flex-direction: column; padding: 20px; }
  .editor-cta .btn { width: 100%; }
  .article-links > div { grid-template-columns: 1fr; }
}

/* ===========================================================
   TWEAKS — warianty charakteru listy bloga
   =========================================================== */

/* — Układ wpisów — */
:scope[data-grid="magazine"] .post-grid { grid-template-columns: repeat(2, 1fr); gap: 30px; }
:scope[data-grid="magazine"] .post-card h3 { font-size: 1.5rem; }
:scope[data-grid="magazine"] .post-card .pc-ex { font-size: 15.5px; }
:scope[data-grid="magazine"] .post-card .pc-body { padding: 28px; }

:scope[data-grid="list"] .post-grid { grid-template-columns: 1fr; gap: 14px; }
:scope[data-grid="list"] .post-card { flex-direction: row; align-items: stretch; }
:scope[data-grid="list"] .post-card .pc-media { width: 38%; max-width: 340px; flex: none; aspect-ratio: auto; }
:scope[data-grid="list"] .post-card .pc-body { flex: 1; justify-content: center; }
:scope[data-grid="list"] .post-card h3 { font-size: 1.45rem; }
@media (max-width: 680px) {
  :scope[data-grid="magazine"] .post-grid { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; }
  :scope[data-grid="list"] .post-card { flex-direction: column; }
  :scope[data-grid="list"] .post-card .pc-media { width: 100%; max-width: none; aspect-ratio: 16/10; }
}

/* — Nastrój: Ciepły (kremowy) — */
:scope[data-mood="warm"] {
  --white: #fffdf8; --cloud: #faf3e9; --cloud-2: #f1e6d4;
  --line: #ece1cf; --line-2: #e0d1b8;
  --ink: #2a2118; --ink-2: #5c5346; --ink-3: #8a7f6e;
  background: #faf3e9;
}
:scope[data-mood="warm"] .site-header { background: rgba(255,253,248,.86); }
:scope[data-mood="warm"] .blog-hero .hero-sky {
  background: radial-gradient(900px 420px at 80% -10%, var(--accent-tint), transparent 60%), linear-gradient(180deg, #fffdf8, #faf3e9);
}

/* — Nastrój: Nocny (ciemny motyw) — */
:scope[data-mood="night"] {
  --white: #14222f; --cloud: #0d1922; --cloud-2: #1d2f3d;
  --line: rgba(255,255,255,.10); --line-2: rgba(255,255,255,.18);
  --ink: #eaf1f8; --ink-2: #aebccb; --ink-3: #7e8c9b;
  background: #0a141d;
}
:scope[data-mood="night"] { background: #0a141d; }
:scope[data-mood="night"] .site-header { background: rgba(13,25,34,.82); }
:scope[data-mood="night"] .site-header.scrolled { box-shadow: 0 6px 24px -18px #000; }
:scope[data-mood="night"] .blog-hero .hero-sky {
  background: radial-gradient(900px 420px at 80% -10%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 60%), linear-gradient(180deg, #0d1922, #0a141d);
}
:scope[data-mood="night"] .blog-search { background: var(--white); border-color: var(--line-2); }
:scope[data-mood="night"] .cat { background: var(--white); }
:scope[data-mood="night"] .ph { background: #1d2f3d; background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 12px, transparent 12px 24px); }
:scope[data-mood="night"] .ph .ph-mark { color: #bfe2fb; }
:scope[data-mood="night"] .pc-cat { background: rgba(13,25,34,.86); color: #bfe2fb; border-color: rgba(255,255,255,.18); }
:scope[data-mood="night"] .nav-links a:hover { background: rgba(255,255,255,.06); }
:scope[data-mood="night"] .btn-ghost { color: var(--ink); border-color: var(--line-2); }

/* ===========================================================
   TWEAKS — charakter czytania artykułu (blog-artykul.html)
   =========================================================== */
:scope { --serif: var(--font-source-serif), Georgia, "Times New Roman", serif; }

/* — Charakter pisma — */
/* Kontrast: szeryfowe nagłówki, sans treść */
:scope[data-type="contrast"] .article-hero h1,
:scope[data-type="contrast"] .prose h2,
:scope[data-type="contrast"] .prose h3,
:scope[data-type="contrast"] .article-lead {
  font-family: var(--serif); letter-spacing: -0.01em; font-weight: 700;
}
/* Magazyn: szeryf również w treści */
:scope[data-type="magazine"] .article-hero h1,
:scope[data-type="magazine"] .prose h2,
:scope[data-type="magazine"] .prose h3,
:scope[data-type="magazine"] .article-lead {
  font-family: var(--serif); letter-spacing: -0.01em; font-weight: 700;
}
:scope[data-type="magazine"] .prose p,
:scope[data-type="magazine"] .prose li,
:scope[data-type="magazine"] .prose blockquote {
  font-family: var(--serif);
}
:scope[data-type="magazine"] .prose p { font-size: 18.5px; line-height: 1.78; }
:scope[data-type="magazine"] .prose blockquote { font-style: italic; }

/* — Szerokość czytania — */
:scope[data-width="focus"] .article-hero .inner,
:scope[data-width="focus"] .article-wrap,
:scope[data-width="focus"] .article-foot { max-width: 620px; }
:scope[data-width="focus"] .prose p { font-size: 18.5px; line-height: 1.8; }
:scope[data-width="focus"] .article-lead { font-size: clamp(1.2rem, 1.8vw, 1.4rem); }

:scope[data-width="wide"] .article-hero .inner,
:scope[data-width="wide"] .article-wrap,
:scope[data-width="wide"] .article-foot { max-width: 920px; }

}
