:root {
	--safe-area-inset-top: env(safe-area-inset-top, 0px);
	--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);
	--safe-area-inset-left: env(safe-area-inset-left, 0px);
	--safe-area-inset-right: env(safe-area-inset-right, 0px);

	--conttainer-size: 96rem;
	--navbar-height: calc(var(--safe-area-inset-top) + 3.5rem);
	--product-card-base-size: 10rem;
}

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

*:focus,
*:active {
	outline: none;
	-webkit-tap-highlight-color: rgb(255, 255, 255, 0);
}

::selection {
	background-color: rgb(255, 173, 0, 0.6);
	color: #101014;
}

* {
	scrollbar-color: #dddde3 transparent;
	scrollbar-width: thin;
}

html {
	scrollbar-color: #fff #101014;
}

html {
	font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
	tab-size: 4;
}

body {
	margin: 0;
}

body,
html {
	min-height: 100vh;
	min-height: 100dvh;
}

body {
	font: 0.875rem/1.5 Rubik, sans-serif;
	color: #101014;
	background-color: #101014;
	letter-spacing: 0.25px;
	overflow: hidden scroll;
	-webkit-overflow-scrolling: touch;
	-webkit-text-size-adjust: none;
}

/* ------------------------------------------------ */

code,
kbd,
samp,
pre {
	font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
	font-size: 1em;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

table {
	border-color: currentcolor;
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

legend {
	padding: 0;
}

progress {
	vertical-align: baseline;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

summary {
	display: list-item;
}

/* ------------------------------------------------ */

a,
a:visited {
	font-weight: 600;
	text-decoration: none;
	color: #008dfd;
	transition: color 0.25s ease-out, border-color 0.25s ease-out, background-color 0.25s ease-out;
}

b,
strong {
	font-weight: 600;
}

small {
	font-size: 0.875em;
}

big {
	font-size: 1.25em;
}

abbr {
	cursor: help;
}

cite {
	color: rgb(0, 0, 0, 0.6);
}

mark {
	background-color: #ffe082;
	color: rgb(0, 0, 0, 0.9);
	font-size: 0.875em;
	padding: 0.1rem 0.5rem;
	border-radius: 0.25rem;
}

code,
var,
kbd,
pre,
samp {
	font-family: Monaco, Consolas, "Courier New", Courier, monospace;
	font-size: 0.875em;
	padding: 0.1rem 0.5rem;
	margin: 0px 0.1rem;
	font-weight: 600;
}

code,
var {
	color: rgb(0, 0, 0, 0.5);
	background-color: #dddde3;
	line-height: normal;
	display: inline-block;
	font-style: normal;
	border-radius: 0.25rem;
}

code {
	color: #101014;
}

kbd {
	background-color: rgb(0, 0, 0, 0.9);
	color: #ffffff;
	border-radius: 0.25rem;
}

samp {
	background-color: #0152af;
	color: rgb(255, 255, 255, 0.9);
	border-radius: 0.25rem;
}

pre {
	font-weight: normal;
	background-color: #101014;
	color: rgb(255, 255, 255, 0.7);
	max-width: 100%;
	tab-size: 4;
	line-height: 1.75;
	white-space: pre-wrap;
	word-wrap: break-word;
	padding: 1.25rem 2.5rem;
	border-radius: 0.25rem;
}

pre code {
	color: inherit;
	background-color: transparent;
	border-radius: 0px;
	font-weight: normal;
	margin: 0px;
	padding: 0px;
	font-size: 1em;
}

blockquote {
	padding: 1rem;
	border-left: 0.25rem solid #dddde3;
}

blockquote cite {
	font-weight: 600;
	font-style: normal;
	color: #101014;
}

ol,
ul {
	padding: 0px 0px 0px 1.25rem;
}

ol li,
ul li {
	padding-left: 0.5rem;
}

li + li {
	margin-top: 0.5rem;
}

dl dl,
ol ol,
ul ul,
ol ul,
ul ol {
	margin-bottom: 0px;
}

dt {
	font-weight: 600;
}

dd {
	margin-left: 2rem;
	position: relative;
}

dd::before {
	content: "- ";
	margin-left: -1rem;
	font-weight: 600;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 700;
	margin: 2rem 0px 1.25rem;
	padding: 0px;
	font-family: Rubik, sans-serif;
}

h1 {
	font-size: 2.5rem;
	line-height: 1.25;
}

h2 {
	font-size: 2rem;
	line-height: 1.25;
}

h3 {
	font-size: 1.75rem;
	line-height: 1.25;
}

h4 {
	font-size: 1.5rem;
	line-height: 1.25;
}

h5 {
	font-size: 1.25rem;
}

h6 {
	font-size: 1rem;
}

h1 + h2,
h2 + h3,
h3 + h4,
h4 + h5,
h5 + h6 {
	margin-top: 1.5rem;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
	color: currentColor;
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child {
	margin-top: 0px;
}

hr {
	box-sizing: content-box;
	overflow: visible;
	margin: 2.125rem auto;
	border: none;
	max-width: 50%;
	height: 0.125rem;
	background-color: #dddde3;
}

figure {
	margin: 0px 0px 1.5rem;
}

figure figcaption {
	text-align: center;
	margin-top: 1rem;
	color: #808080;
}

img {
	font-size: 0px;
	vertical-align: middle;
	border-style: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

img,
iframe {
	display: block;
	border: none;
	margin: 0;
	max-width: 100%;
}

svg {
	vertical-align: middle;
	width: 1.5rem;
	height: 1.5rem;
	flex-shrink: 0;
	fill: currentColor;
	transition: fill 0.25s ease-out;
}

svg[width][height] {
	width: auto;
	height: auto;
}

table {
	width: 100%;
	max-width: 100%;
	border: 1px solid #dddde3;
	border-collapse: collapse;
}

table caption {
	text-align: inherit;
	font-weight: 600;
}

table th {
	font-weight: 600;
}

table th,
table td {
	text-align: inherit;
	vertical-align: top;
	padding: 0.5rem 1rem;
	border: 1px solid #dddde3;
}

p:last-child,
p:last-of-type {
	margin-bottom: 0px;
}

p,
ol,
ul,
dl,
address,
blockquote,
pre,
table,
table caption {
	margin: 0px 0px 1.5rem;
}

/* ------------------------------------------------ */

#wrap {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	min-height: 100dvh;
	width: 100%;
	flex: 0 0 100%;
	margin: 0px auto;
	padding-top: 3.5rem;
	background-color: #101014;
}

#wrap .corners-top {
	position: fixed;
	top: var(--navbar-height);
	left: 0;
	right: 0;
	height: 1rem;
	overflow: hidden;
	z-index: 1;
	pointer-events: none;
}

#wrap .corners-top::before {
	position: absolute;
	inset: 0 0.25rem auto 0.25rem;
	content: "";
	height: 1.5rem;
	border-radius: 1rem 1rem 0 0;
	box-shadow: 0 0 0 1rem #101014;
}

#wrap .corners-bottom {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	height: calc(var(--safe-area-inset-bottom) + 1.25rem);
	overflow: hidden;
	z-index: 1;
	pointer-events: none;
}

#wrap .corners-bottom::before {
	position: absolute;
	inset: auto 0.25rem calc(var(--safe-area-inset-bottom) + 0.25rem) 0.25rem;
	height: calc(var(--safe-area-inset-bottom) + 1.5rem);
	content: "";
	border-radius: 0 0 1rem 1rem;
	box-shadow: 0 0 0 calc(var(--safe-area-inset-bottom) + 1rem) #101014;
}

/* ------------------------------------------------ */

.mobile-nav {
	width: 100%;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: fixed;
	top: 0px;
	z-index: 20;
	background-color: #101014;
	padding: 1rem calc(var(--safe-area-inset-right) + 0.5rem) 1rem calc(var(--safe-area-inset-left) + 0.5rem);
	margin: 0px;
	height: var(--navbar-height);
	border: none;
}

.mobile-nav .btn,
.mobile-nav a {
	color: rgb(255, 255, 255, 0.6);
	position: relative;
	cursor: pointer;
}

.mobile-nav .logo {
	padding: 0px 2rem;
	display: flex;
	align-items: center;
	height: 100%;
}

.mobile-nav .logo a {
	display: flex;
	align-items: center;
	height: 100%;
}

.mobile-nav .logo img {
	max-height: 1rem;
	width: 100%;
	height: 100%;
}

.header .is-cart [data-counter]::before,
.mobile-nav .is-cart-btn[data-counter]::before {
	content: attr(data-counter);
	background-color: #ffad00;
	color: #101014;
	border-radius: 100rem;
	font-size: 0.75rem;
	min-width: 1.125rem;
	height: 1.125rem;
	padding: 0px 0.25rem;
	line-height: 1;
	font-weight: 600;
	letter-spacing: -0.125px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 1;
	right: -0.375rem;
	bottom: 0.25rem;
	transition: box-shadow 0.25s ease-out;
	box-shadow: 0px 0px 0px 3px #ffffff;
}

.header .is-cart [data-counter="0"]::before,
.mobile-nav .is-cart-btn[data-counter="0"]::before {
	display: none;
}

.mobile-nav .is-cart-btn[data-counter]::before {
	box-shadow: 0px 0px 0px 3px #101014;
	right: 0.25rem;
	bottom: 0.375rem;
}

.mobile-nav .corners {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	height: 1rem;
	overflow: hidden;
	pointer-events: none;
}

.overlay {
	position: fixed;
	background-color: rgb(0, 0, 0, 0.8);
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	width: 100vw;
	height: 100vh;
	height: 100dvh;
	z-index: -100;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s ease-out;
}

/* ------------------------------------------------ */

.header {
	position: fixed;
	overflow: hidden auto;
	z-index: -100;
	top: 0;
	left: var(--safe-area-inset-left, 0px);
	visibility: hidden;
	transform: translateX(-150%);
	background-color: #ffffff;
	border: none;
	margin: 0.75rem;
	height: calc(100vh - 1.5rem);
	height: calc(100dvh - 1.5rem);
	border-radius: 1rem;
	min-width: 16rem;
	width: calc(100vw - 5rem);
	max-width: 20rem;
	box-shadow: 0px 1rem 3rem rgb(0, 0, 0, 0.06);
	transition: transform 0.25s ease-out;
}

.header .wrapper {
	height: auto;
	min-height: calc(100vh - 4.5rem);
	min-height: calc(100dvh - 4.5rem);
	display: flex;
	width: 100%;
	align-items: center;
	flex-direction: column;
	text-align: right;
	padding: 0px 1.5rem;
	margin: 1.5rem 0px;
}

.header .logo {
	font-size: 1.5rem;
	color: #101014;
	display: flex;
	align-items: center;
	width: 100%;
}
.header .logo a {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
}
.header .logo img {
	width: 80%;
	height: auto;
	margin: 0px auto;
}

.header .navigation {
	padding: 2rem 0px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	margin: auto 0px;
}

.header .navigation ul {
	display: flex;
	flex-direction: column;
	padding: 0px;
	margin: 0px;
	width: 100%;
	text-transform: uppercase;
}

.header .navigation ul li {
	padding: 0px;
	margin: 0px;
	list-style: none;
	font-size: 0.875rem;
}

.header .navigation ul li + li {
	border-top: 1px solid #dddde3;
}

.header .navigation ul li a {
	color: #101014;
	font-weight: 600;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0.5rem 0px;
}

.header .navigation ul li a span {
	width: 2rem;
	height: 2rem;
	background-color: #101014;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	flex-shrink: 0;
	border-radius: 100rem;
	margin-left: 1rem;
	transition: box-shadow 0.25s ease-out, background-color 0.25s ease-out;
	box-shadow: 0px 0.125rem 0.25rem rgb(0, 0, 0, 0.1);
}

.header .navigation ul li a span svg {
	width: 1.25rem;
	height: 1.25rem;
}

.header .navigation .is-youtube {
	color: #f91736;
}

.header .navigation .is-youtube span {
	background-color: #f91736;
}

.header .info {
	text-align: right;
	width: 100%;
}

.header .contacts a {
	font-size: 1rem;
	display: inline-block;
	margin-bottom: 0.5rem;
}

.header .social {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	text-align: right;
	margin-top: 1.5rem;
}

.header .social a {
	background-color: #101014;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	border-radius: 100rem;
	width: 2rem;
	height: 2rem;
	transition: box-shadow 0.25s ease-out, background-color 0.25s ease-out;
	box-shadow: 0px 0.125rem 0.25rem rgb(0, 0, 0, 0.1);
}

.header .social a + a {
	margin-left: 0.75rem;
}

.header .social svg {
	width: 1.25rem;
	height: 1.25rem;
	color: #ffffff;
}

.menu-visible .header {
	z-index: 100;
	visibility: visible;
	transform: translateX(0px);
}

.menu-visible .header {
	z-index: 100;
	visibility: visible;
	transform: translateX(0px);
}

.menu-hidden .header {
	transform: translateX(-150%);
}

.menu-visible .overlay {
	visibility: visible;
	opacity: 1;
	z-index: 30;
}

.menu-hidden .overlay {
	opacity: 0;
}

/* ------------------------------------------------ */

.main {
	flex-grow: 1;
	margin: 0px 0.25rem var(--bottom-offset, 0px) 0.25rem;
	position: relative;
	z-index: 1;
	background-color: #101014;
	display: flex;
	flex-direction: column;
}

.main .heading {
	font-size: 1rem;
	margin: 0 0 1.75rem;
	font-weight: 700;
	border-bottom: 3px solid currentcolor;
	padding-bottom: 0.375rem;
}

.main .banner {
	background-color: #101014;
	background-image: url("/assets/images/logo.svg"), url("/assets/images/banner.png");
	background-position: top 1.25rem right 1.25rem, center left;
	background-size: 6rem, cover;
	background-repeat: no-repeat;
	color: #ffffff;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	height: 14rem;
	border-radius: 0.75rem;
	padding: 1.25rem;
	overflow: hidden;
}

.main .banner .banner-title {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 0.125rem;
	text-wrap: balance;
}

.main .banner .banner-subtitle {
	font-weight: 600;
}

/* ------------------------------------------------ */

.empty {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 2rem;
	gap: 1.5rem;
	font-size: 1rem;
	max-width: 40rem;
	margin: auto;
}

.empty svg {
	width: 5rem;
	height: 5rem;
}

.empty .title {
	color: #101014;
	margin: 0px 0px -1.25rem 0px;
	font-weight: 700;
	font-size: 1.5rem;
}

.empty .description {
	text-wrap: balance;
	color: rgb(16, 16, 20, 60%);
}

.page {
	padding: 1rem calc(var(--safe-area-inset-right) + 1rem) 1rem calc(var(--safe-area-inset-left) + 1rem);
	background-color: #ffffff;
	border-radius: 1rem;
	min-height: calc(100vh - var(--navbar-height) - 0.25rem);
	min-height: calc(100svh - var(--navbar-height) - 0.25rem);
	display: flex;
	flex-direction: column;
	width: 100%;
	gap: 2rem;
}

.page .page-info {
	order: 1;
}

.page .page-info h1 {
	font-size: 1.25rem;
	margin: 0 0 1.75rem;
	border-bottom: 3px solid currentcolor;
	padding-bottom: 0.375rem;
}

.page-header {
	margin: 0 -1.25rem -2rem -1.25rem;
	position: relative;
	top: -1.25rem;
	text-transform: none;
	padding: 1.25rem;
	max-width: 100vw;
	overflow: hidden;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
}

.page-header::before {
	content: "";
	position: absolute;
	left: 1.5rem;
	right: 1.5rem;
	bottom: 0px;
	border-top: 1px solid #dddde3;
}

.page-header h1 {
	text-wrap: balance;
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
}

.page-content {
	font-size: 1rem;
}

/* ------------------------------------------------ */

.footer {
	margin: 0px;
	padding: 2rem 1.5rem 1.5rem 1.5rem;
	color: rgb(255, 255, 255, 0.4);
	border: none;
	display: flex;
	text-align: center;
	flex-direction: column-reverse;
	position: fixed;
	z-index: 0;
	bottom: 0px;
	width: 100%;
}

.footer a {
	color: #ffffff;
	font-weight: 600;
}

.footer .navigation {
	margin-bottom: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.footer .info {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-direction: column-reverse;
}

.footer .copyright {
	display: flex;
	align-items: center;
}

.footer .copyright svg {
	margin-right: 0.5rem;
}

/* ------------------------------------------------ */

.categories-list {
	display: flex;
	overflow: auto hidden;
	margin: -0.5rem -1rem;
	padding: 0 calc(var(--safe-area-inset-right) + 1rem) 0.5rem calc(var(--safe-area-inset-left) + 1rem);
}

.categories-list ul {
	display: flex;
	gap: 0.5rem;
	list-style: none;
	padding: 0;
	margin: 0 auto;
}

.categories-list ul li {
	padding: 0;
	margin: 0;
	white-space: nowrap;
}

.categories-list ul li a {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 0.375rem 1rem;
	background-color: rgb(16, 16, 20, 10%);
	color: #101014;
	font-weight: 600;
	line-height: 1;
	height: 2rem;
	font-size: 0.875rem;
	border-radius: 100rem;
	transition: background-color 0.25s ease-out, color 0.25s ease-out;
}

.categories-list ul li.is-active a {
	color: #ffffff;
	background-color: #101014;
}

/* ------------------------------------------------ */

.products-items ul {
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(auto-fill, minmax(var(--product-card-base-size), 1fr));
	padding: 0px;
	margin: 0px;
	align-content: flex-start;
	box-shadow: 0 0 0 1px #dddde3;
	overflow: hidden;
	list-style: none;
	border-radius: 0.75rem;
}

.products-items li {
	margin: 0px;
	padding: 1rem;
	display: flex;
	gap: 0.75rem;
	flex-direction: column;
	position: relative;
	box-shadow: 0 0 0 1px #dddde3;
}

.products-items li::before {
	position: absolute;
	inset: 0;
	border-radius: 0.75rem;
	content: "";
	z-index: 1;
	pointer-events: none;
	opacity: 0;
	box-shadow: inset 0px 0px 0px 3px #101014;
	transition: opacity 0.25s ease-out;
}

.products-items.is-scrolled {
	display: flex;
	overflow: auto hidden;
	margin: 0 -1rem;
	padding: 0 1rem;
}

.products-items.is-scrolled ul {
	display: flex;
	padding: 1px;
	overflow: unset;
	border-radius: unset;
	box-shadow: none;
}

.products-items.is-scrolled li {
	flex: 0 0 calc(var(--product-card-base-size) - 0.5rem);
}

.products-items.is-scrolled li:first-child {
	border-radius: 0.75rem 0 0 0.75rem;
}

.products-items.is-scrolled li:last-child {
	border-radius: 0 0.75rem 0.75rem 0;
}

.products-items li .picture {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 0;
	aspect-ratio: 1 / 1;
	border-radius: 0.375rem;
	overflow: hidden;
}

.products-items li .picture svg {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 0;
	transform: translate(-50%, -50%);
	width: 50%;
	height: 50%;
	pointer-events: none;
	opacity: 0.1;
}

.products-items li a {
	color: #101014;
}

.products-items li .info {
	text-align: left;
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.products-items li .title {
	font-size: 1rem;
	line-height: 1.25;
	color: #101014;
	font-weight: 700;
	display: block;
	text-wrap: balance;
}

.products-items li .tag {
	font-size: 0.75rem;
	font-weight: 500;
	line-height: 1.25;
	color: #008dfd;
}

/* ------------------------------------------------ */

.is-product-page .description {
	padding: 1rem 0;
}

.is-product-page h1.title {
	font-size: 1.5rem;
	text-wrap: balance;
	font-weight: 700;
	margin: 0 0 1.25rem;
}

.is-product-page .heading {
	margin: 0 0 1.25rem;
}

.is-product-page .page-content {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.is-product-page .page-content > .picture {
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 4 / 3;
	grid-column: 1/2;
	border-radius: 0.75rem;
	background-color: rgb(16, 16, 20, 0.04);
	max-height: 24rem;
}

.is-product-page .page-content > .picture svg {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 0;
	transform: translate(-50%, -50%);
	width: min(7rem, 50%);
	height: min(7rem, 50%);
	pointer-events: none;
	opacity: 0.1;
}

.is-product-page .product-carousel {
	position: relative;
	min-width: 0;
}

.is-product-page .product-carousel .zoom-picture {
	background-color: #101014;
	position: absolute;
	z-index: 1;
	top: 1rem;
	right: 1rem;
	font-weight: 700;
	border: none;
	border-radius: 100rem;
	padding: 0.25rem 0.75rem;
	color: #ffffff;
	font-size: 0.75rem;
	line-height: 1;
	display: flex;
	align-items: center;
	cursor: pointer;
	height: 1.75rem;
	box-shadow: 0 0 0.5rem 0.25rem #ffffff;
	transition: background-color 0.25s ease-out, color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.is-product-page .product-carousel .zoom-picture svg {
	width: 1.125rem;
	height: 1.125rem;
	margin: 0 0.25rem 0 -0.5rem;
}

.is-product-page .product-carousel .counter {
	background-color: #101014;
	position: absolute;
	z-index: 1;
	top: 1rem;
	left: 1rem;
	font-weight: bold;
	border-radius: 100rem;
	padding: 0.25rem 0.75rem;
	color: #ffffff;
	font-size: 0.75rem;
	line-height: 1;
	display: flex;
	align-items: center;
	gap: 0.25rem;
	height: 1.75rem;
	min-width: 3.875rem;
	box-shadow: 0 0 0.5rem 0.25rem #ffffff;
}

.is-product-page .product-carousel .counter::before {
	content: attr(data-current);
	display: inline;
}

.is-product-page .product-carousel .carousel {
	margin: -1rem -1rem 0;
}

.is-product-page .product-carousel .carousel-slide-inner {
	padding: 1rem;
}

.is-product-page .product-carousel .carousel-slide img {
	max-height: 30rem;
}

.is-product-page .product-carousel .carousel-thumbnails {
	position: relative;
	overflow: hidden;
	padding: 0 3.75rem;
	margin: 0 -1rem;
}

.is-product-page .product-carousel .carousel-thumbnails::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background-image: linear-gradient(
		to right,
		#ffffff 0.5rem,
		transparent 4rem,
		transparent calc(100% - 4rem),
		#ffffff calc(100% - 0.5rem)
	);
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-container {
	padding: 0.25rem 0;
	display: flex;
	margin-left: -0.75rem;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide {
	position: relative;
	min-width: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding-left: 0.75rem;
	flex: 0 0 auto;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide-inner {
	padding: 0.25rem;
	cursor: pointer;
	border: 1px solid #dddde3;
	background-color: #ffffff;
	border-radius: 0.375rem;
	width: 3.5rem;
	height: 3.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: border-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide-inner img {
	border-radius: 0.25rem;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide.is-selected .carousel-slide-inner {
	border-color: #ffffff;
	box-shadow: 0px 0px 0px 0.125rem #ffad00;
	position: relative;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide .carousel-slide-inner::before {
	content: "";
	position: absolute;
	z-index: 1;
	right: 0.125rem;
	bottom: 0.125rem;
	display: block;
	border: 0.375rem solid transparent;
	border-right: 0.375rem solid transparent;
	border-bottom: 0.375rem solid transparent;
	border-radius: 0.25rem;
	opacity: 0;
	transition: opacity 0.25s ease-out;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-slide.is-selected .carousel-slide-inner::before {
	border-right-color: #ffad00;
	border-bottom-color: #ffad00;
	opacity: 1;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-btn {
	position: absolute;
	top: 50%;
	padding: 0;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 100rem;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	background-color: #101014;
	color: #ffffff;
	border: none;
	z-index: 2;
	box-shadow: 0 0 0.5rem #ffffff;
	transition: transform 0.25s ease-out, color 0.25s ease-out, background-color 0.25s ease-out,
		box-shadow 0.25s ease-out;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-btn.prev--action {
	left: 1rem;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-btn.next--action {
	right: 1rem;
}

.is-product-page .product-carousel .carousel-thumbnails .carousel-btn svg {
	width: 1.125rem;
	height: 1.125rem;
	flex: 0 0 1.125rem;
}

.is-product-page .tabs .tabs-nav {
	display: flex;
	align-items: center;
	padding: 1rem;
	margin: -1rem -1rem -0.5rem -1rem;
	gap: 0.75rem;
	overflow: auto hidden;
	position: sticky;
	top: var(--navbar-height);
	border-bottom: 1px solid #dddde3;
	background-color: #ffffff;
}

/* ------------------------------------------------ */

.is-cart-page .cart-form-content {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.is-cart-page .cart-form-content .info {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.is-cart-page .cart-form-content .info .description {
	background-color: rgb(16, 16, 20, 10%);
	padding: 1rem;
	border-radius: 0.5rem;
	margin: 0;
}

.is-cart-page .in-cart-stats {
	display: none;
	flex-direction: column;
	gap: 1rem;
	position: sticky;
	bottom: 0;
	z-index: 2;
	left: 0;
	right: 0;
	padding: 1rem;
	margin: 0 -1rem -1rem -1rem;
	border-top: 1px solid #dddde3;
	background-color: #ffffff;
	border-radius: 0 0 1rem 1rem;
}

.is-cart-page .in-cart-stats .cart-stats {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	gap: 1rem;
}

.is-cart-page .in-cart-stats .cart-price {
	display: flex;
	gap: 0.75rem;
	align-items: center;
	line-height: 1;
}

.is-cart-page .in-cart-stats .cart-price svg {
	width: 1.75rem;
	height: 1.75rem;
}

.is-cart-page .in-cart-stats .cart-price .price {
	font-weight: 600;
	font-size: 1.25rem;
}

.is-cart-page .remove-from-cart .btn svg {
	width: 1.25rem;
	height: 1.25rem;
}

/* ------------------------------------------------ */

.is-blog-page .blog-posts {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.is-blog-page .blog-posts .blog-post {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.is-blog-page .blog-posts .blog-post + .blog-post {
	padding-top: 2rem;
	border-top: 1px solid #dddde3;
}

.is-blog-page .blog-posts .blog-post .picture {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 0;
	aspect-ratio: 1 / 1;
	border-radius: 0.75rem;
	overflow: hidden;
	background-color: rgb(16, 16, 20, 0.04);
	max-height: 16rem;
}

.is-blog-page .blog-posts .blog-post .picture svg {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 0;
	transform: translate(-50%, -50%);
	width: min(6rem, 50%);
	height: min(6rem, 50%);
	pointer-events: none;
	opacity: 0.1;
}

.is-blog-page .blog-posts .blog-post .picture img {
	border-radius: 0.375rem;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.is-blog-page .blog-posts .blog-post .post-title {
	margin: 0;
	font-size: 1.5rem;
	display: flex;
	gap: 1.25rem;
	font-weight: 600;
}

.is-blog-page .blog-posts .blog-post .post-title a {
	color: #101014;
}

.is-blog-page .blog-posts .blog-post .actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
}

.is-blog-page .blog-posts .blog-post .actions a {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-left: auto;
}

.is-blog-page iframe {
	margin: 0 auto;
}

/* ------------------------------------------------ */

.variants .variants-items {
	display: flex;
	flex-direction: column;
	list-style: none;
	padding: 0px;
	margin: 0px;
}

.variants .variants-items .variants-item {
	padding: 0px;
	margin: 0px;
	display: grid;
	grid-template-columns: 3.5rem auto auto;
	grid-template-rows: auto auto auto;
	gap: 1rem;
	align-items: flex-start;
}

.variants .variants-items .variants-item + .variants-item {
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid #dddde3;
}

.variants .variants-items .variants-item .picture {
	padding: 0.25rem;
	border: 1px solid #dddde3;
	background-color: #fff;
	border-radius: 0.375rem;
	height: auto;
	aspect-ratio: 1 / 1;
	grid-row: 1/3;
}

.variants .variants-items .variants-item .picture img {
	border-radius: 0.375rem;
}

.variants .variants-items .variants-item .alert {
	width: 100%;
}

.variants .variants-items .variants-item .title {
	line-height: 1.25;
	font-weight: 600;
	text-wrap: balance;
	grid-column: 2/4;
}

.variants .variants-items .variants-item .title a {
	color: #101014;
}

.variants .variants-items .variants-item .info {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	grid-column: 2/4;
}

.variants .variants-items .variants-item .info .specs {
	font-size: 0.875rem;
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	align-items: center;
	line-height: 1.375;
}

.variants .variants-items .variants-item .info .specs .specs-item {
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.variants .variants-items .variants-item .info .specs .specs-item + .specs-item {
	border-left: 1px solid #dddde3;
	margin-left: 1rem;
	padding-left: 1rem;
}

.variants .variants-items .variants-item .info .specs .specs-item.price {
	white-space: nowrap;
}

.variants .variants-items .variants-item .actions {
	grid-column: 1/4;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

/* ------------------------------------------------ */

.carousel {
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: hidden;
}

.carousel-container {
	display: flex;
	margin-left: -1.25rem;
	touch-action: pan-y pinch-zoom;
}

.carousel.is-draggable {
	cursor: move;
	cursor: grab;
}

.carousel .carousel-slide {
	position: relative;
	flex: 0 0 100%;
	min-width: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding-left: 1.25rem;
	transform: translate3d(0, 0, 0);
}

.carousel .carousel-slide img {
	border-radius: 0.75rem;
}

/* ------------------------------------------------ */

.tabs .tabs-nav {
	display: flex;
	align-items: center;
	padding: 0.25rem;
	margin: 0;
	gap: 0.75rem;
	overflow: auto hidden;
	position: sticky;
}

.tabs .tabs-nav + .tabs-content {
	margin-top: 1.25rem;
	font-size: 1rem;
}

.tabs .tabs-nav li {
	padding: 0.5rem 1rem;
	margin: 0px;
	flex: 1;
	list-style: none;
	text-align: center;
	cursor: pointer;
	white-space: nowrap;
	flex: 1;
	border-radius: 0.375rem;
	border: 1px solid #dddde3;
	transition: border-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.tabs .tabs-nav li a {
	color: #101014;
	display: block;
	font-weight: 600;
	font-size: 0.875rem;
}

.tabs .tabs-nav li.is-active {
	border-color: #ffffff;
	box-shadow: 0px 0px 0px 0.125rem #ffad00;
	position: relative;
}

.tabs .tabs-nav li::before {
	content: "";
	position: absolute;
	z-index: 1;
	right: 0.125rem;
	bottom: 0.125rem;
	display: block;
	border: 0.375rem solid transparent;
	border-right: 0.375rem solid transparent;
	border-bottom: 0.375rem solid transparent;
	border-radius: 0.25rem;
	opacity: 0;
	transition: opacity 0.25s ease-out;
}

.tabs .tabs-nav li.is-active::before {
	border-right-color: #ffad00;
	border-bottom-color: #ffad00;
	opacity: 1;
}

.tabs .tabs-content > div {
	scroll-margin-top: 8rem;
}

.tabs .tabs-content > div:not(.is-active) {
	display: none;
}

/* ------------------------------------------------ */

.pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
	margin-top: 4rem;
}

.pagination .current {
	font-weight: 700;
}

/* ------------------------------------------------ */

.alert {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 0.25rem 2.25rem;
	border-radius: 0.5rem;
	font-size: 0.75rem;
	font-weight: 500;
	min-height: 2.25rem;
	position: relative;
}

.alert svg {
	width: 1.25rem;
	height: 1.25rem;
	position: absolute;
	left: 0.5rem;
	top: 50%;
	transform: translateY(-50%);
	color: #ffffff;
}

.alert.is-info {
	border: 2px solid #008dfd;
}

.alert.is-info svg {
	fill: #008dfd;
}

.alert.is-warn {
	border: 2px solid #ffad00;
}

.alert.is-warn svg {
	fill: #ffad00;
}

.alert.is-danger {
	border: 2px solid #ff0000;
}

.alert.is-danger svg {
	fill: #ff0000;
}

.alert.is-success {
	border: 2px solid #00bb4f;
}

.alert.is-success svg {
	fill: #00bb4f;
}

/* ------------------------------------------------ */

a.btn,
.btn {
	display: inline-flex;
	overflow: hidden;
	align-items: center;
	justify-content: center;
	background-color: #101014;
	color: #ffffff;
	font-weight: bold;
	border: none;
	text-align: center;
	font-size: 0.875rem;
	text-transform: uppercase;
	line-height: normal;
	min-width: 2.75rem;
	height: 2.75rem;
	white-space: nowrap;
	padding: 0px 1.5rem;
	position: relative;
	user-select: none;
	cursor: pointer;
	border-radius: 100rem;
	transition: color 0.25s ease-out, background-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.btn span:first-of-type {
	display: block;
}

.btn span:last-of-type {
	display: none;
}

.btn.is-toggled span:first-of-type {
	display: none;
}

.btn.is-toggled span:last-of-type {
	display: block;
}

.btn.is-primary {
	background-color: #ffad00;
}

.btn.is-secondary {
	background-color: #008dfd;
}

.btn.is-success {
	background-color: #00bb4f;
}

.btn.is-danger {
	background-color: #ff0000;
}

a.btn.is-clear,
.btn.is-clear {
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	font-size: inherit;
	text-align: inherit;
	text-decoration: none;
	cursor: pointer;
	border-radius: 0;
}

.btn.with-icon {
	padding: 0px 1.5rem 0px 3rem;
}

.btn.with-icon > svg {
	flex: 0 0 1.75rem;
	margin: 0px;
	background-color: #ffffff;
	color: #101014;
	border-radius: 100rem;
	padding: 0.25rem;
	position: absolute;
	left: 0.5rem;
	width: 1.75rem;
	height: 1.75rem;
}

.btn.with-only-icon {
	padding: 0px;
}

.btn.with-spinner::before {
	content: "";
	flex: 0 0 1.75rem;
	margin: 0px;
	border-radius: 100rem;
	padding: 0.25rem;
	position: absolute;
	left: 1rem;
	width: 1.25rem;
	height: 1.25rem;
	border-radius: 50%;
	border: 0.125rem solid rgba(0, 0, 0, 0.2);
	border-top-color: #101014;
	background-color: #ffffff;
	box-shadow: 0px 0px 0px 0.25rem #ffffff;
	animation: spinner 0.6s linear infinite;
}

.btn.with-spinner svg {
	opacity: 0;
}

.btn.is-primary.with-spinner::before,
.btn.is-secondary.with-spinner::before {
	background-color: #101014;
	box-shadow: 0px 0px 0px 0.25rem #101014;
	border-color: rgba(255, 255, 255, 0.2);
	border-top-color: #ffffff;
}

a.btn.is-disabled,
.btn[disabled] {
	opacity: 0.5;
	pointer-events: none;
	background-color: #9f9fa1;
}

@keyframes spinner {
	to {
		transform: rotate(360deg);
	}
}

/* ------------------------------------------------ */

input,
select,
textarea,
button,
label {
	font: inherit;
	outline: none;
	text-decoration: none;
}

label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 600;
}

label[for] {
	cursor: pointer;
}

label span {
	color: #ff0000;
}

input,
select,
textarea {
	line-height: 1;
	padding: 0px 0.75rem;
	height: 2.375rem;
	display: block;
	background-color: #ffffff;
	border: 1px solid #dddde3;
	width: 100%;
	outline: none;
	position: relative;
	box-sizing: border-box;
	border-radius: 0.375rem;
	transition: border-color 0.25s ease-out, background-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

input:focus,
select:focus,
textarea:focus {
	border-color: #ffffff;
	box-shadow: 0px 0px 0px 2px #ffad00;
}

textarea {
	padding: 0.5rem 0.75rem;
	height: 7rem;
	line-height: 1.5;
	resize: vertical;
}

select {
	padding-right: 2.5rem;
	appearance: none;
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' fill='rgba(0, 0, 0, 0.3)' viewBox='0 0 24 24' width='24' height='24'%3e%3cpath d='M5.707,10.707l5.586,5.586c0.391,0.391,1.024,0.391,1.414,0l5.586-5.586C18.923,10.077,18.477,9,17.586,9H6.414 C5.523,9,5.077,10.077,5.707,10.707z'%3e%3c/path%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: right 0.75rem top 50%;
	background-size: 1rem 1rem;
}

input[readonly] {
	pointer-events: none;
}

.number-input {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 2.375rem;
	border: 1px solid #dddde3;
	position: relative;
	border-radius: 0.375rem;
	transition: border-color 0.25s ease-out, background-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.number-input:has(input:focus) {
	border-color: #ffffff;
	box-shadow: 0px 0px 0px 2px #ffad00;
}

.number-input::after {
	content: "";
	border-left: 1px solid #dddde3;
	display: block;
	height: 60%;
	position: absolute;
	left: 2.375rem;
	z-index: 0;
}

.number-input::before {
	content: "";
	border-right: 1px solid #dddde3;
	display: block;
	height: 60%;
	position: absolute;
	right: 2.375rem;
	z-index: 0;
}

.number-input input {
	text-align: center;
	padding: 0px;
	width: 2.75rem;
	height: 100%;
	line-height: inherit;
	background: none;
	border: none;
	margin: 0px;
	position: relative;
	z-index: 2;
	border: 1px solid transparent;
	appearance: textfield;
}

.number-input input:focus {
	box-shadow: none;
}

.number-input button {
	user-select: none;
	transition: background-color 0.25s ease-out;
	width: 2.375rem;
	height: 2.375rem;
	color: #101014;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	position: relative;
	z-index: 1;
	background: none;
	border: none;
	border-radius: 0.25rem;
	transition: border-color 0.25s ease-out, box-shadow 0.25s ease-out;
}

.number-input button:focus {
	box-shadow: 0px 0px 0px 0.1125rem #101014;
}

.number-input button > svg {
	width: 1rem;
	height: 1rem;
}

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

/* ------------------------------------------------ */

form {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

form .form-control {
	display: block;
	flex: 1;
}

form .form-group {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

form .description {
	font-size: 0.8125rem;
	margin: 0.5rem 0px 0px 0px;
	color: rgb(16, 16, 20, 60%);
	font-weight: 500;
	display: block;
}

.form-control .validate-error {
	margin-top: 0.25rem;
}

.validate-error span {
	background-color: #ff0000;
	color: #fff;
	padding: 0.25rem 0.5rem;
	border-radius: 0.375rem;
	font-weight: bold;
	font-size: 0.875em;
	line-height: 1.25;
	display: inline-flex;
	align-items: center;
}

.field-error {
	border-color: #ff0000 !important;
}

.field-error:focus {
	border-color: #fff !important;
	box-shadow: 0px 0px 0px 0.125rem #ff0000 !important;
}

/* ------------------------------------------------ */

.notify {
	position: fixed;
	max-width: 100vw;
	min-height: 2.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: #008dfd;
	color: #ffffff;
	border-radius: 100rem;
	z-index: 150;
	top: 0;
	left: 0.75rem;
	right: 0.75rem;
	padding: 0.5rem 2.5rem;
	box-shadow: 0px 0.125rem 0.5rem rgb(0, 0, 0, 0.1);
	transform: translateY(-100%);
	transition: transform 0.25s ease-out;
}

.notify.is-success-status {
	background-color: #00bb4f;
}

.notify.is-warning-status {
	background-color: #ffad00;
}

.notify.is-error-status {
	background-color: #ff0000;
}

.notify.is-active {
	transform: translateY(calc(var(--navbar-height) + 0.5rem));
}

.notify svg {
	position: absolute;
	left: 0.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1.5rem;
	height: 1.5rem;
	fill: #ffffff;
	color: #008dfd;
}

/* ------------------------------------------------ */

.cookie-accept {
	position: fixed;
	background-color: #101014;
	color: #ffffff;
	border-radius: 0.75rem;
	z-index: 100;
	right: 1.25rem;
	left: 1.25rem;
	padding: 1.25rem;
	gap: 1.25rem;
	bottom: calc(var(--safe-area-inset-bottom) + 1.25rem);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.cookie-accept .btn {
	align-self: flex-end;
}

.cookie-accept > svg {
	width: 8rem;
	height: 8rem;
	position: absolute;
	fill: rgb(255, 255, 255, 0.2);
	left: -2rem;
	bottom: -2rem;
}

@media only screen and (min-width: 640px) {
	:root {
		--product-card-base-size: 13rem;
	}
}

@media only screen and (min-width: 1025px) {
	body {
		background-color: #101014;
		padding: 0 0.5rem;
	}

	#wrap {
		padding-top: 0;
		padding-left: 20rem;
		padding-bottom: 3rem;
		background-color: #fff;
	}

	#wrap .corners-top {
		top: 0;
		height: 1.5rem;
	}

	#wrap .corners-top::before {
		inset: 0.5rem 0.5rem auto 0.5rem;
	}

	#wrap .corners-bottom {
		bottom: 3rem;
		height: 1rem;
	}

	#wrap .corners-bottom::before {
		inset: auto 0.5rem 0 0.5rem;
	}

	/* ------------------------------------------------ */

	.mobile-nav {
		display: none;
	}

	.header {
		display: flex;
		transform: unset;
		z-index: 0;
		width: 20rem;
		top: 0.5rem;
		left: 0.5rem;
		bottom: 3rem;
		height: auto;
		visibility: visible;
		box-shadow: none;
		border-radius: 0;
		margin: 0;
		transition: unset;
	}

	.header::after {
		content: "";
		position: absolute;
		top: 1.5rem;
		right: 0;
		bottom: 1.5rem;
		width: 1px;
		background-color: #dddde3;
	}

	.header .wrapper {
		min-height: unset;
	}

	/* ------------------------------------------------ */

	.footer {
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		background-color: #101014;
		z-index: 100;
		padding: 0.75rem 1.5rem;
		color: #fff;
		height: 3rem;
	}

	.footer .info {
		flex-direction: row;
	}

	.footer .navigation {
		flex-direction: row;
		margin: 0;
		gap: 1.75rem;
	}

	/* ------------------------------------------------ */

	.main {
		max-width: 65rem;
		width: 100%;
		margin: 1.5rem auto;
		background: none;
	}

	.main .banner {
		background-position: top 1.5rem right 1.5rem, center left;
		background-size: 8rem, cover;
		height: 15rem;
	}

	.main .banner .banner-title {
		font-size: 1.75rem;
	}

	.main .banner .banner-subtitle {
		font-size: 1rem;
	}

	.page {
		border-radius: 0;
		min-height: unset;
		flex: 1;
	}

	.page-header {
		justify-content: flex-start;
		text-align: left;
		padding: 0 0 1.5rem;
		margin: 0;
		top: 0;
	}

	.page-header::before {
		left: 0;
		right: 0;
	}

	.page-header h1 {
		font-size: 2rem;
	}

	.page-info {
		margin-top: auto;
	}

	/* ------------------------------------------------ */

	.is-product-page .page-content {
		display: grid;
		grid-template-columns: 1.5fr 1fr;
	}

	.is-product-page .page-content > * {
		grid-column: 1/3;
	}

	.is-product-page .page-content .product-carousel {
		grid-column: 1/2;
		padding: 1rem;
		border: 1px solid #dddde3;
		border-radius: 0.75rem;
	}

	.is-product-page .page-content .carousel .carousel-slide img {
		max-height: 26rem;
	}

	.is-product-page .page-content .description {
		grid-column: 2/3;
	}

	.is-product-page .tabs .tabs-nav {
		top: 0.5rem;
		padding: 1rem 0.25rem;
		margin: -1rem 0 -0.5rem;
	}

	.variants .variants-items .variants-item {
		gap: 1rem 1.5rem;
		grid-template-rows: auto auto;
	}

	.variants .variants-items .variants-item .info {
		grid-column: 2/3;
	}

	.variants .variants-items .variants-item .info .specs {
		max-width: 20rem;
	}

	.variants .variants-items .variants-item .actions {
		grid-column: 3/4;
		justify-content: flex-end;
		gap: 1.5rem;
	}

	/* ------------------------------------------------ */

	.notify {
		max-width: 30rem;
		margin: 0 auto;
	}

	.notify.is-active {
		transform: translateY(2rem);
		left: 1rem;
		right: 1rem;
	}

	/* ------------------------------------------------ */

	.is-cart-page .cart-form-content {
		display: grid;
		grid-template-columns: 1.7fr 1fr;
	}

	.is-cart-page .delivery-control {
		display: flex;
		gap: 1.5rem;
		align-items: flex-start;
	}

	.is-cart-page .in-cart-stats {
		bottom: 3rem;
		left: 0;
		right: 0;
		padding: 1rem 0;
		margin: 0 0 -1rem 0;
		border-radius: 0;
	}

	/* ------------------------------------------------ */

	.is-blog-page .blog-posts .blog-post {
		display: grid;
		grid-template-columns: 1fr 13.75rem;
	}

	.is-blog-page .blog-posts .blog-post .picture {
		grid-column: 2/3;
		grid-row: 1/4;
		max-height: 24rem;
	}

	/* ------------------------------------------------ */

	.cookie-accept {
		max-width: 30rem;
		left: auto;
		bottom: 3.75rem;
	}

	/* ------------------------------------------------ */

	form .form-group {
		flex-direction: row;
	}
}

@media only screen and (min-width: 1376px) {
	.categories-list {
		padding: 0;
		margin: -0.75rem 0 0;
	}

	.products-items.is-scrolled {
		padding: 0;
		margin: 0;
	}
}

@media only screen and (pointer: fine) and (hover: hover) {
	.products-items.is-scrolled {
		padding-bottom: 0.5rem;
	}

	a:hover {
		color: #39a7ff;
	}

	.header .navigation ul li:hover a {
		color: #39a7ff;
	}

	.header .navigation ul li:hover a span {
		background-color: #39a7ff;
	}

	.header .social a.youtube:hover {
		background-color: #f91736;
	}

	.header .social a.instagram:hover {
		background-color: #dd336d;
	}

	.header .social a.viber:hover {
		background-color: #7360f2;
	}

	.products-items li:hover::before {
		opacity: 1;
	}

	.categories-list ul li a:hover {
		background-color: rgb(16, 16, 20, 20%);
	}

	.categories-list ul li.is-active a:hover {
		background-color: #008dfd;
		color: #fff;
	}

	.variants .variants-items .variants-item .title a:hover {
		color: #39a7ff;
	}

	.btn:hover,
	a.btn:hover,
	.is-product-page .product-carousel .zoom-picture:hover,
	.is-product-page .product-carousel .carousel-thumbnails .carousel-btn:hover {
		background-color: #008dfd;
		color: #fff;
	}

	.btn.is-primary:hover,
	.btn.is-secondary:hover,
	.btn.is-success:hover,
	.btn.is-danger:hover {
		background-color: #101014;
		color: #ffffff;
	}

	input:hover,
	select:hover,
	textarea:hover,
	.number-input:hover,
	.tabs .tabs-nav li:hover,
	.is-product-page .product-carousel .carousel-thumbnails .carousel-slide-inner:hover {
		border-color: #bdbdc8;
	}

	input:focus-visible:hover,
	select:focus-visible:hover,
	textarea:focus-visible:hover {
		border-color: transparent;
	}

	.number-input:hover input,
	.tabs .tabs-nav .is-active:hover {
		border-color: transparent;
	}

	.is-blog-page .blog-posts .blog-post .post-title a:hover {
		color: #39a7ff;
	}
}

@supports (view-transition-name: none) {
	@view-transition {
		navigation: auto;
	}
}
