:root {
	--red: #ef142f;
	--blue: #0f2952;
	--green: #3fc907;
	--light: #edeff3;
	--gray: #cfd3d9;
	--grayBlue: #94a0b2;
	--scale: 1;
}

html {
	scroll-behavior: smooth;
	scroll-snap-type: y proximity;
	scroll-padding-top: 100px;
}

body {
	margin: 0;
	font-family: "Poppins", serif;
	font-weight: normal;
	background: #fff;
}

.before-header {
	width: 100%;
	height: 100px;
	background: var(--light);
	position: absolute;
	left: 0;
	top: 0;
}

.wrapper {
	width: calc(100% - 30px);
	max-width: 1200px;
	margin: 0 auto;
}

.text-center {
	text-align: center;
}

.none {
	display: none !important;
}

.mt0 {
	margin-top: 0 !important;
}

.mr0 {
	margin-right: 0 !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt-100 {
	margin-top: 100px !important;
}

.mt-150 {
	margin-top: 150px !important;
}

.mt-50 {
	margin-top: 50px !important;
}

.mt-30 {
	margin-top: 30px !important;
}

.mt-0 {
	margin-top: 0 !important;
}

.mb0 {
	margin-bottom: 0 !important;
}

.mb-50 {
	margin-bottom: 50px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.mb-10 {
	margin-bottom: 10px !important;
}

.mb-100 {
	margin-bottom: 100px !important;
}

.mb5 {
	margin-bottom: 5px !important;
}

.pb-50 {
	padding-bottom: 50px !important;
}

.pt-0 {
	padding-top: 0 !important;
}

.pb-0 {
	padding-bottom: 0 !important;
}

.d-block {
	display: block;
}

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

.d-flex {
	display: flex;
}

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

.gap20 {
	gap: 20px;
}

.gap50 {
	gap: 50px;
}

.color-blue {
	color: var(--blue);
}

.text-uppercase {
	text-transform: uppercase;
}

.invert {
	filter: invert(100%);
}

.icon {
	padding-left: 30px;
}

.icon-phone {
	background: url('../img/ico-telefon-white.svg') no-repeat left center / 35px;
}

.icon-email {
	padding-left: 35px;
	background: url('../img/ico-email-white.svg') no-repeat left center / 35px;
}

.col-half {
	min-width: 50%;
	max-width: 50%;
	width: 50%;
}

.col-40 {
	min-width: 40%;
	max-width: 40%;
	width: 40%;
}

.col-60 {
	min-width: calc(60% - 50px);
	max-width: calc(60% - 50px);
	width: calc(60% - 50px);
}

.half-50gap.col-half {
	min-width: calc(50% - 25px);
	max-width: calc(50% - 25px);
	width: calc(50% - 25px);
}

header {
	width: 100%;
	height: 100px;
	position: fixed;
	width: calc(100% - 30px);
	max-width: 1200px;
	margin: 0 auto;
	top: 0;
	z-index: 10;
}

.float-left {
	float: left;
}

.other-pages header {
	position: absolute;
}

.fixed {
	position: fixed;
	top: 0;
	max-width: 1200px;
	z-index: 100;
	box-shadow: 0 0 25px rgba(0,0,0,.1);
}

.image-circles .btn {
	display: inline-block;
	background: var(--red);
	color: #fff !important;
	z-index: 3;
	margin-left: 155px;
	padding: 10px 16px;
	position: absolute;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 600;
	border-radius: 0px 20px 20px 20px;
	transition: .3s all ease-in-out;
}

.image-circles .btn:hover {
	background: var(--blue);
}

.image-circles {
	float: right;
	width: 400px;
	position: relative;
}

.image-circles:before {
	width: 100px;
	height: 100px;
	border-radius: 100%;
	position: absolute;
	left: -100px;
	top: 10px;
	content: '';
	background: var(--blue);
}

.image-circles:after {
	width: 160px;
	height: 160px;
	border-radius: 100%;
	position: absolute;
	right: 30px;
	bottom: 10px;
	content: '';
	background: var(--blue);
}

.image-circles img {
	width: 320px;
	height: 320px;
	border-radius: 100%;
	position: relative;
	z-index: 1;
	object-fit: cover;
}

.align-middle {
	align-items: center;
	align-content: center;
}

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

.logo {
	width: 300px;
	height: 100px;
	background: #fff url('../img/logo.svg') no-repeat center center / 230px;
	display: block;
	text-decoration: none;
	float: left;
}

#notify {
	background: var(--blue);
	position: absolute;
	right: 140px;
	z-index: 100;
	line-height: 16.5px;
	top: 117px;
	box-sizing: border-box;
	padding: 10px 15px;
	box-shadow: 0 .188rem .375rem rgba(0,0,0,.16);
	border-radius: 3px;
	font-size: 13px;
	pointer-events: none;
	color: #fff;
	opacity: 0;
	transform: translateX(-30px);
	transition: .3s all ease-in-out;
}

#notify i {
	font-style: normal;
}

#notify::before {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 5px;
	border-color: transparent transparent transparent var(--blue);
	position: absolute;
	right: -5px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: '';
}

#notify.active {
	opacity: 1;
	transform: translateX(0);
}

.cats-banner {
	width: 100%;
	padding: 100px 0 50px;
	float: left;
	margin-top: 100px;
	color: #fff;
	background: var(--blue);
}

.cats-banner .arrow-right {
	filter: invert(100%);
}

.cats-banner p {
	color: #fff;
}

.cats-banner .button:hover {
	background: var(--grayBlue) !important;
	color: var(--blue) !important;
}

.cats-banner__image {
	width: 500px;
	min-width: 500px;
	height: 100%;
	display: flex;
	justify-content: center;
	position: relative;
}

.cats-banner__image::before {
	width: 160px;
	height: 160px;
	background: #fff;
	content: '';
	position: absolute;
	left: 30px;
	bottom: 0;
	z-index: 2;
	border-radius: 100%;
}

.cats-banner__image::after {
	width: 90px;
	height: 90px;
	background: #fff;
	opacity: .2;
	content: '';
	position: absolute;
	right: 80px;
	top: 0;
	z-index: 0;
	border-radius: 100%;
}

.small-cirlce {
	width: 50px;
	height: 50px;
	border-radius: 100%;
	background: var(--light);
	left: 10px;
	top: 20px;
	opacity: .6;
	position: absolute;
}

.cats-banner__image img {
	width: 300px;
	height: 300px;
	object-fit: cover;
	border-radius: 100%;
	position: relative;
	z-index: 1;
}

.products {
	width: 100%;
	float: left;
}

.clear-bottom {
	width: 100%;
	float: left;
	clear: both;
	margin-bottom: 550px;
}

.breadcrumbs {
	color: #fff;
}

.breadcrumbs a {
	color: var(--red);
	text-underline-offset: 3px;
}

.navbar {
	width: calc(100% - 300px);
	float: left;
}

.navbar__info {
	width: 100%;
	height: 30px;
	background: var(--blue);
	color: #fff;
	float: left;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 25px;
	font-size: 13px;
	box-sizing: border-box;
}

.navbar__info a {
	color: #fff;
	text-underline-offset: 3px;
}

.ecommerce-navbar,
#search-holder {
	width: 100%;
	height: 70px;
	background: #fff;
	float: left;
	display: flex;
	align-items: center;
	box-sizing: border-box;
	border: 1px solid var(--light);
}

#search-holder {
	border-right: 0;
	border-left: 0;
}

#search-holder {
	position: relative;
}

#search-holder input {
	border: 0;
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px 20px;
	outline: none !important;
	width: 100%;
	background: #fff;
}

.ecommerce-navbar__links {
	width: 100%;
	display: flex;
	justify-content: space-between;
	gap: 20px;
	box-sizing: border-box;
	padding: 20px;
}

.ecommerce-navbar__links a {
	color: var(--red);
	font-size: 16px;
	text-decoration: none;
	font-weight: 600;
	transition: .3s all ease-in-out;
}

.ecommerce-navbar__links a:hover {
	color: var(--blue);
}

.ecommerce-navbar__actions {
	display: flex;
	height: 100%;
	align-items: center;
}

.ecommerce-navbar__actions a {
	display: block;
	height: 100%;
}

.i {
	width: 45px;
	height: 100%;
	padding: 0 12px;
	display: block;
	cursor: pointer;
	text-decoration: none;
	border-left: 1px solid var(--light);
}

.icon-cart {
	background: url('../img/ico-kosik.svg') no-repeat center center / 45px;
}

.icon-search {
	background: url('../img/ico-search.svg') no-repeat center center / 45px;
}

.icon-search.close {
	background: url('../img/cross.svg') no-repeat center center / 45px;
}

.icon-user {
	background: url('../img/ico-user.svg') no-repeat center center / 45px;
}

.menu {
	width: 100%;
	height: 70px;
	background: var(--red);
	color: #fff;
	float: left;
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	padding: 0 25px;
}

.menu a {
	color: #fff;
	font-weight: 600;
	text-decoration: none;;
	font-size: 16px;
	transition: .3s all ease-in-out;
}

.menu a:not(.btn) {
	border-bottom: 2px solid transparent;
}

.menu a:not(.btn):hover {
	opacity: .75;
}

.btn {
	background: #fff;
	color: var(--red) !important;
	padding: 8px 25px;
	border-radius: 25px;
	box-shadow: 0 0 15px rgba(0,0,0,.1);
}

.btn:hover {
	background: #ffe5e8;
}

.banner {
	width: calc(100% - 60px);
	height: 800px;
	background: url('../img/banner.jpg') no-repeat center center / cover;
	float: right;
	border-bottom-left-radius: 120px;
	display: flex;
	align-items: center;
	position: relative;
	overflow: clip;
	margin-bottom: 50px;
}

.middle {
	position: relative;
	z-index: 5;
}

.banner video {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	object-fit: cover;
	z-index: 1;
	position: none;
}

.banner h1 {
	color: #fff;
	font-size: 38px;
	margin-bottom: 15px;
}

.banner h1 strong {
	font-size: 15px;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--red);
	display: block;
}

.button {
	display: inline-block;
	background: var(--red);
	color: #fff;
	padding: 10px 16px;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 600;
	border-radius: 0px 20px 20px 20px;
	transition: .3s all ease-in-out;
}

.button:hover {
	background: var(--blue);
	border-radius: 20px 20px 20px 0px;
}

.basic-button {
	max-width: 200px;
	border-radius: 20px;
	color: #fff !important;
}

.main {
	width: 100%;
	float: left;
	clear: both;
}

.small-middle {
	max-width: 600px;
	margin: 0 auto;
}

h2 {
	font-size: 28px;
	color: var(--blue);
}

h2 small {
	display: block;
	font-size: 14px;
	text-transform: uppercase;
	color: var(--red);
}

p {
	color: #6b6b6b;
}

.section {
	width: 100%;
	float: left;
	clear: both;
}

.products-list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border: .5px solid var(--light);
}

.product {
	height: 410px;
	text-decoration: none;
	display: block;
	position: relative;
	border: .5px solid var(--light);
	box-shadow: 0 0 0 rgba(0,0,0,.1);
}

.banner-product {
	height: 100%;
	box-sizing: border-box;
	padding: 20px;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.banner-product h2 {
	position: absolute;
	top: 30px;
	margin: 0;
	color: #fff;
	font-size: 36px;
	line-height: 1.3;
	box-sizing: border-box;
	padding-right: 20px;
}

.banner-product .button {
	position: absolute;
	bottom: 30px;
}

.tag {
	position: absolute;
	background: var(--green);
	color: #fff;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 12px;
	padding: 3px 7px;
	border-radius: 15px;
	left: 10px;
	top: 10px;
}

.product img {
	width: 100%;
	height: 200px;
	float: left;
	object-fit: contain;
	object-position: center center;
}

.product-info {
	width: 100%;
	box-sizing: border-box;
	padding: 20px;
	padding-top: 0;
	float: left;
}

.product-info h2 {
	margin: 0;
	height: 50px;
	font-size: 15px;
	color: var(--blue);
	text-decoration: none;
}

.product-info h2 a {
	color: inherit;
	font-size: inherit;
	transition: .3s all ease-in-out;
	text-decoration: none;
}

.product-info p {
	height: 70px;
	font-size: 14px;
}

.product-info p label {
	display: inline-block;
	width: 70px;
}

.product-info .button {
	width: 100%;
	box-sizing: border-box;
	text-align: center;
	background: var(--blue);
}

.product:hover .button {
	background: var(--red);
}

.product:hover {
	z-index: 5;
	box-shadow: 0 0 20px rgba(0,0,0,.1);
}

.product:hover h2 a {
	color: var(--red);
}

.category-icons {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	transition: .3s all ease-in-out;
	border-left: .5px solid var(--light);
	border-right: .5px solid var(--light);
	border-bottom: .5px solid var(--light);
}

.category-icons span {
	display: block;
	color: var(--blue);
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 14px;
	transition: .3s all ease-in-out;
}

.category-icons a {
	text-decoration: none;
	background: #fff;
	height: 160px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	box-sizing: border-box;
	padding: 15px;
	text-align: center;
	border: .5px solid var(--light);
	box-shadow: 0 0 0 rgba(0,0,0,.1);
	transition: .3s all ease-in-out;
}

.category-icons a img {
	height: 70px;
	display: block;
	margin-bottom: 20px;
}

.category-icons a:hover {
	z-index: 1;
	box-shadow: 0 0 25px rgba(0,0,0,.1);
}

.category-icons a:hover span {
	color: var(--red);
}

.section-categories {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 50px;
	margin-top: 20px;
	margin-bottom: 60px;
	clear: both;
	width: 100%;
	float: left;
}

.section-categories a {
	width: 100%;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	color: var(--blue);
	font-weight: 600;
	transition: .3s all ease-in-out;
}

.section-categories a:hover {
	color: var(--red);
}

.section-categories .image {
	width: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	margin-top: 20px;
	aspect-ratio: 1;
	border-radius: 100%;
	position: relative;
	transition: .3s all ease-in-out;
}

.section-categories .image:before {
	display: inline-block;
	content: 'Přejít na eshop';
	background: var(--red);
	color: #fff;
	padding: 10px 16px;
	position: absolute;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 600;
	border-radius: 0px 20px 20px 20px;
	transition: .3s all ease-in-out;
}

.section-categories .image:hover {
	transform: scale(1.035);
}

.section-categories .image:hover:before {
	transform: scale(0);
	transform-origin: top left;
}

.whole-page,
.whole-page-lightblue-color {
	width: calc(100% - 60px);
	height: 700px;
	background: url('../img/bg-reference.jpg') no-repeat center center / cover;
	float: left;
	border-bottom-right-radius: 120px;
	box-sizing: border-box;
	padding: 50px 0;
	position: relative;
	margin-bottom: 50px;
	align-items: center;
}

.whole-page--right {
	float: right;
	border-bottom-left-radius: 120px;
	border-bottom-right-radius: 0;
}

.whole-page-lightblue-color {
	width: 100%;
	height: auto;
	background: var(--light);
	border-radius: 0;
}

footer {
	width: calc(100% - 60px);
	height: 620px;
	background: url('../img/bg-pata.jpg') no-repeat center center / cover;
	float: right;
	border-top-left-radius: 120px;
	box-sizing: border-box;
	padding: 50px 0;
	position: relative;
	margin-top: -150px;
	margin-bottom: 0px;
	align-items: center;
	z-index: 10000;
}

.overflow-clip {
	overflow: clip;
}

.overlay-image:before {
	width: 100%;
	height: 100%;
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	background: rgba(0,0,0,.3);
}

.wp-bottom-margin {
	margin-bottom: 470px;
}

.whole-page h2 {
	color: #fff;
}

.clear {
	clear: both;
}

.w100p {
	width: 100%;
}

@keyframes floating {
  0% { transform: translateY(0); }
  50% { transform: translateY(-15px); }
  100% { transform: translateY(0); }
}

@keyframes floatingScale {
  0% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-15px) scale(0.8); }
  100% { transform: translateY(0) scale(1); }
}

.circle-midd {
	width: calc(100% - 20px);
	max-width: 500px;
	background: var(--red);
	border-radius: 100%;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	bottom: 0;
	position: relative;
	transform: translateY(50%);
	aspect-ratio: 1;
}

.circle-midd:before {
	width: 350px;
	height: 500px;
	position: absolute;
	content: '';
	left: 0;
	right: 0;
	margin: auto;
	top: -50%;
	animation: floating 3s ease-in-out infinite;
	background: url('../img/kelimek.webp') no-repeat center center / contain;
}

.circle-midd:after {
	width: 250px;
	height: 30px;
	background: rgba(0,0,0,.6);
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	bottom: 43%;
	filter: blur(20px);
	animation: floatingScale 3s ease-in-out infinite;
}

.ml-0 {
	margin-left: 0 !important;
}

.ml-20 {
	margin-left: 20px !important;
}

.white-box {
	background: #fff;
	box-sizing: border-box;
	padding: 35px;
	text-align: left;
	position: absolute;
	bottom: -44%;
	right: -50%;
	max-width: 500px;
}

.white-box h2,
blockquote h2 {
	color: var(--blue) !important;
	margin-top: 0;
}

blockquote h2 {
	opacity: 0;
	transform: translateY(20px);
	position: absolute;
	transition: .35s all ease-in-out;
}

blockquote h2.active {
	opacity: 1;
	transform: translateX(0px)  scale(1);
}

blockquote {
	width: 100%;
	max-width: 500px;
	height: 220px;
	text-align: left;
	position: relative;
}

.whole-page blockquote {
	position: relative;
	top: 220px;
}

blockquote .navigation {
	width: 100%;
	margin-bottom: 10px;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--red);
}

blockquote .navigation small {
	margin-left: 25px;
	color: rgba(0,0,0,.2);
	cursor: pointer;
}

blockquote .navigation small.active {
	color: var(--red);
}

.blank-space {
	height: 450px;
}

.green-bg h2 small {
	color: var(--green);
}

.green-bg .button {
	background: var(--green);
}

.green-bg p {
	color: #fff;
	max-width: 600px;
	margin: 0 auto 30px;
}

.arrow-right {
	display: inline-block;
	width: 20px;
	height: 20px;
	position: relative;
	top: 6px;
	background: url('../img/arrow-right.svg') no-repeat;
}

.circle-container {
	position: relative;
	height: 800px;
	margin-top: 50px;
	margin-bottom: 350px;
}

.circle-blue {
	background: var(--blue);
	width: 100px;
	height: 100px;
	right: 0;
	top: -20px;
}

.circle {
	position: absolute;
	border-radius: 50%;
	overflow: hidden;
	transition: .55s all ease-in-out;
}

.circle img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.circle-1 {
	width: 240px;
	height: 240px;
	top: 0;
	left: 20%;
}

.circle-2 {
	width: 100px;
	height: 100px;
	top: 180px;
	left: 35%;
	background-color: #1d2d59;
}

.circle-3 {
	width: 220px;
	height: 220px;
	top: 50px;
	left: 50%;
}

.circle-4 {
	width: 80px;
	height: 80px;
	top: 200px;
	left: 70%;
	background-color: #1d2d59;
}

.circle-5 {
	width: 200px;
	height: 200px;
	top: 250px;
	left: 5%;
}

.circle-6 {
	width: 100px;
	height: 100px;
	top: 350px;
	left: 25%;
	background-color: #ffffff;
}

.circle-7 {
	width: 430px;
	height: 430px;
	top: 300px;
	left: 45%;
}

.circle-8 {
	width: 240px;
	height: 240px;
	top: 350px;
	left: 90%;
}

.circle-9 {
	width: 150px;
	height: 150px;
	top: 70px;
	left: 85%;
	background-color: #ffffff;
}

.video-button {
	position: absolute;
	width: 140px;
	height: 140px;
	background-color: var(--red);
	border-radius: 50%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: white;
	cursor: pointer;
	z-index: 1;
	box-shadow: 0 4px 20px rgba(228, 31, 45, 0.4);
}

.video-button .play-icon {
	display: block;
	width: 40px;
	height: 40px;
	margin-bottom: 5px;
	background: url('../img/play.svg') no-repeat center center / contain;
}

.video-button .text {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
}

.nav-buttons {
	position: absolute;
	width: 100%;
	top: 50%;
	display: flex;
	justify-content: space-between;
	z-index: 5;
}

.nav-button {
	width: 40px;
	height: 40px;
	background-color: #e41f2d;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	color: white;
	cursor: pointer;
	font-size: 18px;
}

.relative {
	position: relative;
}

.contact-box {
	height: 300px;
	width: 100%;
	background: #fff;
	position: absolute;
	top: -290px;
	display: flex;
}

.map {
	width: 50%;
	height: 300px;
	background: url('../img/mapa.jpg') no-repeat center center / cover;
}

.fast-contact {
	padding: 30px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
}

.hot-links {
	margin-top: 40px;
	width: 100%;
	float: left;
	box-sizing: border-box;
	padding: 0 10px;
	padding-bottom: 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid rgba(255,255,255,.2);
}

.hot-links a {
	transition: .35s all ease-in-out;
}

.hot-links a:not(.button) {
	color: var(--red);
	font-weight: 600;
	text-transform: uppercase;
	text-decoration: none;
}

.hot-links a:hover {
	color: #fff;
}

.hot-links .button {
	border-radius: 20px;
	padding-left: 25px;
	padding-right: 25px;
}

.hot-links .button:hover {
	background: #fff;
	color: var(--red);
}

.footer-nav {
	display: flex;
	width: 100%;
	float: left;
	margin-top: 40px;
	gap: 40px;
}

.footer-nav li {
	list-style: none;
	position: relative;
}

.footer-nav li:not(.title) {
	padding-left: 20px;
}

.footer-nav li:not(.title):before {
	content: '';
	position: absolute;
	left: 0;
	top: 10px;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 6px 0 6px 7px;
	border-color: transparent transparent transparent var(--red);
	transform: rotate(0deg);
	transition: .3s all ease-in-out;
}

.footer-nav li:hover:before {
	transform: translateX(3px);
}

.footer-nav strong {
	color: var(--red);
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 600;
	margin-bottom: 15px;
	display: block;
}

.footer-nav a {
	color: #fff;
	text-decoration: none;
	font-size: 13px;
	line-height: 2.5;
	transition: .3s all ease-in-out;
	border-bottom: 1px solid transparent;
}

.footer-nav a:hover {
	border-bottom: 1px solid #fff;
}

.footer-bottom {
	width: 100%;
	float: left;
	display: flex;
	justify-content: space-between;
	color: #fff;
}

.footer-bottom p {
	color: #fff;
	font-size: 13px;
}

.footer-bottom p a {
	color: #fff;
	text-decoration: none;
	border-bottom: 1px solid #fff;
}

.social-icons {
	display: flex;
	gap: 25px;
}

.social-icons a {
	transition: .3s all ease-in-out;
}

.social-icons a:hover {
	opacity: .5;
}

.detail {
	width: 100%;
	float: left;
	margin-top: 80px;
	padding-top: 100px;
	min-height: 500px;
}

.drobeckova {
	font-size: 13px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.drobeckova a {
	color: var(--red);
	text-underline-offset: 3px;
}

.drobeckova strong {
	font-weight: normal;
}

.image-holder {
	width: 100%;
	float: left;
	position: relative;
}

.image-holder .images {
	width: 100%;
	float: left;
	display: flex;
	gap: 15px;
	flex-wrap: wrap;
}

.image-holder .images .image {
	width: 50%;
	background-size: 80%;
	background-repeat: no-repeat;
	background-position: center center;
	cursor: zoom-in;
	background-color: #fff;
	flex-basis: calc(20% - 7.5px);
	border: 1px solid var(--light);
}

.image-holder .images .image:first-child {
	width: 100%;
	min-width: 100%;
	background-size: 50%;
}

.image-holder .image::before {
	content: '';
	padding-top: 100%;
	display: block;
}

.price-detail-box {
	width: 100%;
	border-radius: 23px;
	float: left;
	border: 1px solid var(--light);
	overflow: clip;
	transition: .3s all ease-in-out;
}

.price-detail-box.shadow {
	box-shadow: 0 0 250px rgba(0,0,0,.3);
}

.price-detail-box__tabs {
	width: 100%;
	display: flex;
	height: 130px;
	float: left;
}

.pdb-tab {
	width: 100%;
	height: 130px;
	box-sizing: border-box;
	padding: 15px;
	display: flex;
	justify-content: center;
	justify-items: center;
	align-content: center;
	align-items: center;
	background: var(--light);
	border-right: 1px solid #fff;
	cursor: pointer;
	position: relative;
}

.not-sell:before {
	content: 'Produkt nelze zakoupit po 1 ks';
	position: absolute;
	font-size: 12px;
	background: var(--red);
	color: #fff;
	padding: 7px 14px;
	border-radius: 20px;
	pointer-events: none;
	opacity: 0;
	transition: .3s all ease-in-out;
}

.pdb-tab:hover:before {
	opacity: 1;
}

.pdb-tab.active {
	background: #fff;
}

.pdb-tab.active strong,
.pdb-tab.active small:nth-child(3) {
	color: var(--green);
}

.pdb-tab strong {
	font-size: 24px;
}

.pdb-tab small:nth-child(3) {
	display: block;
}

.pdb-tab small:nth-child(1) {
	margin-bottom: 5px;
	display: block;
}

.pdb-wrapper {
	width: 100%;
	float: left;
	box-sizing: border-box;
	padding: 10px;
	background: #fff;
}

.detail form {
	width: 100%;
}

.detail form input,
.detail form select,
.detail form button {
	height: 60px;
	box-sizing: border-box;
	border: 1px solid var(--gray);
	appearance: none;
	-webkit-appearance: none;
	outline: none !important;
	padding: 10px;
	background: #fff;
	border-right: 0;
}

.detail form input {
	font-size: 15px;
	font-weight: bold;
	width: 170px;
	border-radius: 0;
}

.detail form select {
	width: 230px;
	font-size: 15px;
	cursor: pointer;
	border-radius: 0;
	color: #000;
	font-weight: bold;
	background: #fff url('../img/ico-arrow-green.svg') no-repeat right 0px center / 40px;
}

.detail form button {
	width: calc(100% - 370px);
	background: var(--green) url('../img/ico-kosik-white.svg') no-repeat left 30px center / 40px;
	border-color: var(--green);
	cursor: pointer;
	padding-right: 50px;
	padding-left: 80px;
	border-radius: 0 30px 30px 0 !important;
}

.detail form button:hover {
	background: var(--blue) url('../img/ico-kosik-white.svg') no-repeat left 30px center / 40px;
	border-color: var(--blue);
}

form.form {
	
}

form.form .button {
	border: 0;
	cursor: pointer;
}

form.form label {
	width: 100%;
	display: block;
	font-weight: bold;
	font-size: 16px;
	margin-bottom: 5px;
}

form.form input {
	width: 100%;
	max-width: 340px;
	height: 45px;
	line-height: 45px;
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	margin-bottom: 15px;
	background: #fff;
	border: 1px solid var(--gray);
	appearance: none;
	-webkit-appearance: none;
	outline: none !important;
	border-radius: 9px;
	transition: .3s all ease-in-out;
}

form.form input:focus {
	border-color: var(--blue);
	outline: 0;
	box-shadow: 0 0 0 .2rem rgba(15, 41, 85, .2);
}

.columns {
	display: flex;
	gap: 10px;
}

.qty-holder {
	position: absolute;
	right: 15px;
	top: 0;
	bottom: 0;
	margin: auto;
	height: 23px;
	display: flex;
	gap: 13px;
	color: var(--green);
	font-weight: bold;
}

.qty-holder span {
	cursor: pointer;
}

.color-blue {
	color: var(--blue);
}

.circle-info {
	width: 24px;
	height: 24px;
	display: inline-block;
	margin-right: 10px;
	border-radius: 100%;
}

.circle__check {
	background: var(--green) url('../img/check.svg') no-repeat center center / contain;
}

.circle__none {
	background: var(--red) url('../img/none.svg') no-repeat center center / contain;
}

.link {
	color: var(--red);
	text-underline-offset: 3px;
}

.padding {
	padding: 25px;
}

.section-blue {
	background: var(--light);
}

.our-brand {
	width: 100%;
	float: left;
	margin-top: 50px;
}

.justify-center {
	justify-content: center;
}

.floating-cup {
	width: 150px;
	height: 175px;
	position: relative;
	animation: floating 3s ease-in-out infinite;
	background: url('../img/kelimek.webp') no-repeat center center / contain;
	z-index: 1;
}

.floating-cup:after {
	width: 100px;
	height: 30px;
	background: rgba(0,0,0,.6);
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	bottom: -50px;
	z-index: -1;
	filter: blur(20px);
	animation: floatingScale 3s ease-in-out infinite;
}

table {
	width: 90%;
	border-collapse: collapse;
}

table td {
	border-top: 1px solid var(--light);
	border-bottom: 1px solid var(--light);
	padding: 7px 25px;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield !important;
}

.total_price {
	width: 22px;
	height: 22px;
	line-height: 22px;
	text-align: center;
	font-size: 12px;
	background: var(--green);
	color: #fff;
	right: 10px;
	top: 10px;
	border-radius: 100%;
	position: absolute;
	font-weight: normal;
}

.pagination {
	width: 100%;
	float: left;
	clear: both;
	display: flex;
	list-style: none;
	padding: 0;
	gap: 5px;
	justify-content: center;
}

.pagination a {
	display: block;
	width: 35px;
	height: 35px;
	line-height: 35px;
	border: 1px solid #fff;
	text-align: center;
	text-decoration: none;
	color: #6b6b6b;
	border-radius: 100%;
	transition: .3s all ease-in-out;
}

.pagination li {
	color: #fff;
}

.pagination li.active a,
.pagination a:hover {
	border-color: #ececec;
}

.pagination .prev a,
.pagination .next a {
	background: var(--red);
}

.pagination .prev a,
.pagination .next a {
	background-image: url('../img/arrow-right-white.svg');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 30px;
}

.pagination .prev a {
	transform: rotate(-180deg);
	margin-right: 25px;
}

.pagination .next a {
	margin-left: 25px;
}

.product-info-price {
	min-width: 120px;
	box-sizing: border-box;
	padding-left: 15px;
	text-align: right;
}

.product-info-price small {
	display: block;
	opacity: .4;
}

#results {
	position: absolute;
	left: -1px;
	width: 100%;
	display: block;
	top: 68px;
	background: #fff;
	z-index: 100;
	border: 1px solid var(--light);
	border-top: 0;
	box-shadow: 0 30px 30px rgba(0,0,0,.24);
}

#results a {
	display: block;
	text-decoration: none;
	box-sizing: border-box;
	padding: 10px;
	background: #fff;
	color: #6b6b6b;
	border-bottom: 1px solid var(--light);
	transition: .3s all ease-in-out;
}

#results a:last-child {
	border-bottom: 0;
}

#results a:hover {
	background: #f3f3f3;
}

.message {
	width: calc(100% - 20px);
	box-sizing: border-box;
	padding: 15px;
	text-align: center;
	display: flex;
	justify-content: center;
	justify-items: center;
	align-content: center;
	align-items: center;
	border-radius: 25px;
	margin: 20px 0;
}

.message.error {
	background: #f8d7da;
	color: #58151c;
}

.message.success {
	background: #d1e7dd;
	color: #456a59;
}

.wedding {
	display: block flex;
	justify-content: center;
	justify-items: center;
	align-content: center;
	align-items: center;
	color: #fff;
	text-align: center;
	text-decoration: none;
	background: url('../uploads/banner-wedding.webp') no-repeat center center / cover;
	width: 100%;
	margin: 50px 0;
	position: relative;
	aspect-ratio: 21/9;
}

.wedding h3 {
	font-size: 32px;
}

.wedding p {
	max-width: 455px;
	color: #fff;
}

.abs {
	position: absolute;
}

.abs-bottom {
	bottom: 15px;
}

.detail-product {
	position: relative;
}

.basket-box {
	width: 100%;
	float: left;
	margin-top: 40px;
	border: 1px solid #e6ebf2;
	background: #ffffff;
	padding: 15px 24px 24px 24px;
}

.steps {
	display: flex;
	gap: 30px;
}

.step {
	display: flex;
	gap: 10px;
	align-content: center;
	align-items: center;
	color: var(--grayBlue);
}

.step span {
	display: block;
	width: 35px;
	height: 35px;
	line-height: 35px;
	border-radius: 100%;
	background: var(--grayBlue);
	color: var(--blue);
	font-weight: bold;
	text-align: center;
}

.step.active {
	color: #fff;
}

.step.active span {
	background: #fff;
	color: var(--red);
}

.helpdesk {
	position: fixed;
	z-index: 1000;
	bottom: 20px;
	right: 20px;
	cursor: pointer;
}

.helpdesk--image {
	width: 150px;
	height: 150px;
	background: url('../uploads/helpdesk/helpdesk.webp') no-repeat center center / contain;
}

.helpdesk--name {
	display: inline-block;
	background: var(--red);
	color: #fff;
	padding: 10px 16px;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	border-radius: 20px 20px 20px 0px;
	transform: scale(0);
	transform-origin: right;
	transition: .3s all ease-in-out;
	position: absolute;
	width: 160px;
	right: 120px;
	text-align: center;
	top: 50px;
}

.helpdesk--name:hover {
	background: var(--blue);
	border-radius: 20px 20px 20px 0px;
}

.helpdesk:hover .helpdesk--name {
	transform: scale(1);
}

.article p {
	line-height: 2;
}

.article li {
	line-height: 2;
	color: #6b6b6b;
}

p a,
li a {
	font: inherit;
	text-underline-offset: 2px;
	color: var(--red);
}

.article ul li::marker {
	color: var(--red);
}

.article ol li {
	margin-bottom: 10px;
}

.article h1 {
	color: var(--blue);
}

.article h2 {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.4375;
	color: var(--red);
	margin: 56px 0 24px;
}

.basket--certification--grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(206px, 1fr));
	grid-gap: 75px;
	margin: 95px 0;
}

.basket--certification--box {
	position: relative;
}

.basket--certification--box::before {
	content: "";
	position: absolute;
	top: -17px;
	left: -15px;
	right: 27px;
	height: 221px;
	background: #F5F6F9;
}

.basket--certification--grid img {
	display: block;
	max-width: 100%;
	height: auto;
	border-style: none;
	position: relative;
}

.basket--certification--footer {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	justify-content: space-between;
	margin: 12px 0;
}

.basket--certification--footer a {
	color: var(--red);
}

.contact--wrap {
  display:-webkit-box;
  display:flex;
  margin:24px 0 0 0
}

.contact--content {
  -webkit-box-flex:1;
  flex:1 1 100%
}

.contact--box {
  border:24px solid #f5f6f9;
  background:#f5f6f9
}

.row {
	display: flex;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	justify-content: center;
	margin: -12px;
}

.contact--box--inside h3 {
	margin-bottom: 0;
}

.contact--block h4 {
	margin: 0;
	margin-top: 20px;
}

.contact--block .col--3 {
	width: 33.333%;
	box-sizing: border-box;
}


.col {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column;
  box-sizing: border-box;
  padding: 0 12px;
}

.contact--box--inside {
  border:.063rem solid #e6ebf2;
  background:#ffffff;
  padding:15px 24px;
  margin:0 0 24px 0
}

.contact--box--inside p {
	font-size: 13px;
}

.contact--box--inside:last-child {
  margin:0
}

.contact--box--pointer {
  position:relative
}

.contact--box--pointer:before {
  position:absolute;
  content:'';
  width:110px;
  height:110px;
  right:-35px;
  top:-6px;
  background:url('../img/pointer-contact.svg') no-repeat center center;
  background-size:contain
}

.contact--block--headline {
  color:#d5202f
}

.contact--side {
  -webkit-box-flex:0;
  flex:0 0 337px;
  margin:0 0 0 24px
}

.contact--mini-map {
  position:relative;
  width:143px;
  height:123px
}

.contact--mini-map:hover:before {
  opacity:1
}

.contact--mini-map:before {
  position:absolute;
  content:'';
  width:100%;
  height:100%;
  top:0;
  left:0;
  background:#d5202f;
  opacity:.75;
  z-index:1;
  -webkit-transition:all 300ms ease;
  transition:all 300ms ease
}

.contact--mini-map--text {
  position:absolute;
  top:50%;
  left:50%;
  -webkit-transform:translate(-50%, -50%);
  transform:translate(-50%, -50%);
  color:#ffffff;
  font-size:.75rem;
  font-weight:700;
  line-height:1.5;
  text-decoration:underline;
  width:90%;
  z-index:1;
  text-align:center
}

.contact--mini-map--img {
  position:absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
  -o-object-fit:cover;
  object-fit:cover
}

.contact--mini-map--1:before {
  background:#021656
}

@media (max-width:959px) {
  .contact--side {
	-webkit-box-flex:0;
	flex:0 0 240px;
	max-width:240px;
	margin:0 0 0 16px
  }
  
  .contact--box {
	border-width:12px
  }
  
  .contact--box--inside {
	padding:12px
  }
}
@media (max-width:666px) {
  .contact--wrap {
	-webkit-box-orient:vertical;
	-webkit-box-direction:normal;
	flex-direction:column
  }
  
  .contact--side {
	-webkit-box-flex:0;
	flex:0 1 100%;
	width:100%;
	max-width:100%;
	margin:0 0 24px 0;
	-webkit-box-ordinal-group:0;
	order:-1
  }
}