/*
Theme Name: Apokryf Ruski
Theme URI: https://apokryfruski.org
Author: Apokryf Ruski
Author URI: https://apokryfruski.org
Description: Editorial archival theme — paleta "Papier i atrament", typografia Cormorant Garamond + Karla, układ asymetryczny 60/40. Komplet szablonów (archiwa, wyszukiwanie, autor, załączniki, komentarze, customizer, widgety stopki, edytor blokowy). Stworzony dla projektu Apokryf Ruski.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: apokryf-ruski
Tags: editorial, archive, asymmetric, serif, minimal, blog, two-columns, right-sidebar, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, block-styles, wide-blocks
*/

/* === Design tokens === */
:root {
  --paper: #f5f3ee;
  --paper-dark: #e8e4dd;
  --ink: #2d2d2d;
  --ink-heavy: #0d0d0d;
  --accent: #8b5a2b;
  --accent-foreground: #f5f3ee;
  --border: #d8d3c8;
  --muted: #6b6b6b;
  --radius: 2px;
  --font-serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --font-sans: "Karla", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  --max-w: 1280px;
  --content-w: 720px;
}

/* === Reset === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body.nav-open { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ink-heavy); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--accent); }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--ink-heavy);
  letter-spacing: -0.01em;
  margin: 0 0 .6em;
  line-height: 1.15;
}
h1 { font-size: clamp(2.5rem, 5vw, 4.5rem); }
h2 { font-size: clamp(1.8rem, 3.2vw, 2.75rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.6rem); }
h4 { font-size: 1.05rem; }
p { margin: 0 0 1.2em; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 2rem; }

/* === Skip link === */
.skip-link {
  position: absolute; left: -10000px; top: auto; z-index: 100;
  background: var(--ink-heavy); color: var(--paper); padding: .75rem 1rem;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* === Header / Nav === */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(245,243,238,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}
.site-header .inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 2rem; gap: 2rem;
  max-width: var(--max-w); margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: .9rem; }
.custom-logo-link img { width: 48px; height: 48px; object-fit: contain; }
.site-title {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: .02em;
  display: inline-block;
}
.site-title small, .site-description {
  display: block;
  font-family: var(--font-sans);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--muted);
  margin-top: 2px;
}

.main-nav ul, .nav-menu, .social-menu {
  display: flex; gap: 2rem; list-style: none; margin: 0; padding: 0;
  font-size: .85rem; text-transform: uppercase; letter-spacing: .15em;
  align-items: center;
}
.main-nav a { color: var(--ink); transition: color .15s ease; }
.main-nav a:hover,
.main-nav a:focus { color: var(--accent); }
.main-nav .current-menu-item > a,
.main-nav .current_page_item > a { color: var(--accent); border-bottom: 1px solid var(--accent); padding-bottom: 2px; }
.main-nav .sub-menu,
.main-nav .children {
  position: absolute; top: 100%; left: 0;
  background: var(--paper); border: 1px solid var(--border);
  display: none; flex-direction: column; gap: 0; padding: .5rem 0;
  min-width: 220px; margin: 0; z-index: 60;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.main-nav li { position: relative; }
.main-nav .sub-menu .sub-menu,
.main-nav .children .children { top: -.5rem; left: 100%; }
.main-nav .menu-item-has-children > a,
.main-nav .page_item_has_children > a { padding-bottom: .75rem; }
.main-nav li:hover > .sub-menu,
.main-nav li:hover > .children,
.main-nav li:focus-within > .sub-menu,
.main-nav li:focus-within > .children,
.main-nav li.is-open > .sub-menu,
.main-nav li.is-open > .children { display: flex; }
.main-nav .sub-menu li,
.main-nav .children li { width: 100%; }
.main-nav .sub-menu a,
.main-nav .children a { display: block; padding: .5rem 1.25rem; font-size: .8rem; white-space: nowrap; color: var(--ink); }
.main-nav .sub-menu a:hover,
.main-nav .sub-menu a:focus,
.main-nav .children a:hover,
.main-nav .children a:focus { color: var(--accent); background: var(--paper-dark); }

.menu-toggle {
  display: none;
  background: transparent; border: 1px solid var(--ink-heavy);
  padding: .55rem .6rem; cursor: pointer;
}
.menu-toggle .bar { display: block; width: 22px; height: 1.5px; background: var(--ink-heavy); margin: 4px 0; }

/* === Buttons === */
.btn {
  display: inline-block;
  padding: .85rem 1.6rem;
  font-family: var(--font-sans);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  border: 1px solid var(--ink-heavy);
  background: var(--ink-heavy);
  color: var(--paper);
  cursor: pointer;
  transition: all .2s ease;
}
.btn:hover { background: var(--accent); border-color: var(--accent); color: var(--paper); }
.btn-ghost { background: transparent; color: var(--ink-heavy); }
.btn-ghost:hover { background: var(--ink-heavy); color: var(--paper); }

/* === Hero === */
.hero { padding: 4rem 0 6rem; border-bottom: 1px solid var(--border); }
.hero .grid { display: grid; grid-template-columns: 60% 40%; gap: 3rem; align-items: end; }
.hero .eyebrow { font-size: .75rem; text-transform: uppercase; letter-spacing: .3em; color: var(--accent); margin-bottom: 1.5rem; }
.hero h1 { font-style: italic; font-weight: 400; }
.hero .lede { font-size: 1.15rem; max-width: 38em; color: var(--ink); margin-top: 1.5rem; }
.hero .cta-row { margin-top: 2.5rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.hero figure { margin: 0; }
.hero figure img { width: 100%; aspect-ratio: 4/5; object-fit: cover; filter: sepia(.15) contrast(.95); }
.hero figcaption {
  font-family: var(--font-serif); font-style: italic;
  font-size: .95rem; color: var(--muted);
  margin-top: .8rem; padding-left: 1rem; border-left: 2px solid var(--accent);
}

/* === Editorial 60/40 === */
.editorial { padding: 6rem 0; border-bottom: 1px solid var(--border); }
.editorial .grid { display: grid; grid-template-columns: 18% 1fr; gap: 4rem; align-items: start; }
.editorial aside { position: sticky; top: 6rem; border-top: 2px solid var(--ink-heavy); padding-top: 1.5rem; }
.editorial aside .label {
  font-size: .7rem; text-transform: uppercase; letter-spacing: .3em; color: var(--muted);
  margin-bottom: 1rem;
}
.editorial aside h2 { font-style: italic; }
.editorial .body p { font-size: 1.05rem; line-height: 1.8; }
/* Sepia treatment for images on the front page */
body.home .editorial .body img,
.home .editorial .body img { filter: sepia(0.85) contrast(.95) saturate(.9); }
.editorial .body p:first-of-type::first-letter {
  font-family: var(--font-serif); font-size: 4.5rem; float: left;
  line-height: .9; padding: .4rem .6rem 0 0; color: var(--accent); font-style: italic;
}

/* === Regions (dark band) === */
.regions { background: var(--ink-heavy); color: var(--paper); padding: 6rem 0; }
.regions h2, .regions h3 { color: var(--paper); }
.regions .eyebrow { color: var(--paper-dark); opacity: .7; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .3em; margin-bottom: 1rem; }
.regions .list { margin-top: 3rem; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0; border-top: 1px solid rgba(245,243,238,.2); }
.regions .list .item { padding: 2rem 1.5rem;
  border-bottom: 1px solid rgba(245,243,238,.15); border-right: 1px solid rgba(245,243,238,.15); }
.regions .list .item:last-child { border-right: none; }
.regions .num { font-family: var(--font-serif); font-style: italic; font-size: .9rem;
  color: var(--accent); display: block; margin-bottom: .5rem; }
.regions .item h3 { font-size: 1.4rem; margin-bottom: .5rem; }
.regions .item p { font-size: .9rem; color: var(--paper-dark); opacity: .8; margin: 0; }

/* === Archive cards (front page) === */
.archive { padding: 6rem 0; border-bottom: 1px solid var(--border); }
.archive > .container > header { display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 3rem; gap: 2rem; flex-wrap: wrap; }
.archive .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.archive .card img { aspect-ratio: 3/4; object-fit: cover; filter: sepia(.2) contrast(.95); }
.archive .card .meta { font-size: .7rem; text-transform: uppercase; letter-spacing: .25em;
  color: var(--accent); margin-top: 1rem; }
.archive .card h3 { font-style: italic; margin-top: .4rem; font-size: 1.25rem; }
.archive .card h3 a { color: var(--ink-heavy); }
.archive .card h3 a:hover { color: var(--accent); }
.archive .card p { font-size: .9rem; color: var(--muted); }

/* === Site content (archive/single/page list layout) === */
.site-content {
  display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 4rem;
  padding: 4rem 2rem;
}
.site-content.no-sidebar, body.no-sidebar .site-content { grid-template-columns: minmax(0, 1fr); max-width: 880px; }
.site-content.full-width { grid-template-columns: minmax(0, 1fr); max-width: var(--max-w); }
.content-area { min-width: 0; }

/* Page header */
.page-header { margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--border); }
.page-header .page-title { font-style: italic; }
.page-header .entry-meta { color: var(--accent); font-size: .75rem; text-transform: uppercase;
  letter-spacing: .3em; margin-bottom: .75rem; }
.archive-description { color: var(--muted); margin-top: 1rem; max-width: 38em; }
.author-header { display: flex; gap: 1.5rem; align-items: center; }
.author-header .avatar { border-radius: 50%; }
.author-bio { color: var(--muted); margin-top: .5rem; max-width: 42em; }

/* === Post summary cards (archives) === */
.post-summary {
  display: grid; grid-template-columns: 280px 1fr; gap: 2rem; align-items: start;
  padding: 2rem 0; border-bottom: 1px solid var(--border);
}
.post-summary:last-child { border-bottom: none; }
.post-summary .post-thumbnail img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover; filter: sepia(.15) contrast(.95);
}
.post-summary .entry-title { font-style: italic; margin: .25rem 0 .75rem; }
.post-summary .entry-title a { color: var(--ink-heavy); }
.post-summary .entry-title a:hover { color: var(--accent); }
.post-summary .entry-meta { color: var(--muted); font-size: .75rem;
  text-transform: uppercase; letter-spacing: .2em; margin-bottom: .5rem; }
.post-summary .entry-meta .author-link { color: var(--ink-heavy); }
.post-summary .entry-excerpt { color: var(--ink); margin-bottom: 1rem; }
.post-summary .btn-ghost { margin-top: .5rem; }
.post-summary .tags-links { display: block; margin-top: 1rem; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }
.post-summary .tags-links a { color: var(--muted); }
.post-summary .tags-links a:hover { color: var(--accent); }

/* === Entry (single/page) === */
.entry { padding: 0 0 3rem; }
.entry .entry-header { margin-bottom: 2rem; }
.entry .entry-title { margin-bottom: 1rem; font-style: italic; }
.entry .entry-meta { color: var(--muted); font-size: .8rem;
  text-transform: uppercase; letter-spacing: .2em; margin-bottom: 1.5rem; }
.entry .entry-meta .author-link { color: var(--ink-heavy); }
.entry .post-thumbnail { margin: 2rem 0; }
.entry .post-thumbnail img { width: 100%; max-height: 560px; object-fit: cover; filter: sepia(.1) contrast(.97); }
.entry .entry-content { max-width: var(--content-w); margin: 0 auto; }
.entry .entry-content p { font-size: 1.05rem; line-height: 1.8; }
.entry .entry-content > *:not(.alignwide):not(.alignfull) { max-width: var(--content-w); margin-left: auto; margin-right: auto; }
.entry .entry-content > h2 { font-style: italic; margin-top: 2.5rem; }
.entry .entry-content > h3 { margin-top: 2rem; }
.entry .entry-content blockquote, .entry blockquote {
  border-left: 3px solid var(--accent); padding-left: 1.5rem;
  font-family: var(--font-serif); font-style: italic; font-size: 1.3rem;
  color: var(--ink-heavy); margin: 2rem 0;
}
.entry .entry-content ul, .entry .entry-content ol { padding-left: 1.4rem; }
.entry .entry-content li { margin-bottom: .4rem; }
.entry .entry-content code { background: var(--paper-dark); padding: .12em .4em; font-size: .92em; border-radius: 2px; }
.entry .entry-content pre {
  background: var(--ink-heavy); color: var(--paper); padding: 1.2rem 1.5rem;
  overflow-x: auto; font-size: .9rem; line-height: 1.55;
}
.entry .entry-content pre code { background: transparent; padding: 0; color: inherit; }
.entry .entry-content hr { border: 0; border-top: 1px solid var(--border); margin: 2.5rem 0; }
.entry .entry-content table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; }
.entry .entry-content th, .entry .entry-content td { padding: .75rem 1rem; border-bottom: 1px solid var(--border); text-align: left; }
.entry-footer .tags-links { display: block; margin-top: 2rem; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }
.entry-footer .tags-links a { color: var(--muted); margin-right: .5rem; }
.entry-footer .tags-links a:hover { color: var(--accent); }
.page-links { margin: 2rem 0; font-size: .85rem; text-transform: uppercase; letter-spacing: .2em; }
.page-links a, .page-links > span { display: inline-block; padding: .35rem .6rem; border: 1px solid var(--border); margin-right: .25rem; }

/* Attachment */
.attachment-figure { margin: 2rem 0; text-align: center; }
.attachment-figure figcaption { font-style: italic; color: var(--muted); margin-top: .8rem; }

/* === Pagination === */
.navigation.pagination, .post-navigation, .comments-navigation { margin: 3rem 0; }
.navigation .nav-links { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; }
.navigation .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.4rem; height: 2.4rem; padding: 0 .75rem;
  border: 1px solid var(--border); font-size: .85rem;
  text-transform: uppercase; letter-spacing: .15em; color: var(--ink);
}
.navigation .page-numbers.current, .navigation .page-numbers:hover {
  background: var(--ink-heavy); color: var(--paper); border-color: var(--ink-heavy);
}
.post-navigation .nav-links {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  padding-top: 2rem; border-top: 1px solid var(--border);
  font-family: var(--font-serif); font-style: italic; font-size: 1.1rem;
}
.post-navigation .nav-next { text-align: right; }

/* === Author box === */
.author-box {
  display: grid; grid-template-columns: 72px 1fr; gap: 1.5rem;
  padding: 2rem; margin: 3rem 0; background: var(--paper-dark); border-left: 3px solid var(--accent);
}
.author-box .avatar { border-radius: 50%; }
.author-box .author-name { font-style: italic; margin-bottom: .25rem; }

/* === Comments === */
.comments-area { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.comments-title { font-style: italic; margin-bottom: 2rem; }
.comment-list { list-style: none; padding: 0; margin: 0; }
.comment-list .children { list-style: none; padding-left: 2rem; margin-top: 1rem; border-left: 1px solid var(--border); }
.comment-body { padding: 1.5rem 0; border-bottom: 1px solid var(--border); }
.comment-meta { display: grid; grid-template-columns: 48px 1fr; gap: 1rem; align-items: center; margin-bottom: .75rem; }
.comment-meta .avatar { border-radius: 50%; }
.comment-author { font-family: var(--font-serif); font-style: italic; font-size: 1.05rem; color: var(--ink-heavy); }
.comment-date { display: block; font-size: .7rem; color: var(--muted);
  text-transform: uppercase; letter-spacing: .2em; }
.comment-content { margin-left: calc(48px + 1rem); }
.comment-footer { margin-left: calc(48px + 1rem); margin-top: .5rem; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }
.comment-footer a { color: var(--accent); }
.comment-awaiting { color: var(--muted); }
.comment-form { display: grid; gap: 1rem; margin-top: 2rem; }
.comment-form label { display: block; font-size: .75rem; text-transform: uppercase; letter-spacing: .2em; color: var(--muted); margin-bottom: .35rem; }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea {
  width: 100%; padding: .75rem 1rem; border: 1px solid var(--border);
  background: var(--paper); font-family: var(--font-sans); font-size: 1rem; color: var(--ink-heavy);
}
.comment-form textarea { min-height: 160px; resize: vertical; }
.comment-form .form-submit { margin-top: .5rem; }

/* === Sidebar / Widgets === */
.widget-area { display: flex; flex-direction: column; gap: 2.5rem; }
.widget { padding-bottom: 2rem; border-bottom: 1px solid var(--border); }
.widget:last-child { border-bottom: none; }
.widget-title {
  font-family: var(--font-sans); font-size: .75rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .25em; color: var(--muted);
  margin-bottom: 1rem;
}
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget li { padding: .35rem 0; border-bottom: 1px dotted var(--border); font-size: .9rem; }
.widget li:last-child { border-bottom: none; }
.widget a { color: var(--ink); }
.widget a:hover { color: var(--accent); }
.widget select { width: 100%; padding: .55rem .75rem; border: 1px solid var(--border); background: var(--paper); }

/* === Search form === */
.search-form { display: flex; gap: .5rem; }
.search-form .search-field {
  flex: 1; padding: .75rem 1rem; border: 1px solid var(--border);
  background: var(--paper); font-family: var(--font-sans);
}

/* === Footer === */
.site-footer { background: var(--paper-dark); padding: 4rem 0 2rem; font-size: .9rem; }
.site-footer .grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; }
.site-footer.footer-widgets .grid, .site-footer .footer-widgets { grid-template-columns: repeat(4, 1fr); }
.site-footer h4, .site-footer .widget-title {
  font-family: var(--font-sans); font-size: .75rem; text-transform: uppercase;
  letter-spacing: .25em; color: var(--muted); margin-bottom: 1rem; font-weight: 600;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: .5rem; }
.site-footer .footer-tagline { font-family: var(--font-serif); font-style: italic; font-size: 1.05rem; color: var(--ink); }
.site-footer .legal {
  border-top: 1px solid var(--border); margin-top: 3rem; padding-top: 1.5rem;
  display: flex; justify-content: space-between; font-size: .75rem; color: var(--muted);
  text-transform: uppercase; letter-spacing: .15em;
}

/* === WP core alignments / gallery / captions === */
.alignleft { float: left; margin: .5rem 1.5rem 1rem 0; }
.alignright { float: right; margin: .5rem 0 1rem 1.5rem; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignwide { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.wp-caption { max-width: 100%; }
.wp-caption-text, .wp-block-image figcaption {
  font-family: var(--font-serif); font-style: italic; color: var(--muted);
  font-size: .9rem; text-align: center; margin-top: .6rem;
}
.gallery { display: grid; gap: .75rem; margin: 1.5rem 0; }
.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }
.gallery-columns-5 { grid-template-columns: repeat(5, 1fr); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1/1; }
.gallery-caption { font-style: italic; color: var(--muted); font-size: .8rem; }
.sticky .entry-title::before { content: "★ "; color: var(--accent); }

/* === Block editor color classes === */
.has-paper-color { color: var(--paper); }
.has-paper-background-color { background-color: var(--paper); }
.has-ink-color { color: var(--ink); }
.has-ink-background-color { background-color: var(--ink); }
.has-ink-heavy-color { color: var(--ink-heavy); }
.has-ink-heavy-background-color { background-color: var(--ink-heavy); }
.has-accent-color { color: var(--accent); }
.has-accent-background-color { background-color: var(--accent); }
.has-muted-color { color: var(--muted); }

/* === Post format hints === */
.format-quote .entry-content p:first-child {
  font-family: var(--font-serif); font-style: italic; font-size: 1.4rem;
  border-left: 3px solid var(--accent); padding-left: 1.5rem;
}
.format-aside .entry-title { font-size: 1.4rem; }
.format-link .entry-title::after { content: " →"; color: var(--accent); }

/* === Accessibility === */
.screen-reader-text {
  position: absolute !important; clip: rect(1px,1px,1px,1px);
  width: 1px; height: 1px; overflow: hidden; white-space: nowrap;
}
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* === Error 404 === */
.error-404 { padding: 5rem 0; }

/* === Mobile === */
@media (max-width: 980px) {
  .site-content { grid-template-columns: 1fr; gap: 3rem; padding: 3rem 1.25rem; }
  .post-summary { grid-template-columns: 1fr; }
  .site-footer .grid, .site-footer .footer-widgets { grid-template-columns: repeat(2, 1fr); gap: 2rem; }
  .archive .grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px) {
  .container, .site-header .inner { padding-left: 1.25rem; padding-right: 1.25rem; }
  /* Wyłączamy backdrop-filter na mobile, bo tworzy containing block
     dla fixed-children i blokuje rozwijanie menu. */
  .site-header { backdrop-filter: none; -webkit-backdrop-filter: none; background: var(--paper); }
  .site-header .inner { flex-wrap: wrap; gap: 1rem; padding: .9rem 1.25rem; }
  .menu-toggle { display: block; order: 3; }
  .brand { order: 1; flex: 1; min-width: 0; }
  .social-nav { order: 4; width: 100%; }
  .main-nav {
    order: 5; width: 100%;
    display: none;
    max-height: 0; overflow: hidden;
    transition: max-height .25s ease;
    border-top: 1px solid var(--border);
    margin: 0 -1.25rem;
    padding: 0 1.25rem;
    background: var(--paper);
  }
  .main-nav.is-open {
    display: block;
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    padding: 1.25rem 1.25rem 1.75rem;
  }
  body.nav-open { overflow: hidden; }
  .menu-toggle[aria-expanded="true"] .bar:nth-child(2) { transform: rotate(45deg) translate(4px, 4px); }
  .menu-toggle[aria-expanded="true"] .bar:nth-child(3) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] .bar:nth-child(4) { transform: rotate(-45deg) translate(5px, -5px); }
  .menu-toggle .bar { transition: transform .2s ease, opacity .2s ease; }
  .main-nav ul, .nav-menu { flex-direction: column; gap: 1rem; align-items: flex-start; }
  .main-nav .nav-menu > li { width: 100%; padding-bottom: .75rem; border-bottom: 1px solid var(--border); }
  .main-nav a { display: block; padding: .25rem 0; font-size: 1rem; }
  .main-nav .sub-menu, .main-nav .children { position: static; border: none; padding: .5rem 0 .5rem 1rem; box-shadow: none; }
  .main-nav .sub-menu a, .main-nav .children a { white-space: normal; }
  .hero { padding: 2.5rem 0 3.5rem; }
  .hero .grid, .editorial .grid, .site-footer .grid, .site-footer .footer-widgets { grid-template-columns: 1fr; gap: 2.5rem; }
  .editorial aside { position: static; }
  .archive .grid { grid-template-columns: 1fr; }
  .archive > .container > header { flex-direction: column; align-items: flex-start; }
  .post-navigation .nav-links { grid-template-columns: 1fr; }
  .post-navigation .nav-next { text-align: left; }
  .site-footer .legal { flex-direction: column; gap: .5rem; }
  .author-box { grid-template-columns: 56px 1fr; padding: 1.25rem; }
  .comment-content, .comment-footer { margin-left: 0; }
  .author-header { flex-direction: column; align-items: flex-start; text-align: left; }
}

/* ============================================================
   Apokryf Ruski – ulepszenia (v2.1)
   ============================================================ */

/* --- Reading progress bar --- */
.reading-progress{
  position:fixed; top:0; left:0; right:0; height:3px;
  background:transparent; z-index:9999; pointer-events:none;
}
.reading-progress-bar{
  height:100%; width:100%;
  background:linear-gradient(90deg, #b8860b, #8b1e1e);
  transform:scaleX(0); transform-origin:left center;
  transition:transform .08s linear;
}

/* --- Breadcrumbs --- */
.breadcrumbs{
  max-width:1100px; margin:1rem auto 0; padding:.5rem 1rem;
  font-size:.85rem; color:#6b6357;
}
.breadcrumbs ol{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:.4rem; }
.breadcrumbs li{ display:inline-flex; align-items:center; }
.breadcrumbs li.sep{ opacity:.5; }
.breadcrumbs a{ color:inherit; text-decoration:none; border-bottom:1px dotted currentColor; }
.breadcrumbs a:hover{ color:#8b1e1e; }

/* --- Header search --- */
.header-search-toggle{
  background:transparent; border:0; padding:.5rem; cursor:pointer; color:inherit;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:50%; transition:background-color .2s;
}
.header-search-toggle:hover{ background:rgba(0,0,0,.05); }
.header-search-panel{
  position:absolute; left:0; right:0; top:100%;
  background:#fff; box-shadow:0 8px 24px rgba(0,0,0,.08);
  padding:1rem; z-index:50;
}
.header-search-panel .search-form{ display:flex; gap:.5rem; max-width:680px; margin:0 auto; }
.header-search-panel .search-field{
  flex:1; padding:.6rem .9rem; border:1px solid #d8d2c4; border-radius:6px;
  font:inherit;
}
/* Ukryj duplikat w menu mobilnym na desktopie */
.nav-search{ display:none; }
@media (max-width: 900px){
  .header-search-toggle{ display:none; }
  .nav-search{ display:block; padding:1rem; }
  .nav-search .search-form{ display:flex; gap:.5rem; }
  .nav-search .search-field{ flex:1; padding:.6rem; border:1px solid #d8d2c4; border-radius:6px; font:inherit; }
}

/* --- Spis treści --- */
.entry-toc{
  margin:1.5rem 0 2rem; padding:1rem 1.25rem;
  background:#faf7f0; border-left:3px solid #b8860b; border-radius:4px;
}
.entry-toc-title{
  margin:0 0 .5rem; font-weight:600; text-transform:uppercase;
  font-size:.8rem; letter-spacing:.08em; color:#6b6357;
}
.entry-toc-list{ margin:0; padding-left:1.2rem; }
.entry-toc-list li{ margin:.25rem 0; }
.entry-toc-list .toc-h3{ margin-left:1rem; list-style:circle; font-size:.95em; }
.entry-toc-list a{ color:#3a352d; text-decoration:none; }
.entry-toc-list a:hover{ color:#8b1e1e; text-decoration:underline; }

/* Smooth scroll do kotwic */
html{ scroll-behavior:smooth; }
:target{ scroll-margin-top:80px; }

/* --- Cite this page --- */
.cite-box{
  margin-top:1.5rem; padding:.85rem 1rem;
  background:#f5f1e8; border:1px solid #e6dfcc; border-radius:6px;
  font-size:.92rem;
}
.cite-box summary{
  cursor:pointer; font-weight:600; color:#6b4a1e; list-style:none;
}
.cite-box summary::-webkit-details-marker{ display:none; }
.cite-box summary::before{ content:"📖 "; }
.cite-box[open] summary{ margin-bottom:.6rem; }
.cite-text{
  margin:.5rem 0; padding:.6rem .8rem;
  background:#fff; border:1px dashed #d8d2c4; border-radius:4px;
  font-family:Karla, system-ui, sans-serif; font-size:.88rem; line-height:1.55;
}
.cite-copy{ font-size:.82rem; padding:.35rem .7rem; }
.site-header .inner{ position:relative; }
