/*!
Theme Name: KNIT-ART
Theme URI: https://marianrehak.com
Author: Marián Rehák
Author URI: https://marianrehak.com
Description: Description
Version: 1.0.0.0
Tested up to: 6.1.1
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: knitart
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

@font-face {
	font-family: 'NeueHaas';
	src: url('../font/NeueHaas/NeueHaasDisplay-Roman.woff2') format('woff2'),
		url('.../font/NeueHaas/NeueHaasDisplay-Roman.woff') format('woff');
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'NeueHaas';
	src: url('../font/NeueHaas/NeueHaasDisplay-Bold.woff2') format('woff2'),
		url('.../font/NeueHaas/NeueHaasDisplay-Bold.woff') format('woff');
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

:root {
	--primary: #C8B2B6;
	--secondary: #635850;
}

/* Basic formatting */
html,
body {
	width: 100vw !important;
	overflow-x: hidden !important;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	font-smoothing: antialiased;
	font-smooth: always;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
p,
a,
ul,
li,
.panel-title,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea,
label,
button,
input,
select,
textarea,
.regular,
.regular * {
	color: #000;
	font-family: 'NeueHass', sans-serif;
	font-size: 18px;
	line-height: 1.38;
	font-weight: 500;
}

h1,
h2,
h3,
h4,
h5,
h1 a,
h2 a,
h3 a,
h4 a,
h5 a {
	margin-top: 0;
	margin-bottom: 32px;
	line-height: 1.1;
	font-weight: 500;
}

h1,
h1 a,
h2,
h2 a,
.huge,
.huge a {
	font-size: 40px;
	line-height: 1.1;
	color: var(--secondary);
}

.large,
.large * {
	font-size: 30px;
	line-height: 1.2;
}

h3,
h3 a,
.larger,
.larger a {
	font-size: 24px;
}

h4,
h4 a,
.bit-larger {
	font-size: 20px;
	line-height: 1.2;
	margin-bottom: 22px;
	font-weight: 700;
}

.extra-small,
.extra-small a,
.extra-small p,
.extra-small li {
	font-size: 16px;
	line-height: 1.43;
}

a:hover,
a:focus {
	text-decoration: underline;
	outline: none;
	color: #000;
}

a.active-link {
	text-decoration: underline !important;
	pointer-events: none !important;
}

p {
	margin-top: 0;
	margin-bottom: 20px;
}

p a {
	text-decoration: underline;
}

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


a[href^="mailto:"],
a[href^="tel:"] {
	text-decoration: none;
}

a[href^="mailto:"]:hover,
a[href^="tel:"]:hover {
	text-decoration: underline;
}

b,
strong {
	font-weight: 700;
}

a img {
	-webkit-transition: all 250ms ease-in-out;
	transition: all 250ms ease-in-out;
}

a:hover img {
	-webkit-filter: brightness(0.6);
	filter: brightness(0.6);
}

#main-content ul,
#main-content li {
	padding: 0;
	margin: 0;
}

.page-content,
.entry-content,
.entry-summary {
	padding: 0;
	margin: 0;
}

img {
	width: 100%;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	border: 1px solid #c7c7c7;
	border-radius: 0;
	padding: 4px 8px;
	color: #000;
}

input[type="checkbox"],
input[type="radio"] {
	height: 15px;
	width: 15px;
	margin-right: 20px;
	border: 1px solid #000;
	-webkit-appearance: none;
	-moz-appearance: none;
	cursor: pointer;
	border-radius: 0;
}

input[type="checkbox"]:checked,
input[type="radio"]:checked,
input[type="checkbox"]:checked,
input[type="radio"]:focus {
	background: #000;
	outline: none;
}

mark,
ins {
	background-color: transparent;
}

.knitart-button,
#main-menu .rezervace a,
#mobile-menu .rezervace a,
.btn,
html .nf-form-content input[type=button] {
	font-size: 16px;
	line-height: 24px;
	padding: 4px 12px;
	display: inline-block;
	border: 1px solid #000;
	border-radius: 25px;
	color: #fff;
	background: #000;
	font-weight: 500;
	max-width: 100%;
	width: auto;
	-webkit-transition-duration: 0s !important;
	transition-duration: 0s !important;
	display: inline-block;
	text-align: center;
}

.knitart-button:last-child {
	margin-right: 0;
}

html .nf-form-content input[type=button] {
	margin: 0;
}

.knitart-button.full {
	width: 100%;
	display: block;
	text-align: center;
}

.knitart-button:hover,
.knitart-button:focus,
#main-menu .rezervace a:hover,
#mobile-menu .rezervace a:hover,
html .nf-form-content input[type=button]:hover {
	background: #fff;
	color: #000;
	text-decoration: none !important;
}

iframe {
	width: 100%;
	margin-bottom: -5px;
}

/* Bootstrap formatting */
.container {
	max-width: 100%;
	width: 100%;
	padding-left: 64px;
	padding-right: 64px;
}

.container.full {
	max-width: 100%;
	width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.container.almost-full {
	padding-left: 32px;
	padding-right: 32px;
}

.container.medium {
	width: 1100px;
}

.row {
	margin-left: -16px;
	margin-right: -16px;
}

.col,
.col-1,
.col-10,
.col-11,
.col-12,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-auto,
.col-lg,
.col-lg-1,
.col-lg-10,
.col-lg-11,
.col-lg-12,
.col-lg-2,
.col-lg-3,
.col-lg-4,
.col-lg-5,
.col-lg-6,
.col-lg-7,
.col-lg-8,
.col-lg-9,
.col-lg-auto,
.col-md,
.col-md-1,
.col-md-10,
.col-md-11,
.col-md-12,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-auto,
.col-sm,
.col-sm-1,
.col-sm-10,
.col-sm-11,
.col-sm-12,
.col-sm-2,
.col-sm-3,
.col-sm-4,
.col-sm-5,
.col-sm-6,
.col-sm-7,
.col-sm-8,
.col-sm-9,
.col-sm-auto,
.col-xl,
.col-xl-1,
.col-xl-10,
.col-xl-11,
.col-xl-12,
.col-xl-2,
.col-xl-3,
.col-xl-4,
.col-xl-5,
.col-xl-6,
.col-xl-7,
.col-xl-8,
.col-xl-9,
.col-xl-auto {
	padding-left: 16px;
	padding-right: 16px;
}

.row.tight {
	margin-left: 0;
	margin-right: 0;
}

.row.tight .col {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.col.reveal {
	visibility: hidden;
}

table {
	margin: 0 0 32px 0;
}

ul,
li {
	padding: 0;
	margin: 0;
}

/* Custom classes */
.post,
.page {
	margin: 0;
	padding: 0;
}

.section.half {
	padding-top: 64px;
	padding-bottom: 64px;
}

.section.medium {
	padding-top: 96px;
	padding-bottom: 96px;
}

.section {
	padding-top: 175px;
	padding-bottom: 175px;
}

.top-4 {
	padding-top: 4px;
}

.top-16 {
	padding-top: 16px;
}

.top-24 {
	padding-top: 24px;
}

.top-32 {
	padding-top: 32px;
}

.top-44 {
	padding-top: 44px;
}

.top-48 {
	padding-top: 48px;
}

.top-64 {
	padding-top: 64px;
}

.top-80 {
	padding-top: 80px;
}

.top-96 {
	padding-top: 96px;
}

.top-128 {
	padding-top: 128px;
}

.top-236 {
	padding-top: 236px;
}

.bottom-8 {
	padding-bottom: 8px;
}

.bottom-16 {
	padding-bottom: 16px;
}

.bottom-24 {
	padding-bottom: 24px;
}

.bottom-32 {
	padding-bottom: 32px;
}

.bottom-44 {
	padding-bottom: 44px;
}

.bottom-48 {
	padding-bottom: 48px;
}

.bottom-64 {
	padding-bottom: 64px;
}

.bottom-96 {
	padding-bottom: 96px;
}

.bottom-128 {
	padding-bottom: 128px;
}

.bottom-144 {
	padding-bottom: 144px;
}

.bottom-175 {
	padding-bottom: 175px;
}

.right-16 {
	margin-right: 16px;
}

.right-32 {
	padding-right: 32px;
}

.max-250 {
	max-width: 250px;
}

.max-300 {
	max-width: 300px;
}

.max-375 {
	max-width: 375px;
}

.max-700 {
	max-width: 700px;
}

.max-800 {
	max-width: 800px;
}

.max-850 {
	max-width: 850px;
}

.max-900 {
	max-width: 900px;
}

.nosidepadding {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.flex-center {
	align-items: center;
}

.space-between {
	justify-content: space-between;
}

.justify-end {
	justify-content: flex-end !important;
}

.simple-border {
	border: 1px solid #000;
}

.border-radius {
	border-radius: 8px;
}

.box {
	padding: 64px 10%;
}

.boostrap-box {
	padding: 32px;
}

.height100,
.height100 img {
	min-height: 100%;
}

.height100 img {
	object-fit: cover;
	object-position: center;
}

.marginless,
.marginless *:last-child {
	margin-bottom: 0;
}

.col-paddingless .col,
.col.paddingless,
.paddingless {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.paddingless .row {
	margin-left: 0;
	margin-right: 0;
}

.paddingless .col,
.paddingless .col-12 {
	padding-left: 0;
	padding-right: 0;
}

.automargin {
	margin-left: auto;
	margin-right: auto;
}

.active {
	text-decoration: underline;
}

.white,
.white a,
.white p,
.white span,
.white li,
.white h1,
.white h2,
.white h3,
.white h4 {
	color: #fff;
}

.blue,
.blue a,
.blue p,
.blue span,
.blue li,
.blue h1,
.blue h2,
.blue h3,
.blue h4 {
	color: var(--secondary);
}

.blue-bg {
	background-color: var(--primary);
}

.gray-bg {
	background-color: rgba(0, 0, 0, 0.07);
}

.gray-bg-alt {
	background-color: #F0F0F0;
}

.brown-bg {
	background-color: var(--secondary);
}

.pink-bg {
	background-color: var(--primary);
}

.image-box {
	position: relative;
	background-color: #F0F0F0;
}

.image-box::after {
	content: "";
	display: block;
	padding-bottom: 75%;
}

.image-box.photo::after {
	padding-bottom: 56.25%;
	/* 16:9 */
}

.image-box.high::after {
	padding-bottom: 114%;
}

.image-box img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.video-box {
	position: relative;
}

.video-box::after {
	content: "";
	display: block;
	padding-bottom: 56.25%;
	/* 16:9 */
}

.video-box iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.video-button {
	z-index: 2;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: block;
	height: 70px;
	width: 70px;
	font-size: 0;
	background-color: #fff;
	padding: 16px;
	background-image: url("../img/play.svg");
	background-size: 35%;
	background-position: center;
	background-repeat: no-repeat;
	border: none;
	outline: none;
}

.video-button:hover {
	background-color: var(--primary);
	background-image: url("../img/play-white.svg");
}

.uppercase {
	text-transform: uppercase;
}

.odkazy li {
	list-style: none;
	margin-bottom: 16px;
	display: flex;
	align-items: center;
}

.odkazy li::before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 22px;
	background-image: url("../img/arrow-white.svg");
	background-size: contain;
	background-position: left center;
	margin-right: 36px;
}

.odkazy li:last-child {
	margin-bottom: 0;
}

.mapa {
	overflow: hidden !important;
}

.mapa iframe,
.mapa div {
	width: 100% !important;
	height: 100% !important;
}

.border-top {
	border-top: 1px solid var(--primary) !important;
}

.single-certifikace-item {
	border-top: 1px solid var(--primary);
	padding-top: 32px;
	padding-bottom: 32px;
}

/* Header */
#masthead {
	display: block;
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 99;
	padding: 32px;
	background-color: #fff;
	transition: all 150ms ease-in-out;
	-webkit-transition: all 150ms ease-in-out;
	border-bottom: 1px solid var(--primary);
}

#masthead.scrolled,
#masthead.white-bg-header {
	background-color: #fff !important;
	border-bottom-color: var(--primary) !important;
}

.logged-in #masthead {
	top: 32px;
}

#masthead,
#masthead a {
	line-height: 1;
}

#masthead a {
	color: var(--primary);
	transition: all 150ms ease-in-out;
	-webkit-transition: all 150ms ease-in-out;
}

#masthead.scrolled a,
#masthead.white-bg-header a {
	color: var(--primary) !important;
}

#masthead .menu li {
	display: inline-block;
	margin-right: 50px;
}

#masthead .menu li:last-child {
	margin-right: 0;
}

#masthead .menu a.active {
	text-decoration: underline;
}

#logo {
	display: flex;
	align-items: center;
}

#logo img {
	width: 100%;
	max-width: 300px;
	height: auto;
	transition-duration: 0s;
	-webkit-transition-duration: 0s;
}

.current-lang a {
	text-decoration: underline;
}

.page-template-homepage #masthead {
	background-color: transparent;
	border-bottom-color: transparent;
}

.page-template-homepage #masthead a {
	color: #fff;
}

.page-template-homepage #logo img {
	filter: brightness(0) invert(100%);
}

.page-template-homepage .scrolled #logo img,
.page-template-homepage .white-bg-header #logo img {
	filter: none;
}

/* side bar */
#sidebar {
	position: fixed;
	height: 100vh;
	width: 100vw;
	right: 0;
	top: 0;
	opacity: 0;
	transform: translateX(100%);
	z-index: 100;
	overflow-x: hidden;
	transition: all 500ms ease-in-out;
	-webkit-transition: all 500ms ease-in-out;
}

#sidebar::before {
	content: "";
	display: block;
	height: 100vh;
	width: 100vw;
	left: 0;
	top: 0;
	z-index: 1;
	background-color: rgba(0, 0, 0, 0.37);
	transform: translateX(150%);
	transition: all 800ms ease-in-out;
	-webkit-transition: all 800ms ease-in-out;
}

#sidebar.show-sidebar::before {
	transform: none;
}

#sidebar.show-sidebar {
	transform: none;
	opacity: 1;
}

#sidebar-content {
	height: 100vh;
	overflow-y: scroll;
	background-color: #fff;
	padding: 80px 320px 80px 80px;
	position: absolute;
	right: 0;
	top: 0;
}

#sidebar-content .menu li {
	display: block;
	margin-bottom: 18px;
}

#sidebar-content .menu a {
	font-size: 30px;
}

#close-nav {
	display: block;
	position: absolute;
	top: 85px;
	right: 60px;
	height: 32px;
	width: 32px;
	background-image: url("../img/close-sidebar.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	font-size: 0;
	background-color: transparent;
	border: none;
	outline: none;
}

#sidebar-toggle {
	height: 28px;
	top: 0;
}

#sidebar-toggle .toggle-icon {
	position: relative;
	width: 100%;
	height: 1px;
	background: var(--primary);
	vertical-align: top;
}

#sidebar-toggle .toggle-icon:before,
#sidebar-toggle .toggle-icon:after {
	height: 1px;
	background: var(--primary);
}

.page-template-homepage #sidebar-toggle .toggle-icon,
.page-template-homepage #sidebar-toggle .toggle-icon:before,
.page-template-homepage #sidebar-toggle .toggle-icon:after {
	background: #fff;
}

#sidebar-toggle .toggle-icon:before {
	top: 12px;
}

#sidebar-toggle .toggle-icon:after {
	top: 24px;
}

#masthead.scrolled #sidebar-toggle .toggle-icon,
#masthead.scrolled #sidebar-toggle .toggle-icon:before,
#masthead.scrolled #sidebar-toggle .toggle-icon:after {
	background: var(--primary);
}

white-bg-header

/* Menus */
ul.menu,
ul.menu li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.menu a {
	text-decoration: none;
}

.menu a:hover,
.menu a:focus {
	text-decoration: underline;
}

.menu ul,
.menu ol {
	padding: 0;
	margin: 0;
	list-style: none;
}

.language-switcher ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.language-switcher ul li {
	display: inline-block;
	margin-right: 12px;
}

.language-switcher ul li:last-child {
	margin-right: 0;
}

#ps2id-dummy-offset {
	height: 92px;
}

/* Mobile menu */
#mobile-menu {
	display: none;
}

.navbar-toggle {
	width: 32px;
	height: 20px;
	border: 0;
	padding: 0;
	background: transparent;
	float: right;
	top: -3px;
	position: relative;
}

.navbar-toggle .toggle-icon {
	position: relative;
	width: 100%;
	height: 2px;
	display: inline-block;
	background: #fff;
	transition-duration: 400ms;
	-webkit-transition-duration: 400ms;
}

.navbar-toggle .toggle-icon:before,
.navbar-toggle .toggle-icon:after {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background: #fff;
	content: " ";
	transition-duration: 400ms;
	-webkit-transition-duration: 400ms;
}

.scrolled .navbar-toggle .toggle-icon,
.scrolled .navbar-toggle .toggle-icon:before,
.scrolled .navbar-toggle .toggle-icon:after {
	background: var(--primary);
}

.navbar-toggle .toggle-icon:before {
	bottom: 6px;
}

.navbar-toggle .toggle-icon:after {
	top: 6px;
}

.navbar-toggle.toggled .toggle-icon {
	background: transparent;
	border-color: transparent;
}

.navbar-toggle.toggled .toggle-icon:before {
	transform: rotate(45deg);
	transform-origin: 9px 5px;
	z-index: 2;
}

.navbar-toggle.toggled .toggle-icon:after {
	transform: rotate(-45deg);
	transform-origin: 9px -3px;
	z-index: 1;
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0
}

.sr-only-focusable:active,
.sr-only-focusable:focus {
	position: static;
	width: auto;
	height: auto;
	margin: 0;
	overflow: visible;
	clip: auto
}

/* Page */
#page {
	margin-top: 92px;
}

.page-template-homepage #page {
	margin-top: 0;
}

/* Homepage */
.tight.flex-center img {
	max-height: calc(100vh - 92px);
	height: 100%;
	object-fit: cover;
	object-position: center;
}

#intro .row {
	min-height: 100vh;
}

#intro img {
	height: 100%;
	max-height: 100vh;
	object-fit: cover;
	object-position: center;
}

#intro .box {
	padding-right: 32px;
}

#introGallery {
	position: relative;
}

#introGallery,
#introGallery .slick-list,
#introGallery .slick-track {
	height: 100%;
}

#introGallery::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	background-color: #000;
	opacity: 0.2;
	z-index: 2;
	height: 100%;
	width: 100%;
}

/* Blocks */
/* Gallery block */
.galerie-container {
	display: -ms-flexbox;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	display: flex;
	margin-left: -16px;
	margin-right: -16px;
}

.galerie-container a {
	-ms-flex: 0 0 33.3333%;
	flex: 0 0 33.3333%;
	width: 33.3333%;
	display: inline-block;
	padding: 16px;
}

.wp-block-gallery {
	columns: 4 200px;
	column-gap: 16px;
}

.galerie .image-box {
	display: block;
}

/* Kontakt block */
.kontakt-section {
	border-bottom: 1px solid var(--primary);
	padding: 32px 0;
	margin-right: 32px;
}

/* ikony block */
.ikona-image {
	border: 1.5px solid var(--primary);
	border-radius: 50%;
	position: relative;
}

.ikona-image::after {
	content: "";
	display: block;
	padding-bottom: 100%;
}

.ikona-image img {
	position: absolute;
	top: 50%;
	left: 50%;
	max-width: 60%;
	transform: translate(-50%, -50%);
	object-fit: contain;
	object-position: center;
}

/* Novinky */
.single-novinka,
.single-certifikace {
	padding-top: 44px;
	padding-bottom: 44px;
}

.single-novinka:last-child {
	border-bottom: none;
}

.single-certifikace:last-child {
	border-bottom: 1px solid var(--primary);
	margin-bottom: 164px;
}

.post-link {
	display: flex;
	justify-content: flex-start;
	margin-top: 30px;
}

.post-link.justify-end {
	margin-top: 0;
}

.post-link a,
.post-link button {
	display: block;
	width: 95px;
	height: 95px;
	padding: 0;
	border: 1.5px solid var(--primary);
	border-radius: 50%;
	background-image: url("../img/arrow-brown.svg");
	background-color: #fff;
	background-size: 43px auto;
	background-repeat: no-repeat;
	background-position: center;
	outline: none;
}

.post-link.smaller a,
.post-link.smaller button {
	height: 48px;
	width: 48px;
	background-size: 25px auto;
}

.post-link a:hover,
.post-link button:hover {
	background-color: var(--primary);
	background-image: url("../img/arrow-full-white.svg");
}

.post-link.plus button {
	background-image: url("../img/plus.svg");
}

.post-link.plus button:hover {
	background-image: url("../img/plus-white.svg");
}

.post-link.plus.minus button {
	background-image: url("../img/minus.svg");
}

.post-link.plus.minus button:hover {
	background-image: url("../img/minus-white.svg");
}

.stroje-seznam {
	display: none;
}

/* Stroje / produkty */
.single-kategorie:last-child .border-top,
.single-stroj:last-child .border-top {
	border-bottom: 1px solid var(--primary);
}


.stroj-details {
	display: none;
}

.kategorie-popis {
	position: relative;
	height: 128px;
	overflow: hidden;

}

.kategorie-popis.active-kat {
	height: auto;
}

.kategorie-popis::after {
	content: "";
	display: block;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
	height: 50px;
	width: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
}

.kategorie-popis.active-kat::after {
	display: none;
}

.tab-image {
	display: none;
}

.tab-image.active {
	display: block;
}

.benefity .fade {
	transition-duration: 0s;
}

.nav-link {
	padding: 0 24px 24px 0;
	margin: 0;
	background-color: transparent !important;
	outline: none !important;
	border: none !important;
	color: #000 !important;
}

.nav-link:hover {
	text-decoration: underline;
}

.nav-tabs {
	border: none !important;
}

.tab-pane.active {
	text-decoration: none;
}

.hover-pole {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	display: none;
}

.hover-pole img {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;
}

.hover-pole,
.hover-pole * {
	color: #fff;
}

.hover-text {
	background-color: var(--primary);
	z-index: 1;
	position: relative;
}

.hover-links a {
	text-decoration: none;
	font-weight: 700;
}

.hover-links a:hover,
.hover-links a.activehover {
	text-decoration: underline;
}

/* Referennce */
.reference-carousel {
	padding-left: 48px;
	padding-right: 48px;
	overflow: visible !important;
}

.reference-carousel .slick-list {
	overflow: visible !important;
}

.reference-carousel .single-reference {
	padding: 0 16px;
}

.single-reference.slick-slide {
	opacity: 0;
	transition: all 150ms ease-in-out;
	-webkit-transition: all 150ms ease-in-out;
}

.single-reference.slick-slide.slick-active {
	opacity: 1;
}

.reference-seznam {
	width: 100%;
	max-width: 1300px;
	margin-left: auto;
	margin-right: auto;
}

.reference-seznam .bit-larger {
	padding-bottom: 10px;
	display: inline-block;
	margin-bottom: 0;
}

.reference-seznam .bit-larger::after {
	display: inline-block;
	position: relative;
	top: 2px;
	height: 18px;
	width: 2px;
	content: "";
	background-color: #000000;
	margin: 0 8px 0 10px;
}

.reference-seznam .bit-larger:last-child::after {
	display: none;
}

/* Fancybox */
html .fancybox__toolbar {
	background: transparent !important;
}

html .fancybox__backdrop {
	background-color: rgba(255, 255, 255, 0.95);
}

html .fancybox__thumb {
	border-radius: 0;
}

html .fancybox__thumbs .carousel__slide .fancybox__thumb::after {
	border: 4px solid var(--primary);
	border-radius: 0;
}

html .fancybox__nav .carousel__button {
	background-image: url("../img/arrow-brown.png");
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

html .fancybox__nav .carousel__button.is-prev {
	transform: rotate(180deg);
}

html .fancybox__nav .carousel__button svg,
html .fancybox__counter {
	display: none;
}

html .carousel__button svg {
	filter: none;
}

body:not(.is-using-mouse) .fancybox__container:focus {
	border: none !important;
}

html .carousel__button {
	color: var(--primary);
	box-shadow: none !important;
}

html .fancybox__progress {
	background-color: var(--primary);
}

/* Slick carousel */
.slick-arrows {
	position: absolute;
	width: 100%;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	z-index: 9;
}

.slick-arrow,
.slick-arrows button {
	position: absolute;
	left: 16px;
	top: 0;
	display: block;
	height: 36px !important;
	width: 20px;
	background-image: url("../img/arrow-carousel.png");
	background-size: contain;
	background-position: left center;
	background-repeat: no-repeat;
	background-color: transparent;
	border: none;
	outline: none;
	opacity: 0.7;
	transition: all 150ms ease-in-out;
	-webkit-transition: all 150ms ease-in-out;
	padding: 0;
	font-size: 0;
	z-index: 9;
}

.slick-arrow {
	top: 50%;
	transform: translateY(-50%) rotate(180deg);
	background-image: url("../img/arrow-white.svg");
}

.slick-arrows button:hover {
	opacity: 1;
}

.slick-arrow.slick-next,
.slick-arrows .next {
	left: auto;
	right: 16px;
	transform: rotate(180deg);
}

.slick-arrow.slick-next {
	transform: translateY(-50%);
}

.slick-arrow.slick-disabled {
	opacity: 0.2 !important;
}

/* ajax load more */
.ajax-load-more-wrap {
	width: 100%;
}

.alm-listing {
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
}

html .alm-btn-wrap {
	margin: 0;
	padding: 0;
}


.plus-button,
html .alm-btn-wrap .alm-load-more-btn,
html .alm-load-more-btn.more.done:hover {
	height: 95px;
	width: 95px;
	background-color: transparent !important;
	outline: none;
	border: 1px solid var(--secondary);
	font-size: 0;
	line-height: 0;
	border-radius: 50%;
	background-image: url("../img/plus.svg");
	background-size: 55% auto !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	transition-duration: 0s !important;
	font-size: 0;
	line-height: 0;
	margin-left: auto;
	margin-right: auto;
}

html .alm-btn-wrap .alm-load-more-btn:hover,
.plus-button:hover {
	background-color: var(--secondary) !important;
	background-image: url("../img/plus-white.svg");
}

.alm-btn-wrap .alm-load-more-btn.loading:before {
	display: none !important;
}


/* Newsletter
--------------------------------------------- */

.newsletter {
	position: relative;
	padding: 44px 0 96px 0;
}

.newsletter__header {
	margin-bottom: 32px;
}

.newsletter__title {
	margin: 0;
}

.newsletter__content {
	row-gap: 24px;
}

.newsletter__subtitle p:last-child {
	margin-bottom: 0;
}

.newsletter__form {
	width: 100%;
	max-width: 100%;
	display: flex;
	gap: 12px 6px;
	align-items: center;
	flex-wrap: wrap;
}

.newsletter__message {
	flex: 0 0 100%;
	max-width: 100%;
}

.newsletter__field {
	flex: 1;
}

html .newsletter__input,
html .newsletter__submit {
	width: 100%;
	line-height: 1;
	height: 41px;
	padding: 11px 23px 11px 23px;
	border: 1px solid #fff;
	color: #fff;
	background: transparent;
	border-radius: 21px;
	opacity: 1;
	outline: none !important;
	box-shadow: none !important;
}

html .newsletter__input::placeholder {
	color: #fff;
}

.newsletter__input:focus,
.newsletter__submit:hover {
	background-color: #fff;
	color: var(--secondary);
}

.pink-bg .newsletter__input:focus,
.pink-bg .newsletter__submit:hover {
	color: var(--primary);
}

.newsletter__consent {
	max-width: 450px;
}

.newsletter__submit {
	cursor: pointer;
}

.newsletter__submit[disabled] {
	opacity: 0.7;
	cursor: wait;
}

.newsletter__message.is-success {
	color: #fff;
}

.newsletter__message.is-error {
	color: #fff;
}

.newsletter__close {
	position: absolute;
	top: 0;
	right: 0;
	right: 24px;
	top: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	min-width: 32px;
	height: 32px;
	background: transparent;
	cursor: pointer;
	background-image: url("../img/plus-white.svg");
	transform: rotate(45deg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	padding: 0;
	border: none;
	background-color: transparent;
	outline: none;
}

.newsletter--footer {
	border-bottom: 1px solid #fff;
}

.newsletter--popup {
	position: fixed;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 0;
	z-index: 9999999999;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	transform: translateY(100%);
	transition: transform 0.35s ease;
	will-change: transform;
	pointer-events: none;
}

.newsletter--popup.is-visible {
	transform: translateY(0);
	pointer-events: auto;
}

.newsletter--popup .container {
	width: 100%;
	max-width: 100%;
	padding-top: 48px;
	padding-bottom: 48px;
}

@media(max-width: 767px) {
	.newsletter--popup .container {
		padding-top: 32px;
		padding-bottom: 32px;
	}

	.newsletter__form {
		flex-direction: column;
		align-items: unset;
	}

	.newsletter__consent {
		margin-top: 12px;
	}

	.newsletter__close {
		top: -24px;
		right: 6px;
	}
}

/* Cookies */
html .cmplz-placeholder-1.cmplz-blocked-content-container::after {
	content: "";
	display: block;
	position: absolute;
	height: 100%;
	width: 100%;
	background-color: #eaeaea;
	background-image: url("../complianz-gdpr/g-maps-disabled-bg.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

html .cmplz-cookiebanner {
	min-width: 200px;
	max-width: 400px;
	width: 100%;
	padding: 15px;
	display: block;
	border: 2px solid var(--primary);
	box-shadow: none !important;
	border-radius: 0 !important;
}

html .cmplz-cookiebanner .cmplz-header {
	display: block;
	margin-bottom: 10px;
}

html .cmplz-cookiebanner .cmplz-close {
	position: absolute;
	top: 5px;
	right: 0;
	outline: none !important;
}

html .cmplz-cookiebanner .cmplz-close svg {
	width: 15px;
	height: 15px;
}

.cmplz-link.cookie-statement,
.cmplz-link.privacy-statement {
	display: none !important;
}

html .cmplz-cookiebanner .cmplz-title {
	font-size: 16px;
	font-weight: 500;
}

html .cmplz-cookiebanner .cmplz-categories .cmplz-category:not(:last-child) {
	margin-bottom: 5px;
}

html .cmplz-cookiebanner .cmplz-message,
html .cmplz-cookiebanner .cmplz-message * {
	font-size: 15px;
	line-height: 20px;
	margin-bottom: 15px;
	width: 100%;
}

html .cmplz-cookiebanner .cmplz-message a {
	text-decoration: underline;
	color: #000;
}

html #cmplz-document p a:hover {
	text-decoration: none;
}

html .cmplz-cookiebanner .cmplz-message a:hover {
	text-decoration: none;
}

html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn {
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	padding: 7px;
	height: unset;
	width: calc(50% - 5px);
	margin-right: 5px;
	float: left;
	border-color: #f2f2f2 !important;
	border-width: 2px !important;
	border-radius: 0 !important;
}

html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn:hover {
	background: transparent !important;
	color: var(--primary) !important;
	border-color: var(--primary) !important;
}

html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cc-show-settings {
	margin-right: 0;
	margin-left: 5px;
}

html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept {
	width: 100%;
	margin-bottom: 10px;
	border-color: var(--primary) !important;
}

html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept:hover {
	background: #000 !important;
	color: #fff !important;
	border-color: #000 !important;
}

html .cmplz-cookiebanner .cmplz-buttons {
	display: block;
}

html .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header {
	padding: 4px 8px;
}

html .cmplz-cookiebanner .cmplz-categories.cmplz-fade-in {
	margin-bottom: 15px;
	max-width: 100%;
	width: 100%;
}

html .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-category-title,
html .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-always-active {
	font-weight: 500;
}

.cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-description {
	padding: 4px;
}

#cmplz-manage-consent .cmplz-manage-consent {
	display: none !important;
}

html #cmplz-document .cmplz-subtitle {
	font-weight: 500;
}

@media (max-width: 767px) {
	html .cmplz-cookiebanner {
		bottom: 20px;
		left: 50%;
		transform: translateX(-50%);
		max-width: calc(100vw - 40px);
	}

	html .cmplz-cookiebanner .cmplz-body {
		min-width: unset;
	}

	html .cmplz-cookiebanner .cmplz-buttons .cmplz-btn {
		width: 100%;
		margin-right: 0 !important;
		margin-left: 0 !important;
		margin-bottom: 10px;
	}
}

html .cmplz-blocked-content-container,
html .cmplz-placeholder-1.cmplz-blocked-content-container iframe {
	height: 100%;
	box-shadow: none !important;
}

html .cmplz-blocked-content-container .cmplz-blocked-content-notice {
	background: #fff;
	color: #000;
	font-size: 16px;
	line-height: 22px;
	border-radius: 0;
	border: none;
}

html .cmplz-blocked-content-container .cmplz-blocked-content-notice:hover {
	background: #000;
	color: #fff;
}

html #cmplz-document p a,
#cmplz-cookies-overview .cmplz-dropdown a,
#cmplz-cookies-overview .cmplz-dropdown p,
#cmplz-document .cmplz-dropdown a,
#cmplz-document .cmplz-dropdown p,
#cmplz-document li,
#cmplz-document p,
#cmplz-document td,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown a,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown p,
.editor-styles-wrapper .cmplz-unlinked-mode li,
.editor-styles-wrapper .cmplz-unlinked-mode p,
.editor-styles-wrapper .cmplz-unlinked-mode td {
	font-size: 16px !important;
}

#cmplz-document h2,
.editor-styles-wrapper .cmplz-unlinked-mode h2 {
	font-size: 24px !important;
}

#cmplz-document h3,
.editor-styles-wrapper .cmplz-unlinked-mode h3 {
	font-size: 16px !important;
}

html .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-always-active {
	color: #000;
}

html .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-icon.cmplz-open {
	height: auto;
}

/* Footer */
footer {
	margin-top: 0;
	background-color: var(--secondary);
}

footer h4 {
	padding-bottom: 32px;
	margin-bottom: 32px;
	position: relative;
}

footer h4::after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100px;
	background-color: #fff;
}

#main-footer {
	padding-top: 80px;
	padding-bottom: 96px;
}

#subfooter {
	border-top: 1px solid #fff;
	padding-top: 48px;
	padding-bottom: 48px;
}

.social-ikony {
	filter: brightness(0) invert(100%);
}

.social-ikony img {
	height: 21px;
	width: auto;
	margin: 0 32px 16px 0;
	transition: all 150ms ease-in-out;
	-webkit-transition: all 150ms ease-in-out;
}

.social-ikony img:hover {
	transform: scale(1.25);
}

/* Responsive */
@media (min-width: 1600px) {
	#page {
		margin-top: 100px;
	}

	/* fonts */
	h1,
	h1 a,
	h2,
	h2 a,
	.huge,
	.huge a {
		font-size: 50px;
	}

	h3,
	h3 a,
	.larger,
	.larger a {
		font-size: 30px;
	}

	/* Header */
	#masthead,
	#masthead a {
		font-size: 20px;
		line-height: 1;
	}

	#masthead .menu li {
		margin-right: 32px;
	}

	#logo img {
		max-width: 400px;
	}

	/* homepage */
	.tight.flex-center img {
		height: calc(100vh - 100px);
	}
}

@media (max-width: 1599px) {
	.lg-top-64 {
		padding-top: 64px;
	}

	#masthead .menu li {
		margin-right: 30px;
	}
}

@media (max-width: 1200px) {
	.box {
		padding: 24px 10%;
	}

	/* Fonts */
	html,
	body,
	p,
	a,
	ul,
	li,
	.panel-title,
	input[type="text"],
	input[type="email"],
	input[type="url"],
	input[type="password"],
	input[type="search"],
	input[type="number"],
	input[type="tel"],
	input[type="range"],
	input[type="date"],
	input[type="month"],
	input[type="week"],
	input[type="time"],
	input[type="datetime"],
	input[type="datetime-local"],
	input[type="color"],
	textarea,
	label,
	button,
	input,
	select,
	textarea {
		font-size: 16px;
	}

	h1,
	h1 a,
	h2,
	h2 a,
	.huge,
	.huge a {
		font-size: 36px;
		line-height: 1.1;
	}

	/* Header */
	#masthead,
	#masthead a {
		font-size: 16px;
		line-height: 1;
	}

	#masthead .menu li {
		margin-right: 16px;
	}

	#sidebar-toggle {
		top: -2px;
	}
}

@media (min-width: 992px) {
	#main-menu {
		padding-left: 0;
	}

	#site-navigation {
		padding-left: 10.6%;
	}
}

@media (max-width: 991px) {
	.tabletmargin {
		margin-top: 32px;
	}

	.tabletmargin-64 {
		margin-top: 64px;
	}

	#page {
		margin-top: 61px;
	}

	/* Bootstrap */
	.container,
	.container.almost-full {
		padding-left: 16px;
		padding-right: 16px;
	}

	/* Fonts */
	h1,
	h1 a,
	h2,
	h2 a,
	.huge,
	.huge a {
		font-size: 32px;
	}

	h3,
	h3 a,
	.larger,
	.larger a {
		font-size: 20px;
	}

	/* Menu */
	#mobile-menu {
		padding: 48px 16px 26px 16px;
	}

	#masthead #mobile-menu::before {
		content: "";
		display: block;
		background: rgba(255, 255, 255, 0.8);
		z-index: -1;
		height: 100vh;
		width: 100vw;
		position: fixed;
		top: 0;
		left: 0;
		opacity: 0;
		-webkit-transition: all 500ms ease-in-out;
		transition: all 500ms ease-in-out;
	}

	#masthead.blur #mobile-menu::before {
		opacity: 1;
	}


	#mobile-menu.active-mobile::after {
		opacity: 1;
	}

	#mobile-menu .menu li {
		display: block;
		margin: 0;
		padding: 12px 0;
	}

	/* Header */
	.logged-in #masthead {
		top: 0;
	}

	#masthead {
		padding: 20px 16px;
	}

	#logo img {
		max-width: 200px;
	}

	#ps2id-dummy-offset {
		height: 61px;
	}

	/* Custom classes */
	.box {
		padding: 64px 20px;
	}

	/* homepage */
	.tight.flex-center img {
		max-height: calc(100vh - 92px);
	}

	/* novinky */
	.post-link a,
	.post-link button {
		width: 70px;
		height: 70px;
		background-size: 40px auto;
	}

	.post-link.smaller a,
	.post-link.smaller button {
		height: 38px;
		width: 38px;
		background-size: 22px auto;
	}

	/* Block: kontakt */
	.kontakt-section {
		margin-right: 0;
		padding: 32px;
	}

	/* Block: galerie */
	.galerie-container {
		margin-left: -8px;
		margin-right: -8px;
	}

	.galerie-container a {
		-ms-flex: 0 0 33%;
		flex: 0 0 33%;
		width: 33%;
		max-width: 33%;
		display: inline-block;
		padding: 8px;
	}

	/* Fancybox */
	html .fancybox-navigation .fancybox-button {
		width: 45px;
		height: 45px;
		padding: 0;
		top: 50%;
		transform: translateY(-50%);
	}

	html .fancybox-navigation .fancybox-button div {
		background-size: 20px;
	}

	html .fancybox-navigation .fancybox-button {
		background: #fff;
	}
}

@media (min-width: 768px) {
	.left-md-64 {
		padding-left: 64px;
	}

	.top-md-64 {
		padding-top: 64px;
	}
}

@media (max-width: 767px) {
	.mobilemargin-32 {
		margin-top: 32px;
	}

	.mobilemargin-64 {
		margin-top: 64px;
	}

	.mobile-bottom-16 {
		padding-bottom: 16px;
	}

	.mobile-top-32 {
		padding-top: 32px;
	}

	.section {
		padding-top: 128px;
		padding-bottom: 128px;
	}

	.right-32 {
		padding-right: 0;
	}

	.hover-pole img {
		display: none;
	}

	#introGallery {
		height: 70vh;
	}

	/* Fonts */
	h3,
	h3 a,
	.larger,
	.larger a,
	h4,
	h4 a,
	.bit-larger {
		font-size: 18px;
	}

	/* Block: ikony */
	.single-ikona {
		margin-bottom: 64px;
	}

	.single-ikona:last-child {
		margin-bottom: 0;
	}

	/* Block: galerie */
	.galerie-container a {
		-ms-flex: 0 0 50%;
		flex: 0 0 50%;
		width: 50%;
		max-width: 50%;
	}

	/* homepage */
	#intro .row {
		min-height: unset;
	}

	/* Novinky */
	.post-link a,
	.post-link button {
		width: 54px;
		height: 54px;
		background-size: 28px auto;
		border-width: 1px;
	}

	/* Kontakt */
	.mapa iframe {
		height: 60vh !important;
	}

	/* Realizace */
	.post-link.realizace {
		justify-content: flex-end;
	}
}