/* ============================================================
   DobreZiola — main.css
   Globalne style: zmienne, reset, typografia, header, footer,
   przyciski, karty, badge, paginacja, formularze.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root {
	/* Zieleń */
	--dz-green-dark:   #1a3d1a;
	--dz-green-mid:    #2d5a2d;
	--dz-green-light:  #4a7c4a;
	--dz-green-pale:   #e8f5e8;
	--dz-green-mist:   #f3f8f1;

	/* Tła */
	--dz-cream:        #faf7f2;
	--dz-cream-dark:   #f2ede6;
	--dz-white:        #ffffff;

	/* Tekst */
	--dz-text:         #1c1c1c;
	--dz-text-soft:    #4a4a4a;
	--dz-text-muted:   #8a8578;

	/* Akcenty */
	--dz-gold:         #c8a96e;
	--dz-gold-soft:    #e4d3ad;
	--dz-border:       #e6ded2;

	/* Kategorie (badge) */
	--dz-cat-zdrowie:  #b85c5c;
	--dz-cat-uroda:    #b56a98;
	--dz-cat-ziola:    #4a7c4a;
	--dz-cat-kuchnia:  #c8923a;

	/* Cienie */
	--dz-shadow-sm:  0 2px 8px rgba(26,61,26,.07);
	--dz-shadow-md:  0 6px 24px rgba(26,61,26,.10);
	--dz-shadow-lg:  0 14px 44px rgba(26,61,26,.14);

	/* Typografia */
	--dz-font-head: 'Fraunces', 'Georgia', 'Times New Roman', serif;
	--dz-font-body: 'Jost', system-ui, -apple-system, 'Segoe UI', sans-serif;

	/* Promień */
	--dz-r-sm: 6px;
	--dz-r-md: 10px;
	--dz-r-lg: 16px;
	--dz-r-xl: 22px;
	--dz-r-full: 999px;

	/* Layout */
	--dz-max: 1200px;
	--dz-gap: clamp(1rem, 3vw, 2rem);
	--dz-pad: clamp(1.25rem, 5vw, 2.5rem);

	/* Przejścia */
	--dz-t: 0.22s cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	scroll-padding-top: 90px;
	overflow-x: clip;
	width: 100%;
}
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	* { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
body {
	margin: 0;
	font-family: var(--dz-font-body);
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--dz-text);
	background: var(--dz-cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: clip;
	/* żaden element nie może być szerszy niż viewport */
	max-width: 100vw;
	width: 100%;
	position: relative;
}
img, picture, svg, video { max-width: 100%; height: auto; display: block; }
/* Tabele poza wpisami (widgety, bloki WP) */
.widget table, .wp-block-table { display: block; overflow-x: auto; max-width: 100%; }
/* ── GLOBALNY GUARD: replaced/osadzenia/reklamy nie rozpychają strony ──
   AdSense, mapy, YouTube, twity itp. dostają stałe szerokości inline —
   to je przykrywa niezależnie od strony. */
iframe, embed, object,
ins.adsbygoogle, .adsbygoogle,
.wp-block-embed, .wp-block-embed__wrapper {
	max-width: 100% !important;
}
/* Sekcje strukturalne nigdy szersze niż ekran */
.dz-site-header, .dz-site-footer, .dz-main, main {
	max-width: 100vw;
	overflow-x: clip;
}
a { color: var(--dz-green-mid); text-decoration: none; transition: color var(--dz-t); }
a:hover { color: var(--dz-green-dark); }
button { font-family: inherit; cursor: pointer; }
ul, ol { margin: 0; padding: 0; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--dz-font-head);
	color: var(--dz-green-dark);
	line-height: 1.2;
	margin: 0 0 .5em;
	font-weight: 600;
	letter-spacing: -0.01em;
}

/* ---------- Utility ---------- */
.dz-sr-only, .dz-skip-link:not(:focus) {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.dz-main { display: block; }
.dz-section-inner { max-width: var(--dz-max); margin: 0 auto; padding: clamp(2.5rem,6vw,4.5rem) var(--dz-pad); }

/* ---------- Skip link ---------- */
.dz-skip-link {
	position: absolute; left: -9999px; top: 0; z-index: 999;
	padding: 1em 1.5em; background: var(--dz-green-dark); color: #fff;
	border-radius: 0 0 var(--dz-r-md) 0; font-weight: 600;
}
.dz-skip-link:focus { left: 0; }

/* ============================================================
   HEADER
   ============================================================ */
.dz-site-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(250,247,242,.9);
	border-bottom: 1px solid var(--dz-border);
}
/* Rozmycie tła tylko na desktopie — na mobile NIE, bo backdrop-filter tworzy
   układ odniesienia dla pozycji fixed i psułby wysuwane menu (szufladę). */
@media (min-width: 769px) {
	.dz-site-header {
		-webkit-backdrop-filter: saturate(180%) blur(12px);
		backdrop-filter: saturate(180%) blur(12px);
	}
}
.dz-header-inner {
	max-width: var(--dz-max); margin: 0 auto;
	padding: .8rem var(--dz-pad);
	display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
}

/* Logo */
.dz-logo { flex-shrink: 0; }
.dz-logo-link { display: flex; align-items: center; gap: .65rem; }
.dz-logo-leaf { color: var(--dz-green-light); display: flex; }
.dz-logo-leaf .dz-leaf { transform: rotate(-8deg); }
.dz-logo-text { font-family: var(--dz-font-head); font-weight: 700; font-size: 1.5rem; color: var(--dz-green-dark); line-height: 1; display: block; }
.dz-logo-tagline { display: block; font-family: var(--dz-font-body); font-size: .58rem; letter-spacing: .2em; text-transform: uppercase; color: var(--dz-green-light); margin-top: 3px; }
.custom-logo-link { display: inline-flex; align-items: center; }
.custom-logo { height: auto; width: auto; max-height: 54px; max-width: min(60vw, 220px); object-fit: contain; }

/* Nawigacja */
.dz-primary-nav { margin-left: auto; }
.dz-menu { display: flex; align-items: center; gap: .35rem; list-style: none; }
.dz-menu li { position: relative; }
.dz-menu a {
	display: block; padding: .55rem .9rem; border-radius: var(--dz-r-full);
	color: var(--dz-text-soft); font-weight: 500; font-size: .95rem;
	transition: all var(--dz-t);
}
.dz-menu a:hover, .dz-menu .current-menu-item > a, .dz-menu .current_page_item > a {
	color: var(--dz-green-dark); background: var(--dz-green-pale);
}
/* Dropdown */
.dz-menu .sub-menu {
	position: absolute; top: calc(100% + .4rem); left: 0; z-index: 50;
	min-width: 200px; padding: .5rem; list-style: none;
	background: var(--dz-white); border: 1px solid var(--dz-border);
	border-radius: var(--dz-r-md); box-shadow: var(--dz-shadow-md);
	opacity: 0; visibility: hidden; transform: translateY(6px);
	transition: all var(--dz-t);
}
.dz-menu li:hover > .sub-menu, .dz-menu li:focus-within > .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.dz-menu .sub-menu a { padding: .5rem .75rem; border-radius: var(--dz-r-sm); }
.dz-menu .menu-item-has-children > a::after {
	content: '▾'; margin-left: .35rem; font-size: .7em; opacity: .6;
}

/* Search toggle */
.dz-search-toggle {
	display: flex; align-items: center; justify-content: center;
	width: 42px; height: 42px; padding: 0;
	background: transparent; border: 1px solid var(--dz-border);
	border-radius: var(--dz-r-full); color: var(--dz-green-dark);
	transition: all var(--dz-t); flex-shrink: 0;
}
.dz-search-toggle:hover { background: var(--dz-green-pale); border-color: var(--dz-green-light); }

/* Search panel */
.dz-search-panel { border-top: 1px solid var(--dz-border); background: var(--dz-white); }
.dz-search-panel[hidden] { display: none; }
.dz-search-inner { max-width: var(--dz-max); margin: 0 auto; padding: 1rem var(--dz-pad); }

/* Hamburger */
.dz-menu-toggle {
	display: none; flex-direction: column; gap: 5px;
	width: 42px; height: 42px; padding: 9px;
	background: transparent; border: 1px solid var(--dz-border); border-radius: var(--dz-r-sm);
	order: 3;
}
.dz-menu-bar { display: block; height: 2px; width: 100%; background: var(--dz-green-dark); border-radius: 2px; transition: all var(--dz-t); }
.dz-menu-toggle[aria-expanded="true"] .dz-menu-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.dz-menu-toggle[aria-expanded="true"] .dz-menu-bar:nth-child(2) { opacity: 0; }
.dz-menu-toggle[aria-expanded="true"] .dz-menu-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   BUTTONS
   ============================================================ */
.dz-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
	padding: .8rem 1.5rem; border: 1px solid transparent; border-radius: var(--dz-r-full);
	font-family: var(--dz-font-body); font-weight: 600; font-size: .92rem;
	letter-spacing: .02em; text-align: center; line-height: 1;
	transition: all var(--dz-t); cursor: pointer;
}
.dz-btn--primary { background: var(--dz-green-dark); color: #fff; }
.dz-btn--primary:hover { background: var(--dz-green-mid); color: #fff; transform: translateY(-2px); box-shadow: var(--dz-shadow-md); }
.dz-btn--outline { background: transparent; color: var(--dz-green-dark); border-color: var(--dz-green-light); }
.dz-btn--outline:hover { background: var(--dz-green-dark); color: #fff; border-color: var(--dz-green-dark); }
.dz-btn--ghost { background: transparent; color: var(--dz-green-dark); border-color: var(--dz-border); }
.dz-btn--ghost:hover { background: var(--dz-green-pale); border-color: var(--dz-green-light); color: var(--dz-green-dark); }
.dz-btn .dz-leaf { width: 1.1em; height: 1.1em; }

/* ============================================================
   BADGE (kategorie)
   ============================================================ */
.dz-badge {
	display: inline-block; padding: .3rem .85rem;
	font-size: .68rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
	border-radius: var(--dz-r-full); color: #fff; background: var(--dz-green-light);
	transition: all var(--dz-t);
}
a.dz-badge:hover { color: #fff; transform: translateY(-1px); filter: brightness(1.08); }
/* Kolory wg slugów kategorii — dopasuj slugi do swoich kategorii */
.dz-badge--zdrowie, .dz-badge--choroby, .dz-badge--zdrowie-i-choroby { background: var(--dz-cat-zdrowie); }
.dz-badge--uroda, .dz-badge--kosmetyki, .dz-badge--kosmetyki-diy { background: var(--dz-cat-uroda); }
.dz-badge--ziola, .dz-badge--zioła { background: var(--dz-cat-ziola); }
.dz-badge--kuchnia, .dz-badge--przepisy, .dz-badge--kulinaria { background: var(--dz-cat-kuchnia); }

/* ============================================================
   GRID + CARDS
   ============================================================ */
.dz-grid { display: grid; gap: var(--dz-gap); }
.dz-grid--cards { grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr)); }

.dz-card {
	position: relative; background: var(--dz-white);
	border: 1px solid var(--dz-border); border-radius: var(--dz-r-lg);
	overflow: hidden; transition: transform var(--dz-t), box-shadow var(--dz-t), border-color var(--dz-t);
}
.dz-card:hover { transform: translateY(-5px); box-shadow: var(--dz-shadow-lg); border-color: var(--dz-gold-soft); }
.dz-card-link { display: flex; flex-direction: column; height: 100%; color: inherit; }
.dz-card-link:hover { color: inherit; }

.dz-card-media { position: relative; aspect-ratio: 3/2; overflow: hidden; background: var(--dz-green-mist); }
.dz-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s cubic-bezier(.4,0,.2,1); }
.dz-card:hover .dz-card-img { transform: scale(1.06); }
.dz-card-img--placeholder { display: flex; align-items: center; justify-content: center; color: var(--dz-green-light); opacity: .35; }

.dz-card-body { display: flex; flex-direction: column; flex: 1; gap: .65rem; padding: 1.25rem 1.35rem 1.4rem; }
.dz-card-body .dz-badge { align-self: flex-start; }
.dz-card-title {
	font-size: 1.18rem; line-height: 1.32; margin: 0;
	color: var(--dz-green-dark); transition: color var(--dz-t);
	display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.dz-card:hover .dz-card-title { color: var(--dz-green-mid); }
.dz-card-excerpt {
	margin: 0; font-size: .92rem; line-height: 1.6; color: var(--dz-text-soft);
	display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.dz-card-meta {
	margin-top: auto; padding-top: .5rem; display: flex; align-items: center; gap: .5rem;
	font-size: .8rem; color: var(--dz-text-muted);
}
.dz-card-dot { opacity: .5; }

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.dz-section-head { text-align: center; margin-bottom: clamp(2rem, 4vw, 3rem); }
.dz-section-deco { display: inline-flex; color: var(--dz-gold); margin-bottom: .5rem; }
.dz-section-deco .dz-leaf { transform: rotate(-6deg); }
.dz-section-title {
	font-size: clamp(1.8rem, 4vw, 2.6rem); margin: 0; position: relative; display: inline-block;
}
.dz-section-title::after {
	content: ''; display: block; width: 56px; height: 3px; margin: .65rem auto 0;
	background: linear-gradient(90deg, var(--dz-gold), var(--dz-gold-soft)); border-radius: 2px;
}

/* Archive head */
.dz-archive-head { text-align: center; margin-bottom: clamp(2rem,4vw,3rem); }
.dz-archive-title { font-size: clamp(1.9rem, 4.5vw, 2.8rem); margin: .5rem 0; }
.dz-archive-title span { color: var(--dz-gold); }
.dz-archive-desc { max-width: 640px; margin: 0 auto; color: var(--dz-text-soft); }

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.dz-breadcrumbs {
	display: flex; flex-wrap: wrap; align-items: center; gap: .45rem;
	font-size: .82rem; color: var(--dz-text-muted); margin-bottom: 1rem;
}
.dz-breadcrumbs a { color: var(--dz-green-light); }
.dz-breadcrumbs a:hover { color: var(--dz-green-dark); }
.dz-bc-sep { opacity: .5; }

/* ============================================================
   PAGINATION
   ============================================================ */
.dz-pagination { margin-top: clamp(2.5rem,5vw,3.5rem); }
.dz-pagination ul { display: flex; flex-wrap: wrap; justify-content: center; gap: .4rem; list-style: none; }
.dz-pagination a, .dz-pagination span {
	display: flex; align-items: center; justify-content: center;
	min-width: 44px; height: 44px; padding: 0 .85rem;
	border: 1px solid var(--dz-border); border-radius: var(--dz-r-full);
	background: var(--dz-white); color: var(--dz-text-soft); font-weight: 500;
	transition: all var(--dz-t);
}
.dz-pagination a:hover { border-color: var(--dz-green-light); background: var(--dz-green-pale); color: var(--dz-green-dark); }
.dz-pagination .current { background: var(--dz-green-dark); color: #fff; border-color: var(--dz-green-dark); }
.dz-pagination .dots { border: none; background: transparent; }

/* ============================================================
   FORMS (search)
   ============================================================ */
.dz-search-form { display: flex; gap: .5rem; max-width: 540px; margin: 0 auto; }
.dz-search-input {
	flex: 1; padding: .8rem 1.2rem; border: 1px solid var(--dz-border);
	border-radius: var(--dz-r-full); background: var(--dz-white);
	font-family: inherit; font-size: 1rem; color: var(--dz-text);
	transition: border-color var(--dz-t), box-shadow var(--dz-t);
}
.dz-search-input:focus { outline: none; border-color: var(--dz-green-light); box-shadow: 0 0 0 3px var(--dz-green-pale); }
.dz-search-submit {
	display: flex; align-items: center; justify-content: center;
	width: 48px; height: 48px; flex-shrink: 0;
	border: none; border-radius: var(--dz-r-full);
	background: var(--dz-green-dark); color: #fff; transition: background var(--dz-t);
}
.dz-search-submit:hover { background: var(--dz-green-mid); }

/* ============================================================
   EMPTY STATE + 404
   ============================================================ */
.dz-none, .dz-404 { text-align: center; max-width: 640px; margin: 0 auto; padding: 2rem 0; }
.dz-none-icon, .dz-404-leaf { display: inline-flex; color: var(--dz-green-light); opacity: .4; margin-bottom: 1rem; }
.dz-none-title { font-size: 1.8rem; }
.dz-none-text { color: var(--dz-text-soft); margin-bottom: 1.5rem; }
.dz-404-code { display: block; font-family: var(--dz-font-head); font-size: clamp(4rem,15vw,8rem); font-weight: 700; color: var(--dz-green-pale); line-height: 1; }
.dz-404-leaf { margin-top: -1.5rem; }
.dz-404-title { font-size: clamp(1.6rem,4vw,2.2rem); }
.dz-404-text { color: var(--dz-text-soft); margin-bottom: 1.5rem; }
.dz-404-search { margin-bottom: 1.5rem; }
.dz-404-recent { margin-top: 3.5rem; text-align: left; }
.dz-404-recent-title { text-align: center; font-size: 1.5rem; margin-bottom: 1.5rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.dz-site-footer { margin-top: clamp(3rem,7vw,5rem); background: var(--dz-green-dark); color: rgba(255,255,255,.82); }
.dz-footer-main { padding: clamp(2.5rem,5vw,4rem) 0 clamp(2rem,4vw,3rem); }
.dz-footer-inner {
	max-width: var(--dz-max); margin: 0 auto; padding: 0 var(--dz-pad);
	display: grid; gap: clamp(1.5rem,4vw,3rem);
	grid-template-columns: 1.4fr 1fr 1fr;
}
.dz-footer-logo { display: inline-flex; align-items: center; gap: .6rem; color: #fff; font-family: var(--dz-font-head); font-size: 1.4rem; font-weight: 700; margin-bottom: .85rem; }
.dz-footer-logo:hover { color: #fff; }
.dz-footer-logo .dz-leaf { color: var(--dz-gold-soft); }
.dz-footer-desc { font-size: .92rem; line-height: 1.7; color: rgba(255,255,255,.7); max-width: 36ch; }

.dz-footer-widget-title, .dz-footer-col h4 { color: #fff; font-size: 1rem; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 1rem; }
.dz-footer-col ul { list-style: none; }
.dz-footer-col li { margin-bottom: .55rem; }
.dz-footer-col a { color: rgba(255,255,255,.72); font-size: .92rem; }
.dz-footer-col a:hover { color: var(--dz-gold-soft); padding-left: 4px; }
.dz-footer-menu, .dz-footer-cats { list-style: none; }

/* Social */
.dz-social { display: flex; gap: .6rem; margin-top: 1.25rem; }
.dz-social-link {
	display: flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: var(--dz-r-full);
	background: rgba(255,255,255,.1); color: rgba(255,255,255,.85);
	transition: all var(--dz-t);
}
.dz-social-link:hover { background: var(--dz-gold); color: var(--dz-green-dark); transform: translateY(-3px); }

.dz-footer-bottom { border-top: 1px solid rgba(255,255,255,.12); }
.dz-footer-bottom-inner {
	max-width: var(--dz-max); margin: 0 auto; padding: 1.25rem var(--dz-pad);
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem;
}
.dz-copyright { font-size: .85rem; color: rgba(255,255,255,.6); margin: 0; }
.dz-footer-legal { display: flex; gap: 1.25rem; list-style: none; }
.dz-footer-legal a { font-size: .85rem; color: rgba(255,255,255,.6); }
.dz-footer-legal a:hover { color: var(--dz-gold-soft); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
	.dz-footer-inner { grid-template-columns: 1fr 1fr; }
	.dz-footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 768px) {
	.dz-menu-toggle { display: flex; }
	.custom-logo { max-height: 44px; max-width: min(58vw, 180px); }
	.dz-primary-nav {
		position: fixed; inset: 0 0 0 auto; z-index: 200;
		width: min(80vw, 320px); padding: 5rem 1.5rem 2rem;
		background: var(--dz-white); box-shadow: -10px 0 40px rgba(0,0,0,.15);
		transform: translateX(100%); transition: transform var(--dz-t);
		overflow-y: auto;
	}
	body.dz-nav-open .dz-primary-nav { transform: translateX(0); }
	body.dz-nav-open { overflow: hidden; }
	/* Gdy menu otwarte: nagłówek (a w nim szuflada) nad nakładką — inaczej nakładka
	   przykrywa menu, przyciemnia je i przechwytuje kliknięcia. */
	body.dz-nav-open .dz-site-header { z-index: 200; }
	.dz-menu { flex-direction: column; align-items: stretch; gap: .25rem; }
	.dz-menu a { padding: .8rem 1rem; border-radius: var(--dz-r-sm); }
	.dz-menu .sub-menu {
		position: static; opacity: 1; visibility: visible; transform: none;
		box-shadow: none; border: none; padding: 0 0 0 1rem; min-width: 0;
		background: transparent;
	}
	.dz-menu-toggle[aria-expanded="true"] { position: fixed; right: var(--dz-pad); top: 1rem; z-index: 201; }
	/* Overlay */
	body.dz-nav-open::after {
		content: ''; position: fixed; inset: 0; z-index: 150;
		background: rgba(0,0,0,.4); animation: dz-fade .2s;
	}
}
@keyframes dz-fade { from { opacity: 0; } to { opacity: 1; } }

@media (max-width: 480px) {
	.dz-grid--cards { grid-template-columns: 1fr; }
	.dz-footer-inner { grid-template-columns: 1fr; }
	.dz-footer-bottom-inner { flex-direction: column; text-align: center; }
}

/* Header po przewinięciu (klasa dodawana przez JS) */
.dz-site-header.dz-scrolled { box-shadow: var(--dz-shadow-sm); background: rgba(250,247,242,.96); }

/* ============================================================
   PASEK POSTĘPU CZYTANIA + PRZYCISK DO GÓRY
   ============================================================ */
.dz-reading-progress {
	position: fixed; top: 0; left: 0; right: 0; z-index: 101;
	height: 3px; background: transparent; pointer-events: none;
}
.dz-reading-progress span {
	display: block; height: 100%; width: 0;
	background: linear-gradient(90deg, var(--dz-green-light), var(--dz-gold));
	transition: width .1s linear;
}

.dz-to-top {
	position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 99;
	display: flex; align-items: center; justify-content: center;
	width: 46px; height: 46px; padding: 0;
	background: var(--dz-green-dark); color: #fff;
	border: none; border-radius: var(--dz-r-full);
	box-shadow: var(--dz-shadow-md);
	opacity: 0; visibility: hidden; transform: translateY(12px);
	transition: opacity var(--dz-t), transform var(--dz-t), visibility var(--dz-t), background var(--dz-t);
}
.dz-to-top:hover { background: var(--dz-green-mid); transform: translateY(-2px); }
.dz-to-top--show { opacity: 1; visibility: visible; transform: translateY(0); }
.dz-to-top--show:hover { transform: translateY(-2px); }
@media (max-width: 600px) { .dz-to-top { bottom: 1rem; right: 1rem; width: 42px; height: 42px; } }

/* ============================================================
   WIDGET: ARCHIWUM — akordeon lat (rozwijane miesiące)
   ============================================================ */
.dz-archive-acc { list-style: none; margin: 0; padding: 0; }
.dz-archive-year + .dz-archive-year { border-top: 1px solid var(--dz-border); }
.dz-archive-acc details > summary {
	display: flex; align-items: center; gap: .6rem;
	padding: .65rem .15rem; cursor: pointer; list-style: none;
	font-family: var(--dz-font-head); font-weight: 600; font-size: 1.02rem;
	color: var(--dz-green-dark);
}
.dz-archive-acc summary::-webkit-details-marker { display: none; }
.dz-archive-year-label { flex: 1; }
.dz-archive-count {
	font-size: .72rem; font-weight: 600; color: var(--dz-green-mid);
	background: var(--dz-green-pale); border-radius: var(--dz-r-full);
	padding: .12rem .6rem; min-width: 1.7rem; text-align: center;
}
.dz-archive-acc summary::after {
	content: '▾'; font-size: .8em; color: var(--dz-green-light);
	transition: transform var(--dz-t);
}
.dz-archive-acc details[open] > summary::after { transform: rotate(180deg); }
.dz-archive-acc summary:hover { color: var(--dz-green-mid); }
.dz-archive-months { list-style: none; margin: 0 0 .4rem; padding: 0 0 .3rem .15rem; }
.dz-archive-months li { margin: 0; }
.dz-archive-months a {
	display: flex; align-items: center; justify-content: space-between; gap: .5rem;
	padding: .38rem .5rem; font-size: .9rem; color: var(--dz-text-soft);
	border-radius: var(--dz-r-sm); border-left: 2px solid transparent;
	transition: all var(--dz-t);
}
.dz-archive-months a:hover {
	background: var(--dz-green-mist); color: var(--dz-green-dark);
	border-left-color: var(--dz-green-light); padding-left: .7rem;
}
.dz-archive-mcount { color: var(--dz-text-muted); font-size: .8rem; }
@media (prefers-reduced-motion: no-preference) {
	.dz-archive-acc details[open] .dz-archive-months { animation: dz-arch-in .25s ease both; }
}
@keyframes dz-arch-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
