/* =====================================================================
   ZAHRADA SEZÓNNÍ PRŮVODCE — moderní CSS (v1.0.0)
   
   Design jazyk:
   - Sage zelená paleta (sjednoceno s booking pluginem)
   - Glass efekty (backdrop-filter blur)
   - Container queries pro skutečnou responzivitu
   - Smooth transitions, accessible focus states
   - Tokenizovaná typografie (clamp pro plynulé škálování)
   ===================================================================== */

/* --------- DESIGN TOKENS (scopované na .zs-root) --------- */
.zs-root {
	/* Design tokens — mapováno na globální proměnné z bricks-variables.json (tvůj web) */
	/* Barvy — sage paleta z webu */
	--zs-accent:        var(--color-accent);
	--zs-accent-hover:  var(--color-accent-hover);
	--zs-accent-soft:   var(--color-accent-soft);
	--zs-accent-line:   var(--color-accent-border);
	--zs-text:          var(--color-text-primary);
	--zs-text-muted:    var(--color-text-secondary);
	--zs-text-subtle:   var(--color-text-secondary);
	--zs-bg:            var(--color-card);
	--zs-bg-soft:       var(--color-bg);
	--zs-border:        var(--color-border);
	--zs-border-strong: var(--color-border-strong);
	--zs-shadow-sm:     var(--shadow-xs);
	--zs-shadow-md:     var(--shadow-sm);
	--zs-shadow-lg:     var(--shadow-md);

	/* Sezónní akcenty (každý měsíc jiný hue) — zachováno pro vizuální rozlišení */
	--zs-spring:  hsl(105 35% 50%);
	--zs-summer:  hsl(45 80% 55%);
	--zs-autumn:  hsl(25 70% 50%);
	--zs-winter:  hsl(210 30% 55%);

	/* Typography — tvé fonty z webu (Geist + Fraunces) */
	--zs-font:          var(--font-family-body);
	--zs-font-display:  var(--font-family-serif);
	--zs-fs-xs:    var(--font-caption);
	--zs-fs-sm:    var(--font-body-sm);
	--zs-fs-base:  var(--font-body-sm);
	--zs-fs-md:    var(--font-body);
	--zs-fs-lg:    var(--font-body);
	--zs-fs-xl:    var(--font-h6);
	--zs-fs-2xl:   var(--font-h5);
	--zs-fs-3xl:   var(--font-h4);

	/* Spacing & radii — z tvého webu */
	--zs-radius-sm:  var(--radius-sm);
	--zs-radius-md:  var(--radius-md);
	--zs-radius-lg:  var(--radius-lg);
	--zs-radius-xl:  var(--radius-xl);
	--zs-gap:        var(--space-sm);
	
	/* Motion — z webu */
	--zs-ease:       cubic-bezier(0.16, 1, 0.3, 1);
	--zs-dur-fast:   160ms;
	--zs-dur-base:   320ms;
	--zs-dur-slow:   600ms;

	/* Container query scope — vnitřní bloky reagují na šířku rootu */
	container-type: inline-size;
	container-name: zsroot;

	/* Reset uvnitř */
	font-family: var(--zs-font);
	font-size: var(--zs-fs-base);
	line-height: 1.5;
	color: var(--zs-text);
	box-sizing: border-box;
}
.zs-root *,
.zs-root *::before,
.zs-root *::after { box-sizing: border-box; }

/* --------- LOADING STATE --------- */
.zs-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 80px 20px;
	color: var(--zs-text-muted);
	font-size: var(--zs-fs-sm);
}
.zs-spinner {
	width: 24px; height: 24px;
	border: 2.5px solid var(--zs-border);
	border-top-color: var(--zs-accent);
	border-radius: 50%;
	animation: zs-spin 800ms linear infinite;
}
@keyframes zs-spin {
	to { transform: rotate(360deg); }
}

/* --------- HEADER (nav tabs) --------- */
.zs-header {
	background: linear-gradient(180deg, var(--zs-accent-soft), transparent);
	border-radius: var(--zs-radius-xl) var(--zs-radius-xl) 0 0;
	padding: 28px 24px 0;
	border-bottom: 1px solid var(--zs-border);
}

.zs-title-block {
	max-width: 720px;
	margin: 0 auto 24px;
	text-align: center;
}
.zs-title {
	font-family: var(--zs-font-display);
	font-size: var(--zs-fs-3xl);
	font-weight: 600;
	letter-spacing: -0.02em;
	margin: 0 0 8px;
	color: var(--zs-text);
}
.zs-subtitle {
	font-size: var(--zs-fs-md);
	color: var(--zs-text-muted);
	margin: 0;
}

.zs-tabs {
	display: flex;
	gap: 4px;
	justify-content: center;
	overflow-x: auto;
	padding-bottom: 0;
	scrollbar-width: none;
}
.zs-tabs::-webkit-scrollbar { display: none; }

.zs-tab {
	background: transparent;
	border: none;
	padding: 14px 20px;
	font-family: var(--zs-font);
	font-size: var(--zs-fs-sm);
	font-weight: 500;
	color: var(--zs-text-muted);
	cursor: pointer;
	position: relative;
	white-space: nowrap;
	transition: color var(--zs-dur-fast) var(--zs-ease);
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.zs-tab:hover { color: var(--zs-text); }
.zs-tab.zs-tab--active {
	color: var(--zs-accent);
}
.zs-tab.zs-tab--active::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 12px; right: 12px;
	height: 2px;
	background: var(--zs-accent);
	border-radius: 2px 2px 0 0;
}
.zs-tab svg {
	width: 16px; height: 16px;
	flex-shrink: 0;
}

/* --------- MAIN CONTENT WRAPPER --------- */
.zs-app {
	background: var(--zs-bg);
	border: 1px solid var(--zs-border);
	border-radius: var(--zs-radius-xl);
	box-shadow: var(--zs-shadow-md);
	overflow: hidden;
	width: 100%;
	margin: 0 auto;
}

.zs-content {
	padding: 32px 24px;
}

/* --------- MONTH PICKER (kalendář prací) --------- */
.zs-month-picker {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 6px;
	margin-bottom: 28px;
	background: var(--zs-bg-soft);
	border-radius: var(--zs-radius-md);
	padding: 6px;
}
.zs-month-btn {
	background: transparent;
	border: none;
	padding: 10px 4px;
	border-radius: var(--zs-radius-sm);
	font-family: var(--zs-font);
	font-size: var(--zs-fs-xs);
	font-weight: 500;
	color: var(--zs-text-muted);
	cursor: pointer;
	transition: all var(--zs-dur-fast) var(--zs-ease);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.zs-month-btn:hover {
	background: var(--zs-bg);
	color: var(--zs-text);
}
.zs-month-btn.zs-month-btn--active {
	background: var(--zs-text);
	color: var(--zs-bg);
	box-shadow: var(--zs-shadow-sm);
}
.zs-month-btn.zs-month-btn--current {
	color: var(--zs-accent);
	font-weight: 600;
}
.zs-month-btn.zs-month-btn--current.zs-month-btn--active {
	color: var(--zs-bg);
}

/* --------- TASK SECTIONS --------- */
.zs-section {
	margin-bottom: 32px;
}
.zs-section:last-child { margin-bottom: 0; }

.zs-section-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--zs-border);
}
.zs-section-icon {
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--zs-accent-soft);
	color: var(--zs-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.zs-section-icon svg {
	width: 18px; height: 18px;
}
.zs-section-title {
	font-family: var(--zs-font-display);
	font-size: var(--zs-fs-xl);
	font-weight: 600;
	letter-spacing: -0.01em;
	margin: 0;
	flex: 1;
}
.zs-section-count {
	background: var(--zs-bg-soft);
	color: var(--zs-text-muted);
	font-size: var(--zs-fs-xs);
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 999px;
}

/* Task variants — sezónní barvy */
.zs-section[data-task="bloom"] .zs-section-icon {
	background: hsl(330 80% 95%); color: hsl(330 70% 50%);
}
.zs-section[data-task="prune"] .zs-section-icon {
	background: hsl(45 80% 92%); color: hsl(35 70% 45%);
}
.zs-section[data-task="fertilize"] .zs-section-icon {
	background: hsl(105 35% 90%); color: hsl(105 35% 35%);
}
.zs-section[data-task="plant"] .zs-section-icon {
	background: hsl(195 60% 92%); color: hsl(195 60% 40%);
}

/* --------- PLANT CHIPS (kalendář) --------- */
.zs-plant-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 8px;
}

.zs-plant-chip {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	background: var(--zs-bg);
	border: 1px solid var(--zs-border);
	border-radius: var(--zs-radius-sm);
	cursor: pointer;
	font-family: var(--zs-font);
	font-size: var(--zs-fs-sm);
	color: var(--zs-text);
	transition: all var(--zs-dur-fast) var(--zs-ease);
	text-align: left;
	width: 100%;
}
.zs-plant-chip:hover {
	border-color: var(--zs-accent);
	background: var(--zs-accent-soft);
	transform: translateY(-1px);
	box-shadow: var(--zs-shadow-sm);
}
.zs-plant-chip-name {
	font-weight: 500;
	flex: 1;
}
.zs-plant-chip-cat {
	font-size: var(--zs-fs-xs);
	color: var(--zs-text-subtle);
	text-transform: lowercase;
}

/* --------- PLANTS VIEW (browse) --------- */
.zs-toolbar {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--zs-border);
}

.zs-search {
	flex: 1;
	min-width: 200px;
	position: relative;
}
.zs-search-input {
	width: 100%;
	padding: 12px 14px 12px 42px;
	border: 1.5px solid var(--zs-border);
	border-radius: var(--zs-radius-sm);
	font-family: var(--zs-font);
	font-size: var(--zs-fs-base);
	background: var(--zs-bg);
	color: var(--zs-text);
	transition: border-color var(--zs-dur-fast) var(--zs-ease), box-shadow var(--zs-dur-fast) var(--zs-ease);
}
.zs-search-input:focus {
	outline: none;
	border-color: var(--zs-accent);
	box-shadow: 0 0 0 3px var(--zs-accent-soft);
}
.zs-search-icon {
	position: absolute;
	left: 14px; top: 50%;
	transform: translateY(-50%);
	width: 18px; height: 18px;
	color: var(--zs-text-subtle);
	pointer-events: none;
}

.zs-filter-chips {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.zs-chip {
	background: var(--zs-bg);
	border: 1.5px solid var(--zs-border);
	border-radius: 999px;
	padding: 8px 14px;
	font-family: var(--zs-font);
	font-size: var(--zs-fs-sm);
	font-weight: 500;
	color: var(--zs-text-muted);
	cursor: pointer;
	transition: all var(--zs-dur-fast) var(--zs-ease);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
}
.zs-chip:hover {
	border-color: var(--zs-accent);
	color: var(--zs-text);
}
.zs-chip.zs-chip--active {
	background: var(--zs-text);
	color: var(--zs-bg);
	border-color: var(--zs-text);
}
.zs-chip-count {
	background: hsl(0 0% 0% / 0.08);
	font-size: 11px;
	padding: 1px 6px;
	border-radius: 999px;
	font-weight: 600;
}
.zs-chip--active .zs-chip-count {
	background: hsl(0 0% 100% / 0.2);
}

/* --------- PLANT CARDS (browse view) --------- */
.zs-cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
}

.zs-card {
	background: var(--zs-bg);
	border: 1px solid var(--zs-border);
	border-radius: var(--zs-radius-md);
	padding: 18px;
	cursor: pointer;
	transition: all var(--zs-dur-base) var(--zs-ease);
	display: flex;
	flex-direction: column;
	gap: 10px;
	text-align: left;
	font-family: var(--zs-font);
	color: var(--zs-text);
	width: 100%;
}
.zs-card:hover {
	border-color: var(--zs-accent);
	transform: translateY(-2px);
	box-shadow: var(--zs-shadow-md);
}
.zs-card-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
}
.zs-card-name {
	font-family: var(--zs-font-display);
	font-size: var(--zs-fs-lg);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--zs-text);
	margin: 0;
}
.zs-card-latin {
	font-style: italic;
	font-size: var(--zs-fs-xs);
	color: var(--zs-text-subtle);
	margin: 2px 0 0;
}
.zs-card-cat {
	background: var(--zs-bg-soft);
	color: var(--zs-text-muted);
	font-size: 11px;
	font-weight: 500;
	padding: 4px 8px;
	border-radius: 6px;
	text-transform: lowercase;
	white-space: nowrap;
	flex-shrink: 0;
}
.zs-card-desc {
	font-size: var(--zs-fs-sm);
	color: var(--zs-text-muted);
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.zs-card-meta {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: auto;
	padding-top: 10px;
	border-top: 1px dashed var(--zs-border);
}
.zs-card-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: var(--zs-fs-xs);
	color: var(--zs-text-muted);
}
.zs-card-meta-item svg {
	width: 13px; height: 13px;
	color: var(--zs-accent);
}

/* Difficulty dots */
.zs-difficulty {
	display: inline-flex;
	gap: 2px;
	align-items: center;
}
.zs-difficulty-dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--zs-accent);
	opacity: 0.25;
}
.zs-difficulty-dot.zs-difficulty-dot--filled {
	opacity: 1;
}

/* --------- BLOOMING VIEW (galerie) --------- */
.zs-bloom-hero {
	text-align: center;
	padding: 24px 16px 32px;
	background: linear-gradient(180deg, var(--zs-accent-soft), transparent);
	border-radius: var(--zs-radius-md);
	margin-bottom: 24px;
}
.zs-bloom-month {
	font-family: var(--zs-font-display);
	font-size: var(--zs-fs-3xl);
	font-weight: 600;
	letter-spacing: -0.02em;
	margin: 0 0 4px;
	text-transform: capitalize;
}
.zs-bloom-meta {
	font-size: var(--zs-fs-sm);
	color: var(--zs-text-muted);
}

/* --------- DETAIL MODAL --------- */
/* Modal overlay — pevné pozadí, nezávislé na .zs-root scope (modal je appendnut na document.body) 
   POZN: použito :where pro nízkou specificitu jen vůči .zs-root, ALE vůči Bricks/theme má !important
   Modal je mimo .zs-root, takže nedědí design tokeny → používáme přímé hodnoty s !important */
body > .zs-modal-overlay {
	position: fixed !important;
	inset: 0 !important;
	background: hsl(0 0% 0% / 0.55) !important;
	backdrop-filter: blur(6px) !important;
	-webkit-backdrop-filter: blur(6px) !important;
	z-index: 999999 !important;
	opacity: 0;
	visibility: hidden;
	transition: opacity 220ms cubic-bezier(0.4, 0, 0.2, 1), visibility 220ms cubic-bezier(0.4, 0, 0.2, 1);
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 16px !important;
	overflow-y: auto !important;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	color: hsl(0 0% 4%);
	box-sizing: border-box;
}
body > .zs-modal-overlay *,
body > .zs-modal-overlay *::before,
body > .zs-modal-overlay *::after { box-sizing: border-box; }

body > .zs-modal-overlay.zs-modal-overlay--open {
	opacity: 1 !important;
	visibility: visible !important;
}

body > .zs-modal-overlay .zs-modal {
	background: hsl(0 0% 100%) !important;
	border-radius: 20px !important;
	max-width: 700px !important;
	width: 100% !important;
	max-height: 90vh !important;
	overflow-y: auto !important;
	box-shadow: 0 8px 32px hsl(0 0% 0% / 0.18) !important;
	transform: translateY(20px) scale(0.97);
	transition: transform 220ms cubic-bezier(0.4, 0, 0.2, 1);
	margin: auto !important;
	border: 1px solid hsl(240 7% 91%) !important;
}
body > .zs-modal-overlay--open .zs-modal {
	transform: translateY(0) scale(1);
}

body > .zs-modal-overlay .zs-modal-header {
	padding: 24px 24px 16px !important;
	border-bottom: 1px solid hsl(240 7% 91%) !important;
	position: sticky !important;
	top: 0 !important;
	background: hsl(0 0% 100%) !important;
	border-radius: 20px 20px 0 0 !important;
	z-index: 1 !important;
}
body > .zs-modal-overlay .zs-modal-close {
	position: absolute !important;
	top: 16px !important; right: 16px !important;
	width: 36px !important; height: 36px !important;
	border: 1px solid hsl(240 7% 91%) !important;
	border-radius: 50% !important;
	background: hsl(0 0% 100%) !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: hsl(220 9% 46%) !important;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1) !important;
	padding: 0 !important;
}
body > .zs-modal-overlay .zs-modal-close:hover {
	color: hsl(0 0% 4%) !important;
	border-color: hsl(0 0% 4%) !important;
}
body > .zs-modal-overlay .zs-modal-close svg { width: 16px !important; height: 16px !important; }

body > .zs-modal-overlay .zs-modal-title {
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: clamp(22px, 4vw, 28px) !important;
	font-weight: 600 !important;
	letter-spacing: -0.02em !important;
	margin: 0 60px 4px 0 !important;
	color: hsl(0 0% 4%) !important;
	line-height: 1.2 !important;
}
body > .zs-modal-overlay .zs-modal-latin {
	font-style: italic !important;
	color: hsl(220 9% 46%) !important;
	font-size: 15px !important;
	margin: 0 !important;
}

body > .zs-modal-overlay .zs-modal-body {
	padding: 24px !important;
	background: hsl(0 0% 100%) !important;
	border-radius: 0 0 20px 20px;
}

body > .zs-modal-overlay .zs-modal-section {
	margin-bottom: 24px !important;
}
body > .zs-modal-overlay .zs-modal-section:last-child { margin-bottom: 0 !important; }

body > .zs-modal-overlay .zs-modal-section-title {
	font-size: 13px !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	color: hsl(220 9% 46%) !important;
	margin: 0 0 12px !important;
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
}
body > .zs-modal-overlay .zs-modal-section-title svg {
	width: 14px !important; height: 14px !important;
	color: hsl(145 22% 38%) !important;
	stroke: hsl(145 22% 38%) !important;
}

body > .zs-modal-overlay .zs-modal-desc {
	font-size: 15px !important;
	line-height: 1.6 !important;
	color: hsl(0 0% 4%) !important;
	margin: 0 !important;
}

body > .zs-modal-overlay .zs-modal-meta-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
	gap: 12px !important;
	background: hsl(240 7% 97%) !important;
	border-radius: 8px !important;
	padding: 16px !important;
}
body > .zs-modal-overlay .zs-meta-cell {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px !important;
}
body > .zs-modal-overlay .zs-meta-label {
	font-size: 12px !important;
	color: hsl(220 9% 46%) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
}
body > .zs-modal-overlay .zs-meta-value {
	font-size: 14px !important;
	font-weight: 500 !important;
	color: hsl(0 0% 4%) !important;
	display: flex !important;
	align-items: center !important;
	gap: 6px !important;
}
body > .zs-modal-overlay .zs-meta-value svg {
	width: 14px !important; height: 14px !important;
	color: hsl(145 22% 38%) !important;
	stroke: hsl(145 22% 38%) !important;
}

body > .zs-modal-overlay .zs-tip-list,
body > .zs-modal-overlay .zs-problem-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
}
body > .zs-modal-overlay .zs-tip-list li,
body > .zs-modal-overlay .zs-problem-list li {
	display: flex !important;
	align-items: flex-start !important;
	gap: 10px !important;
	padding: 10px 12px !important;
	background: hsl(240 7% 97%) !important;
	border-radius: 8px !important;
	font-size: 13px !important;
	line-height: 1.5 !important;
	color: hsl(0 0% 4%) !important;
}
body > .zs-modal-overlay .zs-tip-list li::before,
body > .zs-modal-overlay .zs-problem-list li::before {
	content: '' !important;
	width: 6px !important; height: 6px !important;
	border-radius: 50% !important;
	background: hsl(145 22% 38%) !important;
	margin-top: 7px !important;
	flex-shrink: 0 !important;
}
body > .zs-modal-overlay .zs-problem-list li::before {
	background: hsl(15 70% 55%) !important;
}

body > .zs-modal-overlay .zs-year-ring {
	display: grid !important;
	grid-template-columns: repeat(12, 1fr) !important;
	gap: 4px !important;
	margin-top: 8px !important;
}
body > .zs-modal-overlay .zs-year-cell {
	aspect-ratio: 1 !important;
	background: hsl(240 7% 97%) !important;
	border-radius: 6px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	color: hsl(220 9% 64%) !important;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1) !important;
}
body > .zs-modal-overlay .zs-year-cell.zs-year-cell--bloom {
	background: hsl(145 22% 38%) !important;
	color: hsl(0 0% 100%) !important;
}
body > .zs-modal-overlay .zs-year-cell.zs-year-cell--current {
	box-shadow: 0 0 0 2px hsl(0 0% 4%) !important;
}

/* Mobile responsive — modal full screen na úzkých zařízeních */
@media (max-width: 480px) {
	body > .zs-modal-overlay { padding: 0 !important; }
	body > .zs-modal-overlay .zs-modal {
		max-height: 100vh !important;
		border-radius: 0 !important;
	}
	body > .zs-modal-overlay .zs-modal-header { border-radius: 0 !important; }
}

/* --------- EMPTY STATE --------- */
.zs-empty {
	text-align: center;
	padding: 48px 24px;
	color: var(--zs-text-muted);
}
.zs-empty-icon {
	width: 56px; height: 56px;
	margin: 0 auto 16px;
	color: var(--zs-text-subtle);
}
.zs-empty-title {
	font-size: var(--zs-fs-lg);
	font-weight: 600;
	color: var(--zs-text);
	margin: 0 0 4px;
}
.zs-empty-desc {
	font-size: var(--zs-fs-sm);
	margin: 0;
}

/* =====================================================================
   RESPONZIVITA — container queries (reagují na šířku zsroot)
   ===================================================================== */

@container zsroot (max-width: 720px) {
	.zs-header { padding: 24px 16px 0; }
	.zs-content { padding: 24px 16px; }
	.zs-month-picker { grid-template-columns: repeat(4, 1fr); }
}

@container zsroot (max-width: 540px) {
	.zs-header { padding: 20px 14px 0; }
	.zs-content { padding: 20px 14px; }
	.zs-cards { grid-template-columns: 1fr; }
	.zs-plant-grid { grid-template-columns: 1fr; }
	.zs-month-picker { grid-template-columns: repeat(3, 1fr); }
	.zs-toolbar { flex-direction: column; align-items: stretch; }
	.zs-search { width: 100%; }
}

@container zsroot (max-width: 380px) {
	.zs-month-picker { grid-template-columns: repeat(2, 1fr); }
	.zs-modal-meta-grid { grid-template-columns: 1fr 1fr; }
}

/* Viewport @media fallback (staré prohlížeče) */
@media (max-width: 720px) {
	.zs-cards { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
}
@media (max-width: 480px) {
	.zs-cards { grid-template-columns: 1fr; }
	.zs-plant-grid { grid-template-columns: 1fr; }
	/* Modal mobile rules: viz body > .zs-modal-overlay výše */
}

/* --------- ACCESSIBILITY --------- */
.zs-root :focus-visible {
	outline: 2px solid var(--zs-accent);
	outline-offset: 2px;
	border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
	.zs-root *,
	.zs-root *::before,
	.zs-root *::after {
		transition-duration: 0.01ms !important;
		animation-duration: 0.01ms !important;
	}
}

/* --------- PRINT --------- */
@media print {
	.zs-tabs, .zs-toolbar, .zs-modal-overlay { display: none !important; }
	.zs-app { box-shadow: none !important; border: none !important; }
}

/* --------- A11y: screen-reader-only utility --------- */
.zs-root .zs-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* --------- A11y: focus-visible — používá tvůj --color-focus --------- */
.zs-root *:focus-visible {
	outline: 2px solid var(--color-focus);
	outline-offset: 2px;
	border-radius: var(--radius-xs);
}

/* --------- A11y: tap target min 48px na všech buttonech a inputech --------- */
.zs-root button,
.zs-root [role="button"],
.zs-root [role="tab"],
.zs-root .zs-search-input {
	min-height: var(--tap-target-min);
}

