/* =============================================================
   Služby Bystřice — main styles (mobile-first, WCAG 2.2 AA)
   For tokens see tokens.css. Order: font → reset → base → layout →
   components → sections → utilities.
   ============================================================= */

/* ——— FONT (self-hosted Inter variable, GDPR) ——— */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../fonts/Inter-latin-wght-normal.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../fonts/Inter-latin-ext-wght-normal.woff2") format("woff2");
  unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ——— RESET / NORMALIZE (lightweight) ——— */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
[hidden] { display: none !important; } /* respect the hidden attribute also on flex/grid components */
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-padding-top: var(--header-h-lg); }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
img { border: 0; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; }
ul, ol { padding-left: 1.25em; }
a { color: var(--color-link); text-decoration: underline; text-underline-offset: 0.15em; }
a:hover { color: var(--color-link-hover); }
table { border-collapse: collapse; }
:target { scroll-margin-top: var(--header-h-lg); }

/* ——— TYPOGRAPHY ——— */
h1, h2, h3, h4, h5, h6 { line-height: var(--lh-snug); letter-spacing: var(--ls-heading); font-weight: var(--fw-bold); color: var(--c-ink); text-wrap: balance; }
h1 { font-size: var(--fs-h1); line-height: var(--lh-tight); }
h2 { font-size: var(--fs-h2); line-height: 1.2; }
h3 { font-size: var(--fs-h3); font-weight: var(--fw-semibold); }
h4 { font-size: var(--fs-xl); font-weight: var(--fw-semibold); }
h5 { font-size: var(--fs-lg); font-weight: var(--fw-semibold); }
h6 { font-size: var(--fs-base); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--c-gray-700); }
p { line-height: var(--lh-normal); }
.lead { font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--c-gray-700); }
small, .small { font-size: var(--fs-sm); }
strong, b { font-weight: var(--fw-semibold); }
code, kbd, samp { font-family: var(--font-mono); font-size: 0.9em; }
.is-mono, .ico-dic { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* yellow "kicker" above the section heading */
.section-kicker { display: inline-block; font-size: var(--fs-sm); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--c-warning); margin-bottom: var(--sp-2); position: relative; padding-left: var(--sp-4); }
.section-kicker::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 12px; height: 12px; background: var(--c-yellow); }

/* ——— ACCESSIBILITY: skip-link, screen-reader-text ——— */
.screen-reader-text {
  border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
  height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; word-wrap: normal !important;
}
.skip-link {
  position: absolute; top: -100px; left: var(--sp-3); z-index: 1000;
  background: var(--c-yellow); color: var(--c-ink); font-weight: var(--fw-bold);
  padding: var(--sp-3) var(--sp-4); border-radius: var(--radius); text-decoration: none;
  box-shadow: var(--shadow-2);
}
.skip-link:focus { top: var(--sp-3); color: var(--c-ink); }

/* ——— FOCUS RING (unified, WCAG 2.4.11/2.4.13) ——— */
:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: 3px solid var(--color-focus); outline-offset: 2px; border-radius: var(--radius-sm);
}
.on-dark :focus-visible, .on-dark:focus-visible { outline-color: var(--c-yellow); }
:focus:not(:focus-visible) { outline: none; }

/* ——— LAYOUT ——— */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.container--narrow { max-width: var(--container-narrow); }
@media (min-width: 1024px) { .container { padding-inline: var(--gutter-lg); } }
.site-content { flex: 1 0 auto; }
.section { padding-block: var(--sp-8); }
@media (min-width: 1024px) { .section { padding-block: var(--sp-10); } }
.section--alt { background: var(--color-bg-alt); }
.section--ink { background: var(--c-blue-900); color: var(--c-white); }
.section--ink h1, .section--ink h2, .section--ink h3, .section--ink h4,
.on-dark h1, .on-dark h2, .on-dark h3, .on-dark h4 { color: var(--c-white); }
.section--ink a:not(.btn), .on-dark a:not(.btn) { color: var(--c-blue-100); }
.section--ink a:not(.btn):hover, .on-dark a:not(.btn):hover { color: var(--c-yellow); }
.section__head { margin-bottom: var(--sp-6); max-width: var(--container-narrow); }
.section__head--center { margin-inline: auto; text-align: center; }
.section__foot { margin-top: var(--sp-6); display: flex; justify-content: flex-end; }

.grid-tiles { display: grid; gap: var(--sp-5); grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.grid-services { display: grid; grid-template-columns: 1fr; gap: var(--sp-5); }
@media (min-width: 640px) { .grid-services { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-services { grid-template-columns: repeat(3, 1fr); } }
.grid-2 { display: grid; gap: var(--sp-6); grid-template-columns: 1fr; }
@media (min-width: 900px) { .grid-2 { grid-template-columns: 1fr 1fr; } }

/* ——— PAGE CONTENT / PROSE ——— */
.entry-content { max-width: 70ch; }
.entry-content > * + * { margin-top: var(--sp-4); }
.entry-content h2 { margin-top: var(--sp-7, 2.5rem); }
.entry-content h3 { margin-top: var(--sp-6); }
.entry-content ul, .entry-content ol { padding-left: 1.4em; }
.entry-content li + li { margin-top: var(--sp-2); }
.entry-content a { color: var(--color-link); font-weight: var(--fw-medium); }
.entry-content img { border-radius: var(--radius); margin-block: var(--sp-4); }
.entry-content blockquote { border-left: 4px solid var(--c-yellow); padding: var(--sp-2) var(--sp-5); color: var(--c-gray-700); background: var(--c-surface); border-radius: 0 var(--radius) var(--radius) 0; }
.entry-content figure { margin-block: var(--sp-5); }
.entry-content figcaption { font-size: var(--fs-sm); color: var(--c-gray-700); margin-top: var(--sp-2); }
.prose { max-width: var(--container-narrow); }

/* WP block alignment */
.alignleft { float: left; margin: 0 var(--sp-5) var(--sp-4) 0; }
.alignright { float: right; margin: 0 0 var(--sp-4) var(--sp-5); }
.aligncenter { display: block; margin-inline: auto; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: var(--fs-sm); color: var(--c-gray-700); }

/* ——— BUTTONS ——— */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 44px; padding: 0.75rem 1.5rem; border-radius: var(--radius);
  font-weight: var(--fw-semibold); font-size: var(--fs-base); text-decoration: none;
  border: 2px solid transparent; cursor: pointer; transition: transform var(--t-fast) var(--ease), background-color var(--t-fast), box-shadow var(--t-fast); line-height: 1.2;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn .icon { width: 1.25em; height: 1.25em; }
.btn--primary { background: var(--c-yellow); color: var(--c-ink); }
.btn--primary:hover { background: var(--c-yellow-deep); color: var(--c-ink); box-shadow: var(--shadow-2); }
.btn--blue { background: var(--c-blue-600); color: var(--c-white); }
.btn--blue:hover { background: var(--c-blue-700); color: var(--c-white); box-shadow: var(--shadow-2); }
.btn--outline { background: transparent; border-color: var(--c-blue-600); color: var(--c-blue-700); }
.btn--outline:hover { background: var(--c-blue-050); color: var(--c-blue-900); }
.btn--ghost { background: transparent; color: var(--c-blue-700); border-color: transparent; }
.btn--ghost:hover { background: var(--c-blue-050); text-decoration: underline; }
.btn[aria-disabled="true"], .btn:disabled { background: var(--c-gray-200); color: var(--c-gray-500); pointer-events: none; transform: none; box-shadow: none; }
.on-dark .btn--outline { border-color: var(--c-yellow); color: var(--c-yellow); }
.on-dark .btn--outline:hover { background: rgba(255,242,0,.12); color: var(--c-yellow); }

/* ——— SERVICE CARD ——— */
.card-service {
  display: flex; flex-direction: column; gap: var(--sp-3);
  background: var(--c-white); border: 1px solid var(--c-gray-200); border-radius: var(--radius);
  padding: var(--sp-5); box-shadow: var(--shadow-1) , inset 4px 0 0 var(--c-yellow);
  text-decoration: none; color: var(--c-ink); transition: transform var(--t-base) var(--ease), box-shadow var(--t-base);
  height: 100%;
}
.card-service:hover { transform: translateY(-2px); box-shadow: var(--shadow-2), inset 4px 0 0 var(--c-yellow); color: var(--c-ink); }
.card-service:focus-within { outline: 3px solid var(--color-focus); outline-offset: 2px; }
.card-service__icon { width: 48px; height: 48px; border-radius: var(--radius-pill); background: var(--c-blue-050); color: var(--c-blue-600); display: grid; place-items: center; transition: background-color var(--t-base), color var(--t-base); flex-shrink: 0; }
.card-service__icon .icon { width: 26px; height: 26px; }
.card-service:hover .card-service__icon { background: var(--c-blue-600); color: var(--c-white); }
.card-service h3 { font-size: var(--fs-lg); margin: 0; }
.card-service h3 a { color: inherit; text-decoration: none; }
.card-service h3 a::after { content: ""; position: absolute; inset: 0; }
.card-service { position: relative; }
.card-service__desc { color: var(--c-gray-700); font-size: var(--fs-base); margin: 0; }
.card-service__more { margin-top: auto; color: var(--c-blue-700); font-weight: var(--fw-semibold); display: inline-flex; align-items: center; gap: var(--sp-1); }

/* ——— NEWS CARD ——— */
.card-post { display: flex; flex-direction: column; background: var(--c-white); border: 1px solid var(--c-gray-200); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-1); transition: transform var(--t-base) var(--ease), box-shadow var(--t-base); height: 100%; position: relative; }
.card-post:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); }
.card-post:focus-within { outline: 3px solid var(--color-focus); outline-offset: 2px; }
.card-post__media { aspect-ratio: 16/9; background: var(--c-blue-050); overflow: hidden; display: grid; place-items: center; }
.card-post__media img { width: 100%; height: 100%; object-fit: cover; }
.card-post__media .icon { width: 48px; height: 48px; color: var(--c-blue-300); }
.card-post__body { padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2); flex: 1; }
.card-post__meta { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; font-size: var(--fs-sm); color: var(--c-gray-700); }
.pill { display: inline-flex; align-items: center; min-height: 24px; background: var(--c-yellow); color: var(--c-ink); font-size: var(--fs-xs); font-weight: var(--fw-semibold); padding: 2px 12px; border-radius: var(--radius-pill); text-decoration: none; }
a.pill { min-height: 24px; } /* WCAG 2.5.8 Target Size for interactive filter pills */
.pill:hover { background: var(--c-yellow-deep); color: var(--c-ink); }
.card-post h3 { font-size: var(--fs-lg); margin: 0; }
.card-post h3 a { color: var(--c-ink); text-decoration: none; }
.card-post h3 a::after { content: ""; position: absolute; inset: 0; }
.card-post__excerpt { color: var(--c-gray-700); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-post__more { margin-top: auto; color: var(--c-blue-700); font-weight: var(--fw-semibold); }

/* ——— BREADCRUMBS ——— */
.breadcrumbs { padding-block: var(--sp-3); font-size: var(--fs-sm); }
.breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; }
.breadcrumbs li { display: flex; align-items: center; gap: var(--sp-2); }
.breadcrumbs li + li::before { content: "/"; color: var(--c-gray-400); }
.breadcrumbs a { color: var(--c-blue-700); }
.breadcrumbs [aria-current="page"] { color: var(--c-gray-700); }

/* ——— TABLES ——— */
.table-wrap { overflow-x: auto; border-radius: var(--radius); }
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-base); }
.table caption { text-align: left; font-weight: 600; padding-block: var(--sp-2); }
.table th { background: var(--c-blue-700); color: #fff; text-align: left; padding: var(--sp-3) var(--sp-4); font-weight: 600; }
.table td { padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--c-gray-200); }
.table tbody tr:nth-child(even) { background: var(--c-blue-050); }
.table tbody tr:hover { background: var(--c-blue-100); }
.table .num { font-variant-numeric: tabular-nums; text-align: right; }

/* ——— ACCORDION (details/summary) ——— */
.accordion { border: 1px solid var(--c-gray-200); border-radius: var(--radius); overflow: hidden; }
.accordion + .accordion { margin-top: var(--sp-3); }
.accordion summary { list-style: none; cursor: pointer; padding: var(--sp-4) var(--sp-5); font-size: var(--fs-lg); font-weight: var(--fw-semibold); display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); background: var(--c-white); }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary .icon-chevron { transition: transform var(--t-base) var(--ease); flex-shrink: 0; }
.accordion[open] summary { background: var(--c-blue-050); }
.accordion[open] summary .icon-chevron { transform: rotate(180deg); }
.accordion__body { padding: var(--sp-4) var(--sp-5) var(--sp-5); }

/* YES/NO blocks (How to sort) */
.sort-yes, .sort-no { padding: var(--sp-3) var(--sp-4); border-radius: var(--radius); margin-top: var(--sp-3); }
.sort-yes { background: var(--c-success-bg); border-left: 4px solid var(--c-success); }
.sort-no { background: var(--c-danger-bg); border-left: 4px solid var(--c-danger); }
.sort-yes .label, .sort-no .label { font-weight: var(--fw-bold); display: inline-flex; align-items: center; gap: var(--sp-1); }
.sort-yes .label { color: var(--c-success); }
.sort-no .label { color: var(--c-danger); }

/* ——— ALERT ——— */
.alert { display: flex; gap: var(--sp-3); padding: var(--sp-4) var(--sp-5); border-radius: var(--radius); border-left: 4px solid; margin-block: var(--sp-4); }
.alert .icon { flex-shrink: 0; width: 24px; height: 24px; margin-top: 2px; }
.alert--info { background: var(--c-info-bg); border-left-color: var(--c-blue-700); color: var(--c-blue-900); }
.alert--warning { background: var(--c-warning-bg); border-left-color: var(--c-yellow-deep); color: var(--c-warning); }
.alert--success { background: var(--c-success-bg); border-left-color: var(--c-success); color: var(--c-success); }
.alert--error { background: var(--c-danger-bg); border-left-color: var(--c-danger); color: var(--c-danger); }
.alert__title { font-weight: var(--fw-bold); }

/* ——— DOCUMENT ITEM ——— */
.doc-list { display: grid; gap: var(--sp-3); }
.doc-item { display: flex; align-items: center; gap: var(--sp-4); padding: var(--sp-4); border: 1px solid var(--c-gray-200); border-left: 4px solid var(--c-yellow); border-radius: var(--radius); background: var(--c-white); transition: background-color var(--t-base); }
.doc-item:hover { background: var(--c-blue-050); }
.doc-item__icon { color: var(--c-danger); flex-shrink: 0; width: 36px; height: 36px; }
.doc-item__main { flex: 1; min-width: 0; }
.doc-item__title { font-weight: var(--fw-semibold); color: var(--c-blue-700); text-decoration: none; }
.doc-item__title:hover { text-decoration: underline; }
.doc-item__meta { font-size: var(--fs-sm); color: var(--c-gray-700); margin-top: 2px; }

/* ——— PAGINATION ——— */
.pagination { display: flex; flex-wrap: wrap; gap: var(--sp-2); justify-content: center; margin-top: var(--sp-8); }
.pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; min-height: 44px; padding: 0 var(--sp-3); border: 1px solid var(--c-gray-300); border-radius: var(--radius); text-decoration: none; color: var(--c-blue-700); font-weight: var(--fw-semibold); }
.pagination .page-numbers:hover { background: var(--c-blue-050); }
.pagination .page-numbers.current { background: var(--c-blue-700); color: #fff; border-color: var(--c-blue-700); }
.pagination .page-numbers.dots { border: 0; }

/* ——— HERO ——— */
.hero { position: relative; background: var(--c-blue-900); color: var(--c-white); overflow: hidden; }
.hero .container { position: relative; z-index: 2; padding-block: var(--sp-10) var(--sp-12); }
.hero__inner { max-width: 720px; }
.hero h1 { color: var(--c-white); }
.hero__subtitle { font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--c-blue-100); margin-top: var(--sp-4); }
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-6); }
.hero__deco { position: absolute; right: -40px; top: 50%; transform: translateY(-50%); width: 320px; max-width: 40vw; color: var(--c-yellow); opacity: .9; z-index: 1; pointer-events: none; }
.hero__edge { display: block; width: 100%; height: 28px; color: var(--c-blue-900); }
.hero__edge svg { display: block; width: 100%; height: 100%; }
/* optional hero image (side wedge as in page-hero); mobile = below the text */
.hero__media { margin: var(--sp-6) var(--gutter) 0; }
.hero__img { display: block; width: 100%; height: auto; border-radius: var(--radius-lg); }
@media (min-width: 768px) {
	.hero--has-image .hero__inner { max-width: 52%; }
	.hero__media { position: absolute; inset: 0 0 0 auto; width: 48%; margin: 0; z-index: 1;
		clip-path: polygon(20% 0, 100% 0, 100% 100%, 0% 100%); }
	.hero__img { width: 100%; height: 100%; object-fit: cover; border-radius: 0; }
	.hero--has-image .hero__edge { position: relative; z-index: 3; }
}
/* inner (page) hero — blue background, light text (consistent across the whole site) */
.page-hero { background: var(--c-blue-900); color: var(--c-white); padding-block: var(--sp-5) var(--sp-6); }
.page-hero h1 { color: var(--c-white); margin-top: var(--sp-2); }
.page-hero__subtitle { color: var(--c-blue-100); font-size: var(--fs-md); margin-top: var(--sp-3); max-width: 65ch; }
/* links (breadcrumbs etc.) and focus ring on a dark background; .pill keeps its own colors */
.page-hero a:not(.btn):not(.pill) { color: var(--c-blue-100); }
.page-hero a:not(.btn):not(.pill):hover { color: var(--c-yellow); }
.page-hero :focus-visible { outline-color: var(--c-yellow); }
/* article meta (date) and breadcrumbs readable on blue */
.page-hero .card-post__meta { color: var(--c-blue-100); }
.page-hero .breadcrumbs [aria-current="page"] { color: var(--c-white); }
.page-hero .breadcrumbs li + li::before { color: var(--c-blue-100); }

/* page-hero with a featured image — diagonal side wedge (colors inherited from .page-hero) */
.page-hero--split { position: relative; overflow: hidden; display: flex; flex-direction: column; }
.page-hero--split .container { position: relative; z-index: 2; order: 1; }
.page-hero__content { max-width: 60ch; }
/* mobile: reorder the image (first in the DOM) below the text and stretch it to full width */
.page-hero__media { order: 2; margin-top: var(--sp-5); }
.page-hero__img { display: block; width: 100%; height: auto; border-radius: var(--radius-lg); }
@media (min-width: 768px) {
	.page-hero--split { padding-block: var(--sp-6) var(--sp-7); }
	.page-hero--split .container { min-height: 280px; display: flex; flex-direction: column; justify-content: center; }
	.page-hero__content { max-width: 52%; }
	.page-hero__media { position: absolute; inset: 0 0 0 auto; width: 48%; margin: 0; z-index: 1;
		clip-path: polygon(20% 0, 100% 0, 100% 100%, 0% 100%); }
	.page-hero__img { width: 100%; height: 100%; object-fit: cover; border-radius: 0; }
}

/* ——— HEADER ——— */
.site-header { position: sticky; top: 0; z-index: 100; background: #fff; border-bottom: 1px solid var(--c-gray-200); }
.site-header.is-scrolled { box-shadow: var(--shadow-1); }
.site-header__bar { display: flex; align-items: center; justify-content: flex-start; gap: var(--sp-5); min-height: var(--header-h); }
.header-actions { margin-left: auto; }
@media (min-width: 1024px) { .site-header__bar { min-height: var(--header-h-lg); } }
.site-brand { display: inline-flex; align-items: center; gap: var(--sp-3); text-decoration: none; padding: var(--sp-2) 0; }
.site-brand img, .site-brand svg { height: 44px; width: auto; }
.site-brand__text { font-weight: var(--fw-bold); color: var(--c-ink); line-height: 1.1; display: none; }
@media (min-width: 480px) { .site-brand__text { display: block; } }

/* main navigation */
.main-nav { display: none; }
@media (min-width: 1024px) { .main-nav { display: block; } }
.main-nav > ul { display: flex; align-items: center; gap: var(--sp-1); list-style: none; margin: 0; padding: 0; }
.main-nav li { position: relative; }
.main-nav a, .main-nav .menu-link { display: inline-flex; align-items: center; gap: var(--sp-1); padding: var(--sp-3) var(--sp-3); color: var(--c-ink); text-decoration: none; font-weight: var(--fw-semibold); border-bottom: 3px solid transparent; }
.main-nav a:hover { color: var(--c-blue-700); border-bottom-color: var(--c-yellow); }
.main-nav .current-menu-item > a, .main-nav .current_page_item > a, .main-nav [aria-current="page"] { border-bottom-color: var(--c-yellow); color: var(--c-blue-700); }
/* dropdown */
.main-nav .sub-menu { position: absolute; top: 100%; left: 0; min-width: 240px; background: #fff; border: 1px solid var(--c-gray-200); border-radius: var(--radius); box-shadow: var(--shadow-2); list-style: none; margin: 0; padding: var(--sp-2); display: none; z-index: 101; }
.main-nav .menu-item-has-children:hover > .sub-menu, .main-nav .sub-menu.is-open { display: block; }
.main-nav .sub-menu a { display: block; padding: var(--sp-2) var(--sp-3); border-bottom: 0; border-radius: var(--radius-sm); font-weight: var(--fw-medium); }
.main-nav .sub-menu a:hover { background: var(--c-blue-050); }
.main-nav .submenu-toggle { background: none; border: 0; padding: var(--sp-1); color: inherit; display: inline-flex; }
.header-actions { display: flex; align-items: center; gap: var(--sp-1); }
.icon-btn { display: inline-grid; place-items: center; width: 44px; height: 44px; background: none; border: 0; border-radius: var(--radius); color: var(--c-ink); }
.icon-btn:hover { background: var(--c-blue-050); color: var(--c-blue-700); }

/* hamburger + off-canvas */
.nav-toggle { display: inline-grid; }
@media (min-width: 1024px) { .nav-toggle { display: none; } }
.mobile-nav { position: fixed; inset: 0 0 0 auto; width: min(86vw, 360px); background: #fff; box-shadow: var(--shadow-2); transform: translateX(100%); transition: transform var(--t-base) var(--ease); z-index: 200; padding: var(--sp-5); overflow-y: auto; }
.mobile-nav.is-open { transform: translateX(0); }
.mobile-nav__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-4); }
.mobile-nav ul { list-style: none; padding: 0; margin: 0; }
.mobile-nav li { border-bottom: 1px solid var(--c-gray-200); }
.mobile-nav a { display: block; padding: var(--sp-3) 0; color: var(--c-ink); text-decoration: none; font-weight: var(--fw-semibold); }
.mobile-nav .sub-menu { padding-left: var(--sp-4); }
.mobile-nav .sub-menu a { font-weight: var(--fw-regular); }
.nav-backdrop { position: fixed; inset: 0; background: rgba(22,34,74,.5); opacity: 0; visibility: hidden; transition: opacity var(--t-base); z-index: 150; }
.nav-backdrop.is-open { opacity: 1; visibility: visible; }
.header-search { padding: var(--sp-3) 0; border-top: 1px solid var(--c-gray-200); }
.header-search--inline { display: none; }
@media (min-width: 1024px) { .header-search--bar.is-open { display: block; } }

/* ——— FOOTER ——— */
.site-footer { background: var(--c-blue-900); color: var(--c-white); margin-top: auto; }
.site-footer__edge { display: block; width: 100%; height: 20px; color: var(--c-yellow); }
.site-footer__grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-6); padding-block: var(--sp-8); }
@media (min-width: 640px) { .site-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .site-footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.site-footer h2, .site-footer h3 { color: var(--c-white); font-size: var(--fs-lg); margin-bottom: var(--sp-3); }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-2); }
.site-footer a { color: var(--c-blue-100); text-decoration: none; }
.site-footer a:hover { color: var(--c-yellow); text-decoration: underline; }
.site-footer__brand img, .site-footer__brand svg { height: 64px; width: auto; margin-bottom: var(--sp-3); }
.site-footer__contact { display: grid; gap: var(--sp-1); color: var(--c-blue-100); font-size: var(--fs-sm); }
.site-footer__legal { border-top: 1px solid rgba(255,255,255,.15); padding-block: var(--sp-4); display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-4); align-items: center; justify-content: space-between; font-size: var(--fs-sm); }
.site-footer__legal ul { display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-4); }
.cookie-settings-btn { background: none; border: 1px solid var(--c-blue-300); color: var(--c-blue-100); padding: var(--sp-2) var(--sp-3); border-radius: var(--radius); min-height: 32px; }
.cookie-settings-btn:hover { border-color: var(--c-yellow); color: var(--c-yellow); }

/* ——— EMBED PLACEHOLDER (map/calendar without consent) ——— */
.embed-consent { background: var(--c-surface); border: 1px dashed var(--c-gray-400); border-radius: var(--radius); padding: var(--sp-6); text-align: center; }
.embed-consent p { color: var(--c-gray-700); margin-bottom: var(--sp-4); }
.embed-frame { position: relative; width: 100%; aspect-ratio: 16/10; border: 0; border-radius: var(--radius); overflow: hidden; }
.embed-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* ——— ICONS ——— */
.icon { display: inline-block; vertical-align: middle; width: var(--icon-size); height: var(--icon-size); fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.icon--solid { fill: currentColor; stroke: none; }
/* Klasický recyklační symbol (♻) je plný glyf, ne obrysová ikona. */
.icon-recycle-symbol { fill: currentColor; stroke: none; }

/* ——— COOKIE BAR ——— */
.cookie-bar { position: fixed; left: var(--sp-4); right: var(--sp-4); bottom: var(--sp-4); z-index: 300; background: #fff; color: var(--c-ink); border: 1px solid var(--c-gray-300); border-top: 4px solid var(--c-yellow); border-radius: var(--radius-lg); box-shadow: var(--shadow-2); padding: var(--sp-5); max-width: 560px; margin-inline: auto; }
.cookie-bar[hidden] { display: none; }
.cookie-bar__title { font-weight: var(--fw-bold); font-size: var(--fs-lg); margin-bottom: var(--sp-2); }
.cookie-bar__text { font-size: var(--fs-sm); color: var(--c-gray-700); margin-bottom: var(--sp-4); }
.cookie-bar__actions { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.cookie-bar__actions .btn { flex: 1 1 auto; }
.cookie-cats { display: grid; gap: var(--sp-2); margin: var(--sp-3) 0; }
.cookie-cat { display: flex; align-items: flex-start; gap: var(--sp-2); font-size: var(--fs-sm); }

/* ——— MISCELLANEOUS ——— */
.kontakt-grid { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
@media (min-width: 720px) { .kontakt-grid { grid-template-columns: 1fr 1fr; } }
.person-card { border: 1px solid var(--c-gray-200); border-radius: var(--radius); padding: var(--sp-4); border-left: 4px solid var(--c-yellow); }
.person-card .role { color: var(--c-gray-700); font-size: var(--fs-sm); }
.contact-strip { display: grid; gap: var(--sp-4); grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); }
.back-to-top { position: fixed; right: var(--sp-4); bottom: var(--sp-4); width: 48px; height: 48px; }

/* ——— MOTION (prefers-reduced-motion) ——— */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}

/* print */
@media print {
  .site-header, .site-footer, .cookie-bar, .breadcrumbs, .hero__deco, .nav-toggle { display: none !important; }
  body { color: #000; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 0.85em; }
}

/* =============================================================
   REDESIGN v2 — topbar, header, bolder homepage, more modern
   footer, cookie bar, fixes (icons, wp-block-file).
   ============================================================= */

/* ——— TOPBAR (above the header) ——— */
.topbar { background: var(--c-blue-900); color: var(--c-blue-100); font-size: var(--fs-sm); }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); min-height: 40px; flex-wrap: wrap; }
.topbar__status { display: inline-flex; align-items: center; gap: var(--sp-2); margin: 0; font-weight: var(--fw-medium); }
.topbar__status .topbar__icon { width: 16px; height: 16px; color: var(--c-blue-300); }
.topbar__dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; background: var(--c-gray-400); box-shadow: 0 0 0 3px rgba(255,255,255,.08); }
.topbar__status--open { color: #fff; }
.topbar__status--open .topbar__dot { background: #36d07f; box-shadow: 0 0 0 3px rgba(54,208,127,.25); }
.topbar__status--closed .topbar__dot { background: var(--c-yellow); box-shadow: 0 0 0 3px rgba(255,242,0,.18); }
.topbar__contacts { display: inline-flex; align-items: center; gap: var(--sp-5); }
.topbar__link { display: inline-flex; align-items: center; gap: var(--sp-2); color: var(--c-blue-100); text-decoration: none; font-weight: var(--fw-medium); }
.topbar__link:hover { color: var(--c-yellow); }
.topbar__link .topbar__icon { width: 15px; height: 15px; }
@media (max-width: 640px) {
  .topbar__inner { min-height: 36px; justify-content: center; }
  .topbar__contacts { display: none; }
}

/* ——— LOGO (B mark + text) ——— */
.site-brand { gap: var(--sp-3); }
.site-brand__mark { display: inline-flex; }
.site-brand__mark svg { height: 46px; width: auto; display: block; }
@media (min-width: 1024px) { .site-brand__mark svg { height: 52px; } }
.site-brand__name { display: inline-flex; flex-direction: column; line-height: 1; }
.site-brand__name strong { font-size: 1.35rem; font-weight: 800; letter-spacing: .02em; color: var(--c-blue-700); }
.site-brand__name > span { font-size: 1.05rem; font-weight: 500; color: var(--c-ink); letter-spacing: .01em; }
@media (min-width: 1024px) { .site-brand__name strong { font-size: 1.6rem; } .site-brand__name > span { font-size: 1.2rem; } }
.site-brand__name--mobile strong { font-size: 1.2rem; }

/* ——— INLINE SEARCH (desktop) ——— */
.header-search-inline { display: none; position: relative; align-items: center; }
@media (min-width: 1024px) { .header-search-inline { display: inline-flex; } }
.header-search-inline__icon { position: absolute; left: 12px; width: 18px; height: 18px; color: var(--c-gray-500); pointer-events: none; }
.header-search-inline input[type="search"] {
  width: 180px; min-height: 42px; padding: 0 var(--sp-3) 0 38px; border: 1.5px solid var(--c-gray-300);
  border-radius: var(--radius-pill); background: var(--c-surface); font-size: var(--fs-sm); transition: width var(--t-base) var(--ease), border-color var(--t-base), background var(--t-base);
}
.header-search-inline input[type="search"]:focus { width: 240px; background: #fff; border-color: var(--c-blue-500); outline: none; box-shadow: var(--shadow-focus); }
.mobile-search { display: flex; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.mobile-search input[type="search"] { flex: 1; min-height: 44px; padding: 0 var(--sp-3); border: 1.5px solid var(--c-gray-300); border-radius: var(--radius); }
.mobile-search .icon-btn { border: 1.5px solid var(--c-blue-600); color: var(--c-blue-700); border-radius: var(--radius); }

/* ——— SUBMENU TOGGLE (centered chevron) ——— */
.main-nav .menu-item-has-children { display: inline-flex; align-items: center; }
.main-nav .submenu-toggle { display: inline-flex; align-items: center; justify-content: center; align-self: center; min-width: 28px; min-height: 28px; padding: 0 2px; margin-left: -6px; color: var(--c-blue-600); }
.main-nav .submenu-toggle .icon-chevron { width: 18px; height: 18px; }
.main-nav .submenu-toggle[aria-expanded="true"] .icon-chevron { transform: rotate(180deg); }
.main-nav .submenu-toggle .icon-chevron { transition: transform var(--t-base) var(--ease); }

/* ——— BOLDER SERVICE TILES ——— */
.grid-services { gap: var(--sp-4); }
.card-service {
  box-shadow: var(--shadow-1);
  border: 1px solid var(--c-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--sp-6) var(--sp-5) var(--sp-5);
  overflow: hidden;
  isolation: isolate;
}
.card-service::before { /* jagged yellow accent (the "B" motif) in the corner */
  content: ""; position: absolute; top: 0; right: 0; width: 56px; height: 56px; z-index: -1;
  background: var(--c-yellow);
  clip-path: polygon(100% 0, 100% 100%, 0 0);
  transition: width var(--t-base) var(--ease), height var(--t-base) var(--ease);
}
.card-service:hover::before { width: 72px; height: 72px; }
.card-service__icon { width: 60px; height: 60px; border-radius: var(--radius); background: var(--c-blue-600); color: #fff; box-shadow: 0 6px 14px rgba(49,81,171,.28); }
.card-service__icon .icon { width: 30px; height: 30px; }
.card-service:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--c-blue-300); }
.card-service:hover .card-service__icon { background: var(--c-blue-900); }
.card-service h3 { font-size: var(--fs-xl); margin-top: var(--sp-1); }
.card-service h3 a { color: var(--c-ink); }
.card-service:hover h3 a { color: var(--c-blue-700); }
.card-service__more { color: var(--c-blue-700); font-weight: var(--fw-bold); }
.card-service__more .icon { transition: transform var(--t-base) var(--ease); }
.card-service:hover .card-service__more .icon { transform: translateX(4px); }

/* stronger "kicker" and section headers */
.section__head { margin-bottom: var(--sp-7, 2.5rem); }
.section-kicker { font-size: var(--fs-sm); padding-left: 0; display: inline-flex; align-items: center; gap: var(--sp-2); background: var(--c-blue-050); color: var(--c-blue-700); padding: 4px 12px 4px 10px; border-radius: var(--radius-pill); }
.section-kicker::before { position: static; transform: none; width: 10px; height: 10px; border-radius: 2px; background: var(--c-yellow); }
.section--ink .section-kicker { background: rgba(255,255,255,.1); color: var(--c-yellow); }
.section__head h2 { margin-top: var(--sp-3); font-size: var(--fs-3xl); }

/* ——— NEWS CARD v2 ——— */
.card-post { border-radius: var(--radius-lg); }
.card-post__media { background: linear-gradient(135deg, var(--c-blue-700), var(--c-blue-900)); }
.card-post__media .icon { color: rgba(255,255,255,.55); width: 56px; height: 56px; }

/* ——— ADDRESSES "Where to find us" (icon next to text) ——— */
.map-addresses { display: grid; gap: var(--sp-4); align-content: start; }
.person-card strong { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-1); }
.person-card strong .icon { width: 20px; height: 20px; color: var(--c-blue-600); flex-shrink: 0; }

/* ——— wp-block-file (hide the 600px object embed, nice download row) ——— */
.entry-content .wp-block-file { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap;
  border: 1px solid var(--c-gray-200); border-left: 4px solid var(--c-yellow); border-radius: var(--radius);
  background: var(--c-white); padding: var(--sp-4); margin-block: var(--sp-4); }
.entry-content .wp-block-file__embed { display: none !important; } /* hide the empty PDF object → no white gap */
.entry-content .wp-block-file > a:not(.wp-block-file__button) { font-weight: var(--fw-semibold); color: var(--c-blue-700); }
.entry-content .wp-block-file > a:not(.wp-block-file__button)::before { content: "📄"; margin-right: var(--sp-2); }
.entry-content .wp-block-file__button { margin-left: auto; background: var(--c-blue-600); color: #fff !important; text-decoration: none; padding: 0.6rem 1.1rem; border-radius: var(--radius); font-weight: var(--fw-semibold); min-height: 40px; display: inline-flex; align-items: center; }
.entry-content .wp-block-file__button:hover { background: var(--c-blue-700); }

/* direct embed (without the consent placeholder) */
.embed-frame { margin-top: var(--sp-2); box-shadow: var(--shadow-1); }

/* ——— MORE MODERN FOOTER ——— */
.site-footer { background: linear-gradient(180deg, var(--c-blue-900), #0f1838); }
.site-footer__grid { padding-block: var(--sp-10) var(--sp-8); gap: var(--sp-8) var(--sp-6); }
.site-footer h2, .site-footer h3 { font-size: var(--fs-md); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--c-yellow); position: relative; padding-bottom: var(--sp-2); margin-bottom: var(--sp-4); }
.site-footer h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 28px; height: 3px; background: var(--c-yellow); border-radius: 2px; }
.site-footer ul { gap: var(--sp-3); }
.site-footer a { transition: color var(--t-fast), padding-left var(--t-fast); }
.site-footer__col a:hover { padding-left: 4px; }
.site-footer__brand .site-footer__name { display: flex; flex-direction: column; line-height: 1; margin-bottom: var(--sp-3); }
.site-footer__contact { gap: var(--sp-2); line-height: 1.6; }
.site-footer__contact .is-mono { color: #fff; }
.site-footer__legal { border-top: 1px solid rgba(255,255,255,.12); padding-block: var(--sp-5); }
.site-footer__legal a, .site-footer__legal .cookie-settings-link { color: var(--c-blue-100); text-decoration: none; }
.site-footer__legal a:hover, .site-footer__legal .cookie-settings-link:hover { color: var(--c-yellow); text-decoration: underline; }
.cookie-settings-link { background: none; border: 0; padding: 0; font: inherit; cursor: pointer; }
.site-footer__copy { color: var(--c-blue-300); margin: 0; }

/* ——— COOKIE BAR v2 ——— */
.cookie-bar {
  left: var(--sp-5); right: var(--sp-5); bottom: var(--sp-5);
  max-width: 460px; margin-inline: 0; padding: var(--sp-6);
  border: 0; border-radius: var(--radius-lg);
  box-shadow: 0 12px 40px rgba(16,34,74,.28), 0 2px 8px rgba(16,34,74,.12);
  border-top: 5px solid var(--c-yellow);
}
@media (min-width: 560px) { .cookie-bar { left: var(--sp-6); right: auto; } }
.cookie-bar__title { font-size: var(--fs-lg); display: flex; align-items: center; gap: var(--sp-2); }
.cookie-bar__title::before { content: "🍪"; font-size: 1.4rem; }
.cookie-bar__actions { gap: var(--sp-3); flex-direction: column; }
@media (min-width: 420px) { .cookie-bar__actions { flex-direction: row; } }
.cookie-bar__actions .btn { flex: 1 1 auto; justify-content: center; }
.cookie-bar .cookie-link { background: none; border: 0; padding: 0; color: var(--c-blue-700); text-decoration: underline; cursor: pointer; font: inherit; }
.cookie-bar__settings-link { display: inline-block; margin-top: var(--sp-3); }

/* taller calendar embed (agenda) */
.embed-frame { aspect-ratio: 16/10; }
.embed-frame--calendar { aspect-ratio: auto; height: clamp(440px, 62vh, 640px); }

/* cookie bar — neutralize the inner .container + actions layout */
.cookie-bar > .container { max-width: none; padding: 0; margin: 0; width: auto; }
.cookie-bar__actions { flex-wrap: wrap; align-items: center; }
.cookie-bar__actions .btn[data-consent="accept"],
.cookie-bar__actions .btn[data-consent="reject"] { flex: 1 1 140px; }
.cookie-bar__actions .btn[data-consent="settings"],
.cookie-bar__actions .btn[data-consent="save"] { flex: 0 0 auto; }
.cookie-bar__link { margin-left: auto; align-self: center; color: var(--c-blue-700); font-size: var(--fs-sm); }
.cookie-cats { background: var(--c-surface); border-radius: var(--radius); padding: var(--sp-3) var(--sp-4); }
.cookie-cat label { display: flex; align-items: center; gap: var(--sp-2); font-weight: var(--fw-semibold); }
.cookie-cat .hint { margin: 2px 0 0 26px; }

/* ——— CONTACTS (clear layout) ——— */
.kontakt-info { display: grid; gap: var(--sp-6); align-content: start; }
.kontakt-aside { display: grid; gap: var(--sp-6); align-content: start; }
.contact-card { background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--sp-6); border-left: 4px solid var(--c-yellow); }
.contact-card h2 { font-size: var(--fs-xl); margin-bottom: var(--sp-1); }
.contact-card__org { font-weight: var(--fw-bold); font-size: var(--fs-md); color: var(--c-blue-700); margin-bottom: var(--sp-5); }
.contact-rows { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-4); }
.contact-rows > li { display: flex; align-items: flex-start; gap: var(--sp-3); }
.contact-rows .icon { width: 22px; height: 22px; color: var(--c-blue-600); flex-shrink: 0; margin-top: 3px; }
.contact-rows > li > span { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.contact-rows__label { font-size: var(--fs-xs); color: var(--c-gray-700); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--ls-caps); }
.contact-rows a { word-break: break-word; }
/* phone numbers flow inline (the label is a separate flex item); a single number never wraps */
.contact-rows__phones a { white-space: nowrap; word-break: normal; }
/* map as a separate card next to the contact details */
.kontakt-map { background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--sp-6); border-left: 4px solid var(--c-blue-600); }
.kontakt-map h2 { font-size: var(--fs-xl); margin-bottom: var(--sp-3); }
.kontakt-map .embed-frame { border-radius: var(--radius); overflow: hidden; }
.kontakt-map__address { display: flex; align-items: center; gap: var(--sp-2); font-weight: var(--fw-semibold); margin-bottom: var(--sp-3); }
.kontakt-map__address .icon { color: var(--c-blue-600); }
.kontakt-map__fallback { margin-top: var(--sp-3); font-size: var(--fs-sm); }
/* page content (contact people) at full width below the cards */
.kontakt-content { margin-top: var(--sp-8); max-width: none; }

/* ——— SERVICE PAGES: waste types, callout, calendar ——— */
.entry-content .svoz-types { display: grid; gap: var(--sp-4); grid-template-columns: 1fr; margin-block: var(--sp-5); }
@media (min-width: 600px) { .entry-content .svoz-types { grid-template-columns: 1fr 1fr; } }
.entry-content .svoz-type { background: #fff; border: 1px solid var(--c-gray-200); border-top: 4px solid var(--c-blue-600); border-radius: var(--radius-lg); padding: var(--sp-5); box-shadow: var(--shadow-1); }
.entry-content .svoz-type h3 { margin: 0 0 var(--sp-2); font-size: var(--fs-lg); }
.entry-content .svoz-type p { margin: 0; color: var(--c-gray-700); }
.entry-content .svoz-type--tridmeny { border-top-color: var(--c-success); }
.entry-content .svoz-type--komunal { border-top-color: var(--c-gray-700); }
.entry-content .info-callout { display: flex; gap: var(--sp-2); align-items: baseline; flex-wrap: wrap; background: var(--c-blue-050); border-left: 4px solid var(--c-blue-600); border-radius: var(--radius); padding: var(--sp-4) var(--sp-5); margin-block: var(--sp-5); }
.entry-content .cal-embed { margin-block: var(--sp-5); }
.entry-content .cal-embed .embed-frame { box-shadow: var(--shadow-1); border: 1px solid var(--c-gray-200); border-radius: var(--radius-lg); overflow: hidden; }
.entry-content .cal-embed__actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-4); }

/* ——— DOCUMENT LIBRARY v2 (groups + anchor navigation) ——— */
.doc-quicknav { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-8); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--c-gray-200); }
.doc-quicknav .pill { background: var(--c-blue-050); color: var(--c-blue-700); min-height: 32px; padding: 6px 14px; font-size: var(--fs-sm); border: 1px solid var(--c-blue-100); }
.doc-quicknav .pill:hover { background: var(--c-blue-600); color: #fff; border-color: var(--c-blue-600); }
.doc-group { margin-bottom: var(--sp-8); scroll-margin-top: calc(var(--header-h-lg) + 24px); }
.doc-group__head { display: flex; align-items: baseline; gap: var(--sp-3); flex-wrap: wrap; padding-bottom: var(--sp-3); margin-bottom: var(--sp-4); border-bottom: 3px solid var(--c-yellow); }
.doc-group__head h2 { font-size: var(--fs-xl); margin: 0; }
.doc-group__count { font-size: var(--fs-sm); color: var(--c-gray-700); background: var(--c-surface); padding: 2px 10px; border-radius: var(--radius-pill); }
.doc-group__desc { color: var(--c-gray-700); margin-bottom: var(--sp-4); }
/* doc-item: a slightly more prominent card */
.doc-item { box-shadow: var(--shadow-1); }
.doc-item:hover { box-shadow: var(--shadow-2); transform: translateY(-1px); transition: transform var(--t-fast), box-shadow var(--t-fast); }

/* ——— ARTICLE DETAIL (single) ——— */
.entry-thumbnail { margin: 0 0 var(--sp-6); }
.entry-thumbnail__img { width: 100%; height: auto; border-radius: var(--radius-lg); box-shadow: var(--shadow-1); }
.entry .entry-content { max-width: none; }
.entry-footer { margin-top: var(--sp-8); padding-top: var(--sp-5); border-top: 1px solid var(--c-gray-200); display: flex; flex-direction: column; gap: var(--sp-3); }
.entry-footer .cat-links,
.entry-footer .tags-links { display: flex; flex-wrap: wrap; align-items: baseline; gap: var(--sp-2); font-size: var(--fs-sm); color: var(--c-gray-700); font-weight: var(--fw-semibold); }
.entry-footer a { display: inline-flex; align-items: center; min-height: 28px; padding: 3px 12px; background: var(--c-blue-050); color: var(--c-blue-700); border: 1px solid var(--c-blue-100); border-radius: var(--radius-pill); font-size: var(--fs-sm); font-weight: var(--fw-medium); text-decoration: none; }
.entry-footer a:hover { background: var(--c-blue-600); color: #fff; border-color: var(--c-blue-600); }
.entry-back { margin-top: var(--sp-8); display: flex; justify-content: flex-end; }
@media (max-width: 480px) { .entry-back { justify-content: stretch; } .entry-back .btn { width: 100%; } }

/* ——— SEARCH FORM (results / 404 / widget) ——— */
.page-hero__search { margin-top: var(--sp-4); max-width: 560px; }
.search-form { display: flex; gap: var(--sp-2); align-items: stretch; width: 100%; max-width: 560px; }
.search-form__field { flex: 1 1 auto; min-width: 0; min-height: 48px; padding: 0 var(--sp-4); font-size: var(--fs-base); border: 2px solid var(--c-gray-300); border-radius: var(--radius); background: #fff; color: var(--c-ink); }
.search-form__field:focus-visible { border-color: var(--c-blue-500); outline: none; box-shadow: var(--shadow-focus); }
.search-form__submit { flex: 0 0 auto; min-height: 48px; }
.search-again { margin-top: var(--sp-6); max-width: 560px; }
/* readable both on the dark hero (just in case) and in the light page-hero */
.page-hero__search .search-form__field { background: #fff; }

/* ——— STANDARDIZED SECTION OF ATTACHED DOCUMENTS (end of page/post) ——— */
.related-docs { margin-top: var(--sp-8); padding-top: var(--sp-6); border-top: 3px solid var(--c-yellow); }
.related-docs > h2 { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-xl); margin: 0 0 var(--sp-4); }
.related-docs > h2 .icon { width: 24px; height: 24px; color: var(--c-blue-600); }
.related-docs .doc-list { display: grid; gap: var(--sp-3); }

/* ——— "nothing found" state + hint on search results ——— */
.content-none { padding: var(--sp-4) 0 var(--sp-6); }
.content-none__title { font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.content-none__text { color: var(--c-gray-700); font-size: var(--fs-md); max-width: 60ch; }
.content-none__actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-4); margin-top: var(--sp-5); }
.content-none__actions .search-form { flex: 1 1 320px; }
.search-suggest { margin-top: var(--sp-8); padding-top: var(--sp-6); border-top: 1px solid var(--c-gray-200); }
.search-suggest__title { font-size: var(--fs-xl); margin-bottom: var(--sp-5); }

/* CTA strip — spacing of the button from the heading */
.section__head--center > p { margin-top: var(--sp-5); margin-bottom: 0; }

/* ——— OPENING HOURS — seasonal cards (collection yard, at the top) ——— */
.hours-highlight .hours-cards { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
.hours-card { background: #fff; border: 1px solid var(--c-gray-200); border-top: 4px solid var(--c-blue-600); border-radius: var(--radius-lg); padding: 0 var(--sp-5) var(--sp-4); box-shadow: var(--shadow-1); }
.hours-card--summer { border-top-color: var(--c-yellow-deep); }
.hours-card--winter { border-top-color: var(--c-blue-300); }
.hours-card .table-wrap { overflow: visible; }
.hours-card .table { width: 100%; font-size: var(--fs-md); }
.hours-card .table caption { font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--c-ink); text-align: left; padding: var(--sp-4) 0 var(--sp-2); }
.hours-card .table thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); } /* header for screen readers only */
.hours-card .table tbody tr { background: transparent !important; }
.hours-card .table tbody tr:hover { background: var(--c-blue-050) !important; }
.hours-card .table th[scope="row"] { background: transparent; color: var(--c-ink); font-weight: var(--fw-semibold); padding: var(--sp-3) 0; text-align: left; }
.hours-card .table td { padding: var(--sp-3) 0; text-align: right; font-variant-numeric: tabular-nums; color: var(--c-gray-700); }
.hours-card .table td, .hours-card .table th { border-bottom: 1px solid var(--c-gray-200); }
.hours-card .table tbody tr:last-child td, .hours-card .table tbody tr:last-child th { border-bottom: 0; }
.hours-highlight__note { margin-top: var(--sp-4); font-size: var(--fs-sm); color: var(--c-gray-600); }

/* opening-hours block within the content (collection yard) */
.hours-highlight { background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--sp-5); margin-bottom: var(--sp-6); }
.hours-highlight__title { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-xl); margin: 0 0 var(--sp-4); }
.hours-highlight__title .icon { color: var(--c-blue-600); width: 26px; height: 26px; }

/* opening hours: don't wrap days + highlight the current one / dim the off-season one */
.hours-card { position: relative; padding-top: var(--sp-4); }
.hours-card .table caption { padding-top: var(--sp-2); }
.hours-card .table th[scope="row"] { white-space: nowrap; }
.hours-card .table td { white-space: normal; }
.hours-card__badge { display: inline-block; font-size: var(--fs-xs); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-caps); padding: 3px 10px; border-radius: var(--radius-pill); background: var(--c-success-bg); color: var(--c-success); }
.hours-card__badge--off { background: var(--c-gray-200); color: var(--c-gray-700); }
.hours-card.is-inactive { background: var(--c-gray-100); border-top-color: var(--c-gray-300); }
.hours-card.is-inactive .table caption { color: var(--c-gray-700); }
.hours-card.is-inactive .table th[scope="row"] { color: var(--c-gray-600); }
.hours-card.is-inactive .table td { color: var(--c-gray-500); }
.hours-card.is-current { border-top-color: var(--c-success); }

/* opening hours: don't wrap inside the range; the day may wrap only at the comma */
.hours-card .table th[scope="row"] { white-space: normal; }
.hours-range { white-space: nowrap; }
/* closed day in the schedule across all 7 days */
.hours-closed { color: var(--c-gray-500); font-style: italic; }
/* collapsed (inactive) season: only heading + chevron, expands on click (<details>) */
.hours-card--collapsible { padding-top: 0; }
.hours-card__summary { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); cursor: pointer; list-style: none; padding: var(--sp-4) 0 var(--sp-2); font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--c-ink); }
.hours-card__summary::-webkit-details-marker { display: none; }
.hours-card__summary::marker { content: ""; }
.hours-card__summary:hover { color: var(--c-blue-700); }
.hours-card__chevron { flex-shrink: 0; width: 22px; height: 22px; color: var(--c-gray-600); transition: transform var(--t-base); }
.hours-card--collapsible[open] .hours-card__chevron { transform: rotate(180deg); }
.hours-card--collapsible[open] .hours-card__summary { color: var(--c-blue-700); }

/* ── Waste sorting: "belongs / doesn't belong" mark (green check / red cross) ── */
.recyklace-znacka {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.6em;
	height: 1.6em;
	border-radius: 50%;
	font-size: 2.1em;
	font-weight: var(--fw-bold);
	line-height: 1;
	vertical-align: -0.35em;
}
.recyklace-znacka--ano { background: var(--c-success-bg); color: var(--c-success); }
.recyklace-znacka--ne  { background: var(--c-danger-bg);  color: var(--c-danger); }

/* Subtle section separator (Gutenberg separator with class "is-subtle") */
.wp-block-separator.is-subtle {
	border: 0;
	border-top: 1px solid var(--c-gray-200);
	max-width: none;
	margin-block: var(--sp-6);
	opacity: 1;
}
