/*
 * BTNZ theme.css
 *
 * Většina stylů jde přes theme.json (paleta, fonty, font-face deklarace,
 * font-size, spacing, link/button presets). Tady jen to, co theme.json
 * neumí elegantně: layout helpery pro custom bloky, base reset výjimky,
 * uppercase tagy a pár hover states.
 *
 * Block-specific styly žijou v theme/blocks/<slug>/style.css.
 */

/* ── base reset ────────────────────────────────────────────────────────── */

*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	min-height: 100vh;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

a { text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── brand defaults ────────────────────────────────────────────────────── */

/* Ostré rohy všude (per logomanuál). Tři výjimky: logo (SVG kruh),
 * AskRabbit chat button (kruh — řešeno v blocks/askrabbit), AskRabbit
 * tooltip (8px — taky tam). Pokud někde uvidíš border-radius v admin
 * Gutenbergu, vrať na 0 — WP defaults to 0 už neumí.
 */

:root {
	--btnz-container: 1100px;
	--btnz-container-wide: 1400px;
}

.btnz-container {
	max-width: var(--btnz-container);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2rem);
}

.btnz-container--wide {
	max-width: var(--btnz-container-wide);
}

/* ── header / footer scaffolding ───────────────────────────────────────── */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--wp--preset--color--w);
	border-bottom: 1px solid var(--wp--preset--color--cr);
}

.site-footer {
	background: var(--wp--preset--color--br);
	color: var(--wp--preset--color--w);
	padding-block: clamp(3rem, 6vw, 5rem);
}

.site-footer a { color: var(--wp--preset--color--cr); }
.site-footer a:hover { color: var(--wp--preset--color--y); }

/* ── nav ──────────────────────────────────────────────────────────────── */

.site-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-block: 1rem;
}

.site-nav__logo svg { width: 56px; height: 56px; }

.site-nav__links {
	display: flex;
	gap: clamp(0.75rem, 2vw, 2rem);
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav__links a {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 0.95rem;
	letter-spacing: 0.03em;
}

.site-nav__links a.active { color: var(--wp--preset--color--orange); }

.site-nav__hamburger {
	display: none;
	background: none;
	border: 0;
	width: 44px;
	height: 44px;
	cursor: pointer;
	padding: 0;
}

.site-nav__hamburger span,
.site-nav__hamburger span::before,
.site-nav__hamburger span::after {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--wp--preset--color--br);
	transition: transform 0.2s, opacity 0.2s;
}

.site-nav__hamburger span { margin-inline: auto; position: relative; }
.site-nav__hamburger span::before { content: ''; position: absolute; top: -8px; left: 0; }
.site-nav__hamburger span::after  { content: ''; position: absolute; top:  8px; left: 0; }

.site-nav__hamburger.open span { background: transparent; }
.site-nav__hamburger.open span::before { transform: translateY(8px) rotate(45deg); }
.site-nav__hamburger.open span::after  { transform: translateY(-8px) rotate(-45deg); }

@media (max-width: 880px) {
	.site-nav__links { display: none; }
	.site-nav__hamburger { display: block; }
}

.mobile-menu {
	display: none;
	position: fixed;
	inset: 64px 0 0 0;
	background: var(--wp--preset--color--cr);
	padding: 2rem;
	z-index: 90;
}

.mobile-menu.open { display: block; }

.mobile-menu ul { list-style: none; padding: 0; margin: 0; }
.mobile-menu li { margin-block: 1.25rem; }
.mobile-menu a {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 1.5rem;
}

body.menu-open { overflow: hidden; }

/* ── skip link ────────────────────────────────────────────────────────── */

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 200;
	background: var(--wp--preset--color--br);
	color: var(--wp--preset--color--w);
	padding: 0.75rem 1rem;
}

.skip-link:focus { left: 1rem; top: 1rem; }

/* ── site footer ───────────────────────────────────────────────────────── */

.site-footer__inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: clamp(1.5rem, 3vw, 3rem);
	align-items: start;
}

@media (min-width: 880px) {
	.site-footer__inner { grid-template-columns: 1.5fr 1fr 1fr 1fr; }
}

.site-footer__col h4 {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 1rem;
	margin: 0 0 1rem;
	color: var(--wp--preset--color--w);
}

.site-footer__brand svg { width: 56px; height: 56px; margin-bottom: 0.75rem; }
.site-footer__intro {
	margin: 0 0 1rem;
	font-size: 0.875rem;
	line-height: 1.6;
	opacity: 0.85;
}
.site-footer__contact {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.7;
}
.site-footer__contact strong {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-weight: 400;
	margin-right: 0.25rem;
}

.site-footer__links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 0.5rem;
}
.site-footer__links a {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 0.875rem;
}

.site-footer__legal {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.6;
	opacity: 0.85;
}

.site-footer__social {
	display: flex;
	gap: 0.5rem;
}
.site-footer__social a {
	display: inline-flex;
	width: 36px;
	height: 36px;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 248, 231, 0.2);
	color: var(--wp--preset--color--cr);
}
.site-footer__social a:hover { color: var(--wp--preset--color--y); border-color: var(--wp--preset--color--y); }

.site-footer__bottom {
	margin-top: clamp(2rem, 4vw, 3rem);
	padding-top: 1.25rem;
	border-top: 1px solid rgba(224, 208, 166, 0.15);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0.75rem;
	font-size: 0.85rem;
	opacity: 0.75;
}
.site-footer__bottom-links {
	display: flex;
	gap: 1rem;
}

/* ── screen-reader only ───────────────────────────────────────────────── */

/* ── misto group (kde koupit) ─────────────────────────────────────────── */

.btnz-misto-group { padding-block: clamp(2rem, 4vw, 3.5rem); }
.btnz-misto-group:nth-child(even) { background: var(--wp--preset--color--cr); }

.btnz-misto-group__title {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: var(--wp--preset--font-size--h3);
	margin: 0 0 1.5rem;
}

.btnz-misto-group__items {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}

.btnz-misto {
	padding: 1rem 1.25rem;
	background: var(--wp--preset--color--w);
	border: 1px solid var(--wp--preset--color--cr);
	font-size: 0.95rem;
	line-height: 1.5;
}
.btnz-misto a { color: inherit; }
.btnz-misto-adresa, .btnz-misto-datum { font-size: 0.85rem; opacity: 0.7; }

/* ── produkt detail ───────────────────────────────────────────────────── */

.btnz-produkt { padding-block: clamp(3rem, 6vw, 5rem); color: var(--wp--preset--color--w); }
.btnz-produkt__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.btnz-produkt__title {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: clamp(2.375rem, 5vw, 3.75rem);
	line-height: 1.1;
	margin: 0.5rem 0 1.5rem;
}
.btnz-produkt__desc { font-size: var(--wp--preset--font-size--lg); line-height: 1.55; margin-bottom: 1rem; }
.btnz-produkt__sizes {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	margin-bottom: 1.5rem;
}
.btnz-produkt__visual img { display: block; max-width: 100%; height: auto; }

.btnz-produkt-meta { padding-block: clamp(2rem, 4vw, 3rem); }
.btnz-produkt-meta__inner { max-width: 720px; }
.btnz-produkt-meta__accordion {
	border-top: 1px solid var(--wp--preset--color--cr);
	padding-block: 1rem;
}
.btnz-produkt-meta__accordion summary {
	cursor: pointer;
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
}
.btnz-produkt-meta__body { padding-block: 0.75rem; line-height: 1.6; }
.btnz-produkt-meta__badge {
	margin-top: 1rem;
	padding: 0.5rem 1rem;
	background: var(--wp--preset--color--cr);
	display: inline-block;
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 0.85rem;
}

@media (max-width: 720px) {
	.btnz-produkt__inner { grid-template-columns: 1fr; }
}

/* ── archive (novinky) ────────────────────────────────────────────────── */

.btnz-archive { padding-block: clamp(2.5rem, 5vw, 4rem); }
.btnz-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}
.btnz-news-card {
	background: var(--wp--preset--color--w);
	color: inherit;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	border: 1px solid var(--wp--preset--color--cr);
}
.btnz-news-card:hover { text-decoration: none; }
.btnz-news-card__img { aspect-ratio: 16 / 10; overflow: hidden; background: var(--wp--preset--color--cr); }
.btnz-news-card__img img { width: 100%; height: 100%; object-fit: cover; }
.btnz-news-card__body { padding: 1rem 1.25rem 1.25rem; }
.btnz-news-card__tag {
	display: inline-block;
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 0.75rem;
	letter-spacing: 0.05em;
	color: var(--wp--preset--color--orange);
	margin-bottom: 0.5rem;
}
.btnz-news-card__body h3 {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 1.05rem;
	margin: 0 0 0.5rem;
}
.btnz-news-card__date { font-size: 0.85rem; opacity: 0.65; }

/* ── single (novinka detail) ──────────────────────────────────────────── */

.btnz-single__content { padding-block: clamp(2rem, 4vw, 3rem); max-width: 760px; }
.btnz-single__thumb { margin-bottom: 1.5rem; }
.btnz-single__thumb img { width: 100%; height: auto; }

/* ── b2b ──────────────────────────────────────────────────────────────── */

.btnz-b2b { padding-block: clamp(2.5rem, 5vw, 4rem); }
.btnz-b2b__inner {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
.btnz-b2b__intro h2 {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: var(--wp--preset--font-size--h2);
	margin: 0 0 1rem;
}
.btnz-b2b__intro > p { line-height: 1.6; margin: 0 0 0.75rem; }

.btnz-b2b__features {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.25rem;
	margin-top: 2rem;
}
.btnz-b2b__feature {
	padding: 1.25rem;
	background: var(--wp--preset--color--cr);
	border-left: 3px solid var(--wp--preset--color--y);
}
.btnz-b2b__feature h4 {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	margin: 0 0 0.5rem;
	font-size: 1rem;
}
.btnz-b2b__feature p { margin: 0; font-size: 0.9rem; line-height: 1.5; opacity: 0.85; }

.btnz-b2b__cta {
	background: var(--wp--preset--color--br);
	color: var(--wp--preset--color--w);
	padding: clamp(1.5rem, 3vw, 2rem);
	position: sticky;
	top: 6rem;
}
.btnz-b2b__cta h3 {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	color: inherit;
	margin: 0 0 0.75rem;
}
.btnz-b2b__cta p { margin: 0 0 0.5rem; line-height: 1.5; opacity: 0.9; }
.btnz-b2b__cta-contact a { color: var(--wp--preset--color--y); }
.btnz-b2b__cta .btnz-btn { margin-top: 1rem; background: var(--wp--preset--color--y); color: var(--wp--preset--color--br); border-color: var(--wp--preset--color--y); }
.btnz-b2b__cta .btnz-btn:hover { background: transparent; color: var(--wp--preset--color--y); }

@media (max-width: 880px) {
	.btnz-b2b__inner { grid-template-columns: 1fr; }
	.btnz-b2b__cta { position: static; }
}

/* ── story (Náš příběh intro) ─────────────────────────────────────────── */

.btnz-story { padding-block: clamp(2.5rem, 5vw, 4rem); }
.btnz-story__inner { max-width: 760px; margin-inline: auto; }
.btnz-story__tag {
	display: inline-block;
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: 0.85rem;
	letter-spacing: 0.06em;
	padding: 0.3rem 0.75rem;
	background: var(--wp--preset--color--y);
	color: var(--wp--preset--color--br);
	margin-bottom: 1rem;
}
.btnz-story__title {
	font-family: var(--wp--preset--font-family--sandwich);
	text-transform: uppercase;
	font-size: var(--wp--preset--font-size--h2);
	margin: 0 0 1.25rem;
	line-height: 1.1;
}
.btnz-story__body p {
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.65;
	margin: 0 0 1rem;
}

/* ── 404 ──────────────────────────────────────────────────────────────── */

.btnz-404 { padding-block: 6rem 4rem; text-align: center; }
.btnz-404 h1 {
	font-family: var(--wp--preset--font-family--sandwich);
	font-size: clamp(4rem, 12vw, 8rem);
	margin: 0;
	color: var(--wp--preset--color--orange);
}

.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;
}
