@charset "UTF-8";@font-face {
    font-family: swiper-icons;
    src: url(data:application/font-woff;charset=utf-8;base64,\ d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: #007aff
}

.swiper,swiper-container {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function,initial);
    box-sizing: content-box
}

.swiper-android .swiper-slide,.swiper-wrapper {
    transform: translateZ(0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide,swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
    display: block
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight,.swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform,height
}

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow,.swiper-3d .swiper-slide,.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top {
    transform-style: preserve-3d
}

.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: rgba(0,0,0,.15)
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left,rgba(0,0,0,.5),rgba(0,0,0,0))
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right,rgba(0,0,0,.5),rgba(0,0,0,0))
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0))
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0))
}

.swiper-css-mode>.swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: start start
}

.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-vertical.swiper-css-mode>.swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper {
    scroll-snap-type: none
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: none
}

.swiper-centered>.swiper-wrapper:before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-centered>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop:always}

.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
    margin-inline-start:var(--swiper-centered-offset-before)}

.swiper-centered.swiper-horizontal>.swiper-wrapper: before {
    height:100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
    margin-block-start:var(--swiper-centered-offset-before)}

.swiper-centered.swiper-vertical>.swiper-wrapper: before {
    width:100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

.swiper-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color,var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: transparent
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,swiper-container:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

/*! PhotoSwipe main CSS by Dmytro Semenov | photoswipe.com */
.pswp {
    --pswp-bg: #000;
    --pswp-placeholder-bg: #222;
    --pswp-root-z-index: 100000;
    --pswp-preloader-color: rgba(79, 79, 79, .4);
    --pswp-preloader-color-secondary: rgba(255, 255, 255, .9);
    --pswp-icon-color: #fff;
    --pswp-icon-color-secondary: #4f4f4f;
    --pswp-icon-stroke-color: #4f4f4f;
    --pswp-icon-stroke-width: 2px;
    --pswp-error-text-color: var(--pswp-icon-color)
}

.pswp {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: var(--pswp-root-z-index);
    display: none;
    touch-action: none;
    outline: 0;
    opacity: .003;
    contain: layout style size;
    -webkit-tap-highlight-color: rgba(0,0,0,0)
}

.pswp:focus {
    outline: 0
}

.pswp * {
    box-sizing: border-box
}

.pswp img {
    max-width: none
}

.pswp--open {
    display: block
}

.pswp,.pswp__bg {
    transform: translateZ(0);
    will-change: opacity
}

.pswp__bg {
    opacity: .005;
    background: var(--pswp-bg)
}

.pswp,.pswp__scroll-wrap {
    overflow: hidden
}

.pswp__scroll-wrap,.pswp__bg,.pswp__container,.pswp__item,.pswp__content,.pswp__img,.pswp__zoom-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.pswp__img,.pswp__zoom-wrap {
    width: auto;
    height: auto
}

.pswp--click-to-zoom.pswp--zoom-allowed .pswp__img {
    cursor: -webkit-zoom-in;
    cursor: -moz-zoom-in;
    cursor: zoom-in
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img {
    cursor: move;
    cursor: -webkit-grab;
    cursor: -moz-grab;
    cursor: grab
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active {
    cursor: -webkit-grabbing;
    cursor: -moz-grabbing;
    cursor: grabbing
}

.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img,.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active,.pswp__img {
    cursor: -webkit-zoom-out;
    cursor: -moz-zoom-out;
    cursor: zoom-out
}

.pswp__container,.pswp__img,.pswp__button,.pswp__counter {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.pswp__item {
    z-index: 1;
    overflow: hidden
}

.pswp__hidden {
    display: none!important
}

.pswp__content {
    pointer-events: none
}

.pswp__content>* {
    pointer-events: auto
}

.pswp__error-msg-container {
    display: grid
}

.pswp__error-msg {
    margin: auto;
    font-size: 1em;
    line-height: 1;
    color: var(--pswp-error-text-color)
}

.pswp .pswp__hide-on-close {
    opacity: .005;
    will-change: opacity;
    transition: opacity var(--pswp-transition-duration) cubic-bezier(.4,0,.22,1);
    z-index: 10;
    pointer-events: none
}

.pswp--ui-visible .pswp__hide-on-close {
    opacity: 1;
    pointer-events: auto
}

.pswp__button {
    position: relative;
    display: block;
    width: 50px;
    height: 60px;
    padding: 0;
    margin: 0;
    overflow: hidden;
    cursor: pointer;
    background: none;
    border: 0;
    box-shadow: none;
    opacity: .85;
    -webkit-appearance: none;
    -webkit-touch-callout: none
}

.pswp__button:hover,.pswp__button:active,.pswp__button:focus {
    transition: none;
    padding: 0;
    background: none;
    border: 0;
    box-shadow: none;
    opacity: 1
}

.pswp__button:disabled {
    opacity: .3;
    cursor: auto
}

.pswp__icn {
    fill: var(--pswp-icon-color);
    color: var(--pswp-icon-color-secondary)
}

.pswp__icn {
    position: absolute;
    top: 14px;
    left: 9px;
    width: 32px;
    height: 32px;
    overflow: hidden;
    pointer-events: none
}

.pswp__icn-shadow {
    stroke: var(--pswp-icon-stroke-color);
    stroke-width: var(--pswp-icon-stroke-width);
    fill: none
}

.pswp__icn:focus {
    outline: 0
}

div.pswp__img--placeholder,.pswp__img--with-bg {
    background: var(--pswp-placeholder-bg)
}

.pswp__top-bar {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 60px;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    z-index: 10;
    pointer-events: none!important
}

.pswp__top-bar>* {
    pointer-events: auto;
    will-change: opacity
}

.pswp__button--close {
    margin-right: 6px
}

.pswp__button--arrow {
    position: absolute;
    top: 0;
    width: 75px;
    height: 100px;
    top: 50%;
    margin-top: -50px
}

.pswp__button--arrow:disabled {
    display: none;
    cursor: default
}

.pswp__button--arrow .pswp__icn {
    top: 50%;
    margin-top: -30px;
    width: 60px;
    height: 60px;
    background: none;
    border-radius: 0
}

.pswp--one-slide .pswp__button--arrow {
    display: none
}

.pswp--touch .pswp__button--arrow {
    visibility: hidden
}

.pswp--has_mouse .pswp__button--arrow {
    visibility: visible
}

.pswp__button--arrow--prev {
    right: auto;
    left: 0px
}

.pswp__button--arrow--next {
    right: 0px
}

.pswp__button--arrow--next .pswp__icn {
    left: auto;
    right: 14px;
    transform: scaleX(-1)
}

.pswp__button--zoom {
    display: none
}

.pswp--zoom-allowed .pswp__button--zoom {
    display: block
}

.pswp--zoomed-in .pswp__zoom-icn-bar-v {
    display: none
}

.pswp__preloader {
    position: relative;
    overflow: hidden;
    width: 50px;
    height: 60px;
    margin-right: auto
}

.pswp__preloader .pswp__icn {
    opacity: 0;
    transition: opacity .2s linear;
    animation: pswp-clockwise .6s linear infinite
}

.pswp__preloader--active .pswp__icn {
    opacity: .85
}

@keyframes pswp-clockwise {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

.pswp__counter {
    height: 30px;
    margin-top: 15px;
    margin-inline-start:20px;font-size: 14px;
    line-height: 30px;
    color: var(--pswp-icon-color);
    text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary);
    opacity: .85
}

.pswp--one-slide .pswp__counter {
    display: none
}

html,body,div,span,applet,picture object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video {
    margin: 0;
    padding: 0;
    border: 0;
    vertical-align: baseline
}

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

img,fieldset,a img {
    border: none
}

input[type=text],input[type=email],input[type=search],input[type=tel],textarea {
    appearance: none;
    -webkit-appearance: none
}

input[type=submit],button {
    cursor: pointer
}

input[type=submit]::-moz-focus-inner,button::-moz-focus-inner {
    padding: 0;
    border: 0
}

textarea {
    overflow: auto
}

input,button {
    margin: 0;
    padding: 0;
    border: 0
}

div,input,textarea,select,button,h1,h2,h3,h4,h5,h6,a,span,a:focus {
    outline: none
}

ul,ol {
    list-style-type: none
}

table {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse
}

html {
    box-sizing: border-box
}

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

picture {
    display: block
}

:root {
    --transition: .4s ease;
    --transition-slow: .6s ease
}

.anim-fade-in {
    opacity: 0
}

.anim-fade-in-up {
    opacity: 0;
    transform: translateY(5rem)
}

@font-face {
    font-family: brown;
    src: url(/index_assets/font/Brown-Regular.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: brown;
    src: url(/index_assets/font/Brown-Bold.woff2) format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: domaine;
    src: url(/index_assets/font/DomaineDisp-Bold.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

body {
    font-family: brown;
    font-size: 16px;
    color: #20201f;
    line-height: 1.4
}

@media only screen and (min-width: 768px) {
    body {
        font-size:18px
    }
}

button,input,textarea,select {
    font-family: brown;
    color: #20201f
}

a {
    color: #20201f;
    text-decoration: none
}

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

svg {
    display: block
}

h1,.h1,.large-title {
    font-size: 40px;
    line-height: 1.1
}

h2,.h2 {
    font-size: 32px;
    line-height: 1.25
}

button {
    background: none
}

[data-pswp-src] {
    cursor: pointer
}

.hidden {
    display: none;
    visibility: hidden
}

:root {
    --c-brand: black;
    --c-text: black
}

body .cookie-though {
    box-shadow: 0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;
    border-radius: 0;
    left: auto;
    right: var(--ct-default-padding);
    --ct-primary-400: var(--c-brand);
    --ct-primary-300: var(--c-brand);
    --ct-primary-200: #dedede;
    --ct-primary-100: #f0f0f0;
    --ct-text: var(--c-text);
    --ct-subtitle: var(--ct-primary-300);
    --ct-title: var(--ct-primary-400);
    --ct-cookie: var(--c-brand);
    --ct-policy: var(--ct-white);
    --ct-policy-enabled: var(--ct-primary-400);
    --ct-policy-text: var(--ct-primary-400);
    --ct-policy-text-enabled: var(--ct-white);
    --ct-policy-essential: var(--ct-primary-100);
    --ct-slider-primary: #6b7280;
    --ct-slider-secondary: #d1d5db;
    --ct-slider-enabled-primary: #efefef;
    --ct-slider-enabled-secondary: black;
    --ct-enabled-option-color: var(--ct-white);
    --ct-white: #ffffff;
    --ct-text-margin: 10px;
    --ct-default-padding: 30px;
    --ct-seperator-padding: 10px;
    --ct-heading-font-size: 16px;
    --ct-sub-heading-font-size: 12px;
    --ct-text-font-size: 12px;
    --ct-button-font-size: 13px;
    --ct-primary-font: var(--f-base);
    --ct-primary-font-weight: var(--fw-buttons);
    --ct-secondary-font: var(--f-base);
    --ct-secondary-font-weight: var(--fw-buttons);
    --ct-button: var(--ct-primary-400);
    --ct-button-color: var(--ct-white);
    --ct-button-border: 1px solid var(--ct-primary-400);
    --ct-button-radius: .25rem;
    --ct-button-padding: 1rem 2rem;
    --ct-button-secondary: transparent;
    --ct-button-secondary-color: var(--ct-primary-400);
    --ct-button-secondary-border: 1px solid var(--ct-primary-400);
    --ct-z-index: 9999
}

@media screen and (min-width: 768px) {
    body .cookie-though {
        width:420px
    }
}

.grecaptcha-badge {
    visibility: hidden
}

.fui-i {
    --fui-primary-color: #20201f;
    --fui-font: $brown;
    --fui-font-size: 18px;
    --fui-label-font-size: 16px;
    --fui-label-margin: 4px;
    --fui-input-font-size: 18px;
    --fui-input-line-height: 30px;
    --fui-input-padding: 12px 24px;
    --fui-input-background-color: transparent;
    --fui-input-border: 1px solid #20201f;
    --fui-input-placeholder-color: #979797;
    --fui-border-radius: 0;
    --fui-focus-border-color: #20201f;
    --fui-focus-shadow: 0 0 0 3px rgba(0, 0, 0, .1);
    --fui-row-gutter: 16px;
    --fui-check-font-size: 18px;
    --fui-check-check-border-radius: 0;
    --fui-check-label-padding-left: 28px;
    --fui-check-label-top: 3px;
    --fui-check-label-bg-color: transparent;
    --fui-check-label-border: 1px solid #20201f;
    --fui-btn-font-size: 18px;
    --fui-btn-font-weight: 700;
    --fui-btn-padding: 14px 24px 13px;
    --fui-btn-border: 1px solid #20201f;
    --fui-submit-btn-bg-color-hover: white;
    --fui-submit-btn-border-color-hover: #20201f;
    --fui-submit-btn-color-hover: #20201f
}

.fui-i .fui-label {
    text-transform: lowercase
}

.fui-i .fui-checkbox .fui-checkbox-input:not(:checked)+.fui-checkbox-label {
    cursor: pointer
}

.fui-i .fui-checkbox .fui-checkbox-input:not(:checked)+.fui-checkbox-label:after {
    position: absolute;
    top: .1rem;
    top: calc(var(--fui-check-label-top) + var(--fui-check-label-width) * .22);
    left: 0;
    left: calc(var(--fui-check-label-width) * .2);
    display: block;
    width: .6rem;
    width: calc(var(--fui-check-label-width) * .6);
    height: .6rem;
    height: calc(var(--fui-check-label-height) * .6);
    content: "";
    cursor: pointer;
    border: none;
    background-color: gray;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 50% 50%;
    opacity: 0;
    transition: all .15s cubic-bezier(.4,0,.2,1);
    transition: var(--fui-check-label-transition)
}

.fui-i .fui-checkbox .fui-checkbox-input:not(:checked)+.fui-checkbox-label:hover:after {
    opacity: 1
}

.fui-i .fui-checkbox .fui-checkbox-input.fui-error+.fui-checkbox-label {
    color: var(--fui-error-color, var(--fui-error))
}

.fui-i .fui-checkbox .fui-checkbox-input.fui-error+.fui-checkbox-label:before {
    border-color: currentColor
}

.fui-i .fui-submit.fui-loading {
    color: #f2f0ed!important;
    opacity: .8;
    cursor: wait
}

.fui-i .fui-submit.fui-loading:after {
    border: none!important;
    transform: none;
    left: auto;
    top: 24px;
    right: 24px;
    margin: 0!important
}

.fui-i .fui-row {
    flex-direction: column
}

@media only screen and (min-width: 768px) {
    .fui-i .fui-row {
        flex-direction:row
    }
}

.fui-i .fui-fieldset {
    margin: 0;
    padding: 0
}

.fui-i .fui-fieldset .fui-group {
    margin: 0;
    padding: 0;
    border: none
}

@media only screen and (min-width: 768px) {
    .fui-i .address-group .fui-fieldset .fui-group .fui-row:first-child .fui-field:first-child {
        max-width:30%
    }
}

@media only screen and (min-width: 768px) {
    .fui-i .address-group .fui-fieldset .fui-group .fui-row:last-child .fui-field:last-child {
        max-width:30%
    }
}

.arrow {
    width: 31px;
    height: 7px
}

.wrapper {
    padding-top: 73px
}

@media only screen and (min-width: 768px) {
    .wrapper {
        padding-top:140px
    }
}

.container {
    max-width: 1760px;
    margin: 0 auto;
    padding: 0 20px
}

@media only screen and (min-width: 768px) {
    .container {
        padding:0 40px
    }
}

@media only screen and (min-width: 1024px) {
    .container {
        padding:0 80px
    }
}

.container--small {
    max-width: 1440px
}

.container--tiny {
    max-width: 1120px
}

.navbar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99;
    width: 100%;
    padding: 16px 0;
    background: white;
    border-bottom: 1px solid transparent;
    text-transform: noe;
    transition: transform var(--transition-slow),border-color var(--transition-slow)
}

@media only screen and (min-width: 768px) {
    .navbar {
        padding:5px 0
    }
}

.navbar.scroll-up {
    transform: translateY(0)
}

.navbar.scroll-down {
    transform: translateY(-100%)
}

@media only screen and (min-width: 768px) {
    .navbar.scroll-down .subnav {
        visibility:hidden!important;
        opacity: 0!important
    }
}

.navbar.scrolled {
    border-color: #f2f0ed
}

.navbar .container {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.navbar__logo {
    flex: 0 0 108px
}

@media only screen and (min-width: 768px) {
    .navbar__logo {
        position:relative;
        flex: 0 0 157px
    }
}

.navbar__logo img {
    width: 100%
}

.navbar__inner {
    position: fixed;
    top: 72px;
    left: 0;
    width: 100%;
    height: calc(100vh - 72px);
    padding: 20px;
    background: white;
    opacity: 0;
    transition: opacity var(--transition);
    pointer-events: none;
    overflow: auto
}

@media only screen and (min-width: 768px) {
    .navbar__inner {
        position:static;
        display: flex;
        flex-direction: column-reverse;
        width: auto;
        height: auto;
        padding: 0;
        opacity: 1;
        pointer-events: all;
        overflow: visible
    }
}

.navbar__inner.visible {
    opacity: 1;
    pointer-events: all
}

.navbar__sub {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    font-size: 16px
}

@media only screen and (min-width: 768px) {
    .navbar__sub {
        justify-content:flex-end;
        margin-bottom: 30px
    }
}

.navbar__sub li {
    margin: 0 32px 24px 0
}

@media only screen and (min-width: 768px) {
    .navbar__sub li {
        margin:0 0 0 24px
    }

    .navbar__sub li:last-child {
        margin-left: 28px
    }
}

.navbar__sub li:nth-child(1),.navbar__sub li:nth-child(2),.navbar__sub li:nth-child(3) {
    flex: 0 0 100%
}

@media only screen and (min-width: 768px) {
    .navbar__sub li:nth-child(1),.navbar__sub li:nth-child(2),.navbar__sub li:nth-child(3) {
        flex:initial
    }
}

.navbar__sub a {
    color: #20201f;
    opacity: .44;
    transition: opacity var(--transition)
}

.navbar__sub a:hover {
    opacity: 1
}

@media only screen and (min-width: 768px) {
    .navbar__nav {
        display:flex;
        justify-content: flex-end
    }
}

.navbar__nav li {
    position: relative;
    margin-bottom: 24px
}

@media only screen and (min-width: 768px) {
    .navbar__nav li {
        margin:0 0 0 40px
    }
}

.navbar__nav li.has-subnav>a:hover+.subnav {
    visibility: visible;
    opacity: 1
}

.navbar__nav li.has-subnav:hover>.subnav:hover {
    visibility: visible;
    opacity: 1
}

.navbar__nav li.has-subnav>.subnav {
    background-color: #fffffff2;
    z-index: 999;
    min-width: calc(100% + 40px);
    padding: 0 0 0 20px;
    margin: 10px 0 0;
    border-left: 1px solid #CCC;
    transition: opacity var(--transition),visibility var(--transition)
}

@media only screen and (min-width: 768px) {
    .navbar__nav li.has-subnav>.subnav {
        position:absolute;
        left: 50%;
        transform: translate(-50%);
        visibility: hidden;
        opacity: 0;
        margin: 0;
        padding: 20px;
        border-left: none
    }
}

.navbar__nav li.has-subnav>.subnav li {
    margin: 3px 0 5px
}

@media only screen and (min-width: 768px) {
    .navbar__nav li.has-subnav>.subnav li {
        margin:3px 0 10px;
        text-align: center
    }

    .navbar__nav li.has-subnav>.subnav li:first-child {
        margin-top: 0
    }

    .navbar__nav li.has-subnav>.subnav li:last-child {
        margin-bottom: 0
    }
}

.navbar__nav li.has-subnav>.subnav li a {
    display: inline-block;
    width: auto
}

.navbar__nav a {
    padding-top: 1px;
    border-bottom: 1px solid transparent;
    font-size: 18px;
    /*font-weight: 700;*/
    color: #20201f;
    line-height: 1.556;
    transition: border-color var(--transition);
    white-space: nowrap;
     font: var(--fnt, var(--font_1));
}

.navbar__nav a small {
    color: #666
}

@media only screen and (min-width: 768px) {
    .navbar__nav a {
        display:block
    }
}

.navbar__nav a:hover,.navbar__nav a.active {
    border-color: #20201f
}

.navbar__burger {
    position: relative;
    width: 40px;
    height: 40px;
    margin-right: -10px
}

@media only screen and (min-width: 768px) {
    .navbar__burger {
        display:none
    }
}

.navbar__burger.active span:nth-child(1),.navbar__burger.active span:nth-child(2) {
    transform: translateY(0) rotate(45deg)
}

.navbar__burger.active span:nth-child(3) {
    transform: translateY(0) rotate(-45deg)
}

.navbar__burger span {
    position: absolute;
    top: 18px;
    left: 10px;
    width: 20px;
    height: 2px;
    background: #20201f;
    transition: transform var(--transition)
}

.navbar__burger span:nth-child(1) {
    transform: translateY(-6px)
}

.navbar__burger span:nth-child(3) {
    transform: translateY(6px)
}

@media only screen and (min-width: 768px) {
    .breadcrumbs {
        min-height:40px
    }
}

.breadcrumbs.exists {
    padding: 12px 0
}

.breadcrumbs ul {
    display: flex;
    font-size: 14px;
    color: #979797;
    line-height: 16px;
    text-transform: lowercase
}

.breadcrumbs li {
    position: relative;
    margin-right: 20px
}

.breadcrumbs li:not(:last-child):after {
    content: "";
    position: absolute;
    top: 3px;
    right: -12px;
    width: 5px;
    height: 9px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='5' height='9' viewBox='0 0 5 9'%3E%3Cpolyline fill='none' stroke='%23979797' stroke-linejoin='round' stroke-width='1.5' points='1 1 4 4.5 1 8'/%3E%3C/svg%3E");
    background-repeat: no-repeat
}

.breadcrumbs a {
    color: #979797;
    transition: color var(--transition)
}

.breadcrumbs a:hover {
    color: #20201f
}

.order {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 999;
    align-items: center;
    background: #20201f;
    transform-origin: 0 0;
    transform: translateY(64px) rotate(-90deg)
}

@media screen and (min-height: 860px) {
    .order {
        top:796px;
        bottom: auto
    }
}

@media only screen and (min-width: 1024px) {
    .order {
        display:flex
    }
}

.order:hover .order__icon {
    background: var(--page-color-hover)
}

.order:hover .order__icon rect:nth-child(1) {
    stroke: #fff
}

.order:hover .order__icon rect:nth-child(2) {
    fill: #fff
}

.order:hover .order__color {
    opacity: 0
}

.order__title {
    padding: 0 24px;
    font-size: 18px;
    color: #fff;
    text-transform: lowercase
}

.order__icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--page-color);
    transition: background-color var(--transition)
}

.order__icon svg {
    position: relative;
    z-index: 2;
    transform: rotate(90deg)
}

.order__icon rect {
    transition: fill var(--transition),stroke var(--transition)
}

.order__color {
    position: absolute;
    inset: 0;
    opacity: 1;
    transition: opacity var(--transition)
}

.title {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .title {
        margin-bottom:40px
    }
}

.btn,.form .actions button[type=submit],.subscribe .fui-btn,.fui-i .fui-submit {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 13px 77px 11px 23px;
    background: #20201f;
    border: 1px solid #20201f;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.667;
    color: #fff;
    text-transform: lowercase;
    transition: background var(--transition),color var(--transition)
}

.btn:hover,.form .actions button[type=submit]:hover,.subscribe .fui-btn:hover,.fui-i .fui-submit:hover,.btn:focus,.form .actions button[type=submit]:focus,.subscribe .fui-btn:focus,.fui-i .fui-submit:focus {
    background: white;
    border-color: #20201f;
    color: #20201f
}

.btn:hover:before,.form .actions button[type=submit]:hover:before,.subscribe .fui-btn:hover:before,.fui-i .fui-submit:hover:before,.btn:focus:before,.form .actions button[type=submit]:focus:before,.subscribe .fui-btn:focus:before,.fui-i .fui-submit:focus:before {
    opacity: 1
}

.btn:hover:after,.form .actions button[type=submit]:hover:after,.subscribe .fui-btn:hover:after,.fui-i .fui-submit:hover:after,.btn:focus:after,.form .actions button[type=submit]:focus:after,.subscribe .fui-btn:focus:after,.fui-i .fui-submit:focus:after {
    opacity: 0
}

.btn:before,.form .actions button[type=submit]:before,.subscribe .fui-btn:before,.fui-i .fui-submit:before,.btn:after,.form .actions button[type=submit]:after,.subscribe .fui-btn:after,.fui-i .fui-submit:after {
    content: "";
    position: absolute;
    top: 24px;
    right: 24px;
    width: 31px;
    height: 7px;
    transition: opacity var(--transition)
}

.btn:before,.form .actions button[type=submit]:before,.subscribe .fui-btn:before,.fui-i .fui-submit:before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='31' height='7'%3E%3Cpath fill='%2320201f' d='M24.99 0v3.001H0v1h24.99V7L31 3.5z'/%3E%3C/svg%3E");
    opacity: 0
}

.btn:after,.form .actions button[type=submit]:after,.subscribe .fui-btn:after,.fui-i .fui-submit:after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='31' height='7'%3E%3Cpath fill='%23fff' d='M24.99 0v3.001H0v1h24.99V7L31 3.5z'/%3E%3C/svg%3E")
}

.btn--white,.subscribe .fui-btn {
    background: white;
    border-color: #fff;
    color: #20201f
}

.btn--white:hover,.subscribe .fui-btn:hover,.btn--white:focus,.subscribe .fui-btn:focus {
    background: #20201f;
    border-color: #fff;
    color: #fff
}

.btn--white:hover:before,.subscribe .fui-btn:hover:before,.btn--white:focus:before,.subscribe .fui-btn:focus:before {
    opacity: 0
}

.btn--white:hover:after,.subscribe .fui-btn:hover:after,.btn--white:focus:after,.subscribe .fui-btn:focus:after {
    opacity: 1
}

.btn--white:before,.subscribe .fui-btn:before {
    opacity: 1
}

.btn--white:after,.subscribe .fui-btn:after {
    opacity: 0
}

.btn--disabled {
    opacity: .5;
    cursor: not-allowed
}

.btn--disabled:hover {
    background: #20201f;
    border-color: #20201f;
    color: #fff
}

.btn--disabled:hover:after {
    opacity: 1!important
}

.checkbox {
    position: relative;
    display: block;
    min-height: 24px;
    padding: 3px 0 0 36px;
    font-size: 18px;
    line-height: 21px;
    cursor: pointer
}

.checkbox:hover>span {
    font-weight: 700
}

.checkbox input {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0
}

.checkbox input:checked+span {
    font-weight: 700
}

.checkbox input:checked+span:after {
    opacity: 1
}

.checkbox>span {
    display: flex;
    align-items: flex-start
}

.checkbox>span:before,.checkbox>span:after {
    content: "";
    position: absolute
}

.checkbox>span:before {
    top: 0;
    left: 0;
    width: 24px;
    height: 24px;
    border: 1px solid #20201f
}

.checkbox>span:after {
    top: 4px;
    left: 4px;
    width: 16px;
    height: 16px;
    background: #20201f;
    opacity: 0;
    transition: opacity var(--transition)
}

.checkbox__color {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    margin: 2px 8px 0 0
}

.checkbox picture {
    margin: -3px 4px 0 -4px
}

.badge {
    padding: 6px 8px;
    background: #20201f;
    font-size: 14px;
    color: #fff;
    text-transform: uppercase
}

.link {
    position: relative;
    display: inline-flex;
    padding-bottom: 2px;
    font-size: 18px;
    line-height: 1.2;
    overflow: hidden;
    text-transform: lowercase
}

.link:hover:before {
    animation: line1 .4s forwards
}

.link:hover:after {
    animation: line2 .4s forwards
}

.link:before,.link:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #20201f
}

@keyframes line1 {
    0% {
        transform: translate(-200%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes line2 {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(200%)
    }
}

.content {
    line-height: 1.667
}

.content h1,.content h2:not(.large-title),.content h3:not(.large-title),.content h4:not(.large-title) {
    text-transform: lowercase
}

.content h1 {
    margin-bottom: 40px
}

.content h2 {
    margin-bottom: 32px
}

.content h3 {
    margin-bottom: 24px
}

.content p:not(:last-child) {
    margin-bottom: 1.5rem
}

.content p:not(:last-child)+h1,.content p:not(:last-child)+h2,.content p:not(:last-child)+h3 {
    margin-top: 3rem
}

.content i {
    font-style: italic
}

.content div.table-wrapper {
    overflow-x: auto;
    max-width: 100%
}

.content table {
    max-width: 100%;
    border-collapse: collapse
}

.content table td,.content table th {
    border: 1px dotted black;
    padding: .4rem .8rem;
    text-align: left;
    vertical-align: top
}

.content table th {
    font-weight: 700
}

.content ul:not(:last-child),.content ol:not(:last-child) {
    margin-bottom: 1.5rem
}

.content ul li:not(:last-child),.content ol li:not(:last-child) {
    margin-bottom: 1rem
}

.content ul li>ul,.content ul li>ol,.content ol li>ul,.content ol li>ol {
    margin-top: 1rem
}

.content ul {
    margin-left: .25rem
}

.content ul li {
    padding-left: 1.5rem;
    margin-bottom: .5rem;
    position: relative
}

.content ul li:before {
    content: "\2022";
    display: block;
    position: absolute;
    left: 0;
    color: currentColor;
    width: 1rem;
    font-size: 1rem;
    line-height: 1.8rem
}

.content ul li>ul {
    margin-top: .15rem
}

.content ol {
    margin-left: .25rem
}

.content ol li {
    padding-left: 1.5rem;
    margin-bottom: .5rem;
    position: relative
}

.content ol>li {
    counter-increment: section
}

.content ol>li:before {
    content: "-";
    content: counter(section);
    display: block;
    position: absolute;
    left: 0
}

.content ol>li>ol {
    margin-top: .5rem
}

.content ol>li>ol li {
    padding-left: 2.5rem;
    counter-increment: subsection
}

.content ol>li>ol li:before {
    content: counter(section) "." counter(subsection)
}

.footer {
    padding: 60px 0;
    background: #20201f;
    font-size: 16px;
    color: #ffffff70;
    line-height: 1.125
}

@media only screen and (min-width: 768px) {
    .footer {
        padding:120px 0 0px
    }
}

.footer li a,.footer p a {
    display: inline-flex;
    color: #fff;
    opacity: .44;
    transition: opacity var(--transition);
    text-transform: lowercase
}

.footer li a:hover,.footer p a:hover {
    opacity: 1
}

.footer h6 {
    color: #fff;
    font-size: 18px;
    line-height: 1.556;
    opacity: 1;
    text-transform: lowercase
}

.footer h6 a {
    border-bottom: 1px solid transparent;
    font-size: 18px;
    line-height: 1.556;
    opacity: 1;
    transition: border-color var(--transition),opacity var(--transition)
}

.footer h6 a:hover {
    border-color: #fff;
    opacity: 1
}

@media only screen and (min-width: 768px) {
    .footer__main {
        display:flex;
        flex-wrap: wrap;
        margin: 0 -20px 0px
    }
}

@media only screen and (min-width: 1024px) {
    .footer__main {
        margin-bottom:0px
    }
}

@media only screen and (min-width: 1260px) {
    .footer__main {
        justify-content:space-between;
        max-width: 1500px
    }
}

.footer__col {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .footer__col {
        flex:0 0 33.33%;
        padding: 0 20px
    }
}

@media only screen and (min-width: 1260px) {
    .footer__col {
        flex:initial;
        margin: 0
    }
}

.footer__logo {
    display: inline-flex;
    width: 126px;
    margin-bottom: 36px;
    opacity: 1
}

.footer__logo img {
    width: 100%
}

.footer__contacts p {
    margin-bottom: 8px
}

.footer__nav li {
    margin-bottom: 16px
}

@media only screen and (min-width: 768px) {
    .footer__bottom {
        display:grid;
        grid-gap: 12px 0;
        grid-template-columns: minmax(0,1fr) auto;
        grid-template-rows: 1fr 1fr;
        align-items: center;
        justify-content: space-between
    }
}

@media only screen and (min-width: 1260px) {
    .footer__bottom {
        max-width:1460px
    }
}

.footer__links {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .footer__links {
        grid-row:1/span 1;
        grid-column: 1/span 1;
        align-self: flex-end
    }
}

@media only screen and (min-width: 768px) {
    .footer__links {
        display:flex;
        margin: 0
    }
}

.footer__links li {
    margin-bottom: 16px
}

@media only screen and (min-width: 768px) {
    .footer__links li {
        margin:0 40px 0 0
    }
}

.footer__socials {
    display: flex
}

@media only screen and (min-width: 768px) {
    .footer__socials {
        grid-row:1/span 2;
        grid-column: 2/span 1
    }
}

.footer__socials li:not(:first-child) {
    margin-left: 16px
}

.footer__socials a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border: 1px solid #d8d8d8;
    border-radius: 50%;
    transition: background var(--transition),border-color var(--transition)
}

.footer__socials a:hover {
    background: white;
    border-color: #fff
}

.footer__socials a:hover svg {
    fill: #20201f
}

.footer__socials svg {
    width: 16px;
    height: 16px;
    fill: #fff;
    transition: fill var(--transition)
}

.footer__socials svg.linkedin {
    width: 20px;
    height: 20px
}

.footer__site-by {
    margin-top: 2rem;
    font-size: 14px
}

@media only screen and (min-width: 768px) {
    .footer__site-by {
        grid-row:2/span 1;
        grid-column: 1/span 1;
        align-self: flex-start;
        margin-top: 0
    }
}

.footer__site-by a {
    color: inherit;
    transition: color var(--transition)
}

.footer__site-by a:hover {
    color: #fff
}

.hero {
    position: relative;
    margin-bottom: 20px
}

.hero .container {
    position: relative;
    padding: 0
}

.hero .swiper-pagination {
    display: block;
    position: static;
    transform: none;
    margin: 20px auto 0;
    position: absolute;
    top: 100%!important;
    height: 10px
}

.hero .swiper-pagination-bullet-active {
    background-color: #20201f
}

.hero .swiper-slide {
    position: relative
}

.hero .swiper-slide a {
    display: block
}

.hero .swiper-slide .slide-overlay {
    position: absolute;
    background: rgba(32,32,31,.25);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    gap: 20px;
    padding: 20px 20px 40px;
    z-index: 2
}

@media only screen and (min-width: 768px) {
    .hero .swiper-slide .slide-overlay {
        padding-bottom:80px
    }
}

.hero .swiper-slide .slide-overlay h1 {
    font-family: domaine;
    font-size: 48px;
    color: #fff;
    line-height: 1;
    text-align: center
}

@media only screen and (min-width: 768px) {
    .hero .swiper-slide .slide-overlay h1 {
        font-size:64px
    }
}

.hero .swiper-slide .slide-overlay .btn--white,.hero .swiper-slide .slide-overlay .subscribe .fui-btn,.subscribe .hero .swiper-slide .slide-overlay .fui-btn {
    border-color: #fff;
    color: #fff;
    background-color: transparent;
    font-weight: 400
}

.hero .swiper-slide .slide-overlay .btn--white:before,.hero .swiper-slide .slide-overlay .subscribe .fui-btn:before,.subscribe .hero .swiper-slide .slide-overlay .fui-btn:before {
    opacity: 0
}

.hero .swiper-slide .slide-overlay .btn--white:after,.hero .swiper-slide .slide-overlay .subscribe .fui-btn:after,.subscribe .hero .swiper-slide .slide-overlay .fui-btn:after {
    opacity: 1
}

.hero .swiper-slide .slide-overlay .btn--white:hover,.hero .swiper-slide .slide-overlay .subscribe .fui-btn:hover,.subscribe .hero .swiper-slide .slide-overlay .fui-btn:hover {
    color: #fff;
    border-color: #20201f;
    background-color: #20201f
}

.hero picture,.hero .video-wrapper {
    width: 100%;
    height: 320px;
    position: relative;
    z-index: 1
}

@media only screen and (min-width: 768px) {
    .hero picture,.hero .video-wrapper {
        height:400px
    }
}

@media only screen and (min-width: 1024px) {
    .hero picture,.hero .video-wrapper {
        height:500px
    }
}

@media only screen and (min-width: 1520px) {
    .hero picture,.hero .video-wrapper {
        height:680px
    }
}

.hero img,.hero video {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.hero__title {
    position: absolute;
    left: 50%;
    bottom: 40px;
    z-index: 2;
    width: 100%;
    padding: 0 20px;
    font-family: domaine;
    font-size: 48px;
    color: #fff;
    line-height: 1;
    text-align: center;
    transform: translate(-50%)
}

@media only screen and (min-width: 768px) {
    .hero__title {
        bottom:80px;
        max-width: 640px;
        padding: 0 40px;
        font-size: 64px
    }
}

.hero--overlay .container:after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(32,32,31,.25)
}

.section {
    padding: 60px 0
}

@media only screen and (min-width: 768px) {
    .section {
        padding:100px 0
    }
}

.section+.section.callout,.section+.section.callout,.section.callout+.section,.section.callout+.section {
    margin-top: -60px
}

@media only screen and (min-width: 768px) {
    .section+.section.callout,.section+.section.callout,.section.callout+.section,.section.callout+.section {
        margin-top:-100px
    }
}

.section.callout+.section.samples {
    margin: 0
}

.section.collections:last-child,.section.cta:last-child,.section.subscribe:last-child {
    padding-bottom: 120px
}

@media only screen and (min-width: 768px) {
    .section.collections:last-child,.section.cta:last-child,.section.subscribe:last-child {
        padding-bottom:200px
    }
}

.section--pb2x {
    padding-bottom: 120px
}

@media only screen and (min-width: 768px) {
    .section--pb2x {
        padding-bottom:200px
    }
}

@media only screen and (min-width: 1024px) {
    .intro__row {
        display:flex;
        justify-content: space-between;
        margin: 0 -40px
    }
}

@media only screen and (min-width: 1260px) {
    .intro__row {
        margin:0 -80px
    }
}

@media only screen and (min-width: 1024px) {
    .intro__col {
        flex:1;
        padding: 0 40px
    }
}

@media only screen and (min-width: 1260px) {
    .intro__col {
        padding:0 80px
    }
}

.intro__col:first-child {
    margin-bottom: 32px;
    text-transform: lowercase
}

@media only screen and (min-width: 768px) {
    .intro__col:first-child {
        max-width:834px
    }
}

@media only screen and (min-width: 768px) {
    .intro__col:last-child {
        max-width:800px
    }
}

.head {
    display: flex;
    align-items: flex-start;
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .head {
        margin-bottom:80px
    }
}

.head h2:only-child {
    flex-grow: 1;
    text-align: center;
    text-transform: lowercase
}

.head .link {
    margin: 8px 0 0 auto
}

.collection {
    position: relative;
    display: block;
    overflow: hidden
}

.collection:hover:after {
    opacity: .6
}

.collection:hover .picture .image {
    transform: scale(1.05)
}

.collection:hover .collection__overlay {
    transform: translateY(calc(-100% + 106px))
}

.collection:hover .collection__text,.collection:hover .collection__arrow {
    opacity: 1
}

.collection:after {
    content: "";
    position: absolute;
    inset: 0;
    background: #20201f;
    opacity: .25;
    transition: opacity var(--transition)
}

.collection__overlay {
    position: absolute;
    top: calc(100% - 106px);
    z-index: 2;
    padding: 0 48px;
    color: #fff;
    text-align: center;
    transition: transform var(--transition);
    width: 100%
}

.collection__title {
    margin-bottom: 12px;
    font-family: domaine;
    font-size: 48px;
    line-height: 1.16
}

.collection__text,.collection__arrow {
    opacity: 0;
    transition: opacity var(--transition)
}

.collection__text {
    margin-bottom: 20px;
    font-size: 18px;
    line-height: 1.66
}

.collection__arrow {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    width: 120px;
    height: 60px;
    margin: 0 auto;
    padding-bottom: 20px;
    border-radius: 60px 60px 0 0
}

.collection__arrow svg {
    fill: #fff
}

.collection .picture .image {
    height: auto;
    min-height: 480px;
    object-fit: cover;
    transition: transform var(--transition-slow)
}

.collections {
    overflow: hidden
}

.collections__list {
    list-style: none;
    margin: 0 -20px 0 0;
    padding: 0
}

@media only screen and (min-width: 768px) {
    .collections__list {
        margin:0
    }
}

.collections__list>li {
    max-width: 300px
}

@media only screen and (min-width: 768px) {
    .collections__list>li {
        min-width:250px;
        max-width: 300px
    }
}

.collections__list>li .collection {
    position: relative
}

.collections__list>li .collection .picture {
    position: relative;
    padding-top: 125%
}

@media only screen and (min-width: 768px) {
    .collections__list>li .collection .picture {
        padding-top:190%
    }
}

.collections__list>li .collection .picture img {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.collections__list-wrapper {
    overflow: visible;
    --swiper-navigation-size: 60px
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev,.collections__list-wrapper .swiper-navigation .swiper-button-next {
    background-color: #20201f;
    color: #f2f0ed;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 60px;
    height: 60px;
    border-radius: 60px;
    opacity: 1;
    transition: color var(--transition),background-color var(--transition)
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev:hover,.collections__list-wrapper .swiper-navigation .swiper-button-next:hover {
    background-color: #f2f0ed;
    color: #20201f
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev:before,.collections__list-wrapper .swiper-navigation .swiper-button-prev:after,.collections__list-wrapper .swiper-navigation .swiper-button-next:before,.collections__list-wrapper .swiper-navigation .swiper-button-next:after {
    content: none
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev.swiper-button-disabled,.collections__list-wrapper .swiper-navigation .swiper-button-next.swiper-button-disabled {
    opacity: 0
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev svg,.collections__list-wrapper .swiper-navigation .swiper-button-next svg {
    fill: currentColor;
    height: 5px
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev {
    left: -20px
}

.collections__list-wrapper .swiper-navigation .swiper-button-prev svg {
    transform: rotate(180deg)
}

.collections__list-wrapper .swiper-navigation .swiper-button-next {
    right: -20px
}

.callout {
    position: relative;
    z-index: 2;
    padding: 120px 0;
    text-align: center;
    overflow: hidden
}

@media only screen and (min-width: 768px) {
    .callout {
        padding:200px 0
    }
}

.callout h2 {
    max-width: 576px;
    margin: 0 auto;
    font-family: domaine;
    font-size: 48px;
    line-height: 1.16
}

.callout .link {
    margin-top: 28px
}

.callout>svg {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    width: auto;
    height: 100%;
    transform: translate(-50%,-50%)
}

@media only screen and (min-width: 768px) {
    .cta .container {
        display:flex;
        height: 640px
    }
}

.cta__inner {
    padding: 60px 40px;
    background: #20201f;
    color: #fff;
    text-align: center
}

@media only screen and (min-width: 768px) {
    .cta__inner {
        display:flex;
        flex: 0 0 50%;
        padding: 60px
    }
}

@media only screen and (min-width: 1024px) {
    .cta__inner {
        flex:0 0 40%
    }
}

@media only screen and (min-width: 768px) {
    .cta .content {
        max-width:334px;
        margin: auto
    }
}

.cta .content h2,.cta .content h3,.cta .content h4 {
    margin-bottom: 16px;
    text-transform: lowercase
}

.cta .content .btn,.cta .content .form .actions button[type=submit],.form .actions .cta .content button[type=submit],.cta .content .subscribe .fui-btn,.subscribe .cta .content .fui-btn,.cta .content .fui-i .fui-submit,.fui-i .cta .content .fui-submit {
    margin-top: 24px
}

.cta__preview {
    background: #20201f
}

@media only screen and (min-width: 768px) {
    .cta__preview {
        display:flex;
        flex: 0 0 50%
    }
}

@media only screen and (min-width: 1024px) {
    .cta__preview {
        flex:0 0 60%
    }
}

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

.cta--light .cta__inner {
    background: #f2f0ed;
    color: #20201f
}

.project {
    display: block
}

.project:hover .project__arrow .arrow:first-child {
    animation: arrow1 .4s forwards
}

.project:hover .project__arrow .arrow:last-child {
    animation: arrow2 .4s forwards
}

.project picture {
    position: relative;
    margin-bottom: 24px;
    overflow: hidden;
    padding-top: 140%
}

.project picture:hover img {
    transform: scale(1.05)
}

.project picture img {
    transition: transform var(--transition-slow);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover
}

.project__inner {
    position: relative;
    padding-right: 56px
}

.project__title {
    font-family: domaine;
    font-size: 24px;
    line-height: 1.333
}

.project__category {
    font-size: 18px
}

.project__arrow {
    position: absolute;
    top: 12px;
    right: 0;
    width: 31px;
    height: 7px;
    overflow: hidden
}

.project__arrow .arrow:first-child {
    position: absolute;
    top: 0;
    left: 0
}

@keyframes arrow1 {
    0% {
        transform: translate(-200%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes arrow2 {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(200%)
    }
}

.projects {
    overflow: hidden
}

@media only screen and (min-width: 768px) {
    .projects .container {
        display:flex
    }
}

.projects__sidebar {
    margin-bottom: 32px;
    text-transform: lowercase
}

@media only screen and (min-width: 768px) {
    .projects__sidebar {
        flex:0 0 240px;
        margin: 0
    }
}

@media only screen and (min-width: 1024px) {
    .projects__sidebar {
        flex:0 0 320px
    }
}

.projects__sidebar h2 {
    margin-bottom: 20px
}

@media only screen and (min-width: 768px) {
    .projects__inner {
        flex:0 0 calc(100% - 240px)
    }
}

@media only screen and (min-width: 1024px) {
    .projects__inner {
        flex:0 0 calc(100% - 320px)
    }
}

.projects .swiper {
    overflow: visible
}

@media only screen and (min-width: 768px) {
    .projects .swiper {
        width:calc(50vw + 480px);
        overflow: hidden
    }
}

@media only screen and (min-width: 768px) {
    .projects .swiper-slide {
        width:320px
    }
}

@media only screen and (min-width: 1024px) {
    .projects .swiper-slide {
        width:480px
    }
}

@media only screen and (min-width: 768px) {
    .usps .container {
        display:flex
    }
}

.usps__preview {
    position: relative
}

@media only screen and (min-width: 768px) {
    .usps__preview {
        display:flex;
        flex: 0 0 50%
    }
}

@media only screen and (min-width: 1260px) {
    .usps__preview {
        flex:0 0 40%
    }
}

.usps__pictures {
    display: flex
}

.usps__pictures picture {
    opacity: 0;
    transition: opacity var(--transition)
}

.usps__pictures picture:not(:first-child) {
    position: absolute;
    inset: 0
}

.usps__pictures picture.active {
    opacity: 1
}

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

.usps__pictures:after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(32,32,31,.2)
}

.usps__title {
    position: absolute;
    top: 50%;
    left: 50%;
    max-width: 460px;
    padding: 60px;
    font-family: domaine;
    font-size: 48px;
    color: #fff;
    text-align: center;
    line-height: 1.167;
    transform: translate(-50%,-50%);
    text-transform: lowercase
}

.usps__inner {
    padding: 60px 124px 60px 40px;
    background: #f2f0ed
}

@media only screen and (min-width: 768px) {
    .usps__inner {
        flex:0 0 50%;
        max-width: 50%
    }
}

@media only screen and (min-width: 1260px) {
    .usps__inner {
        flex:0 0 60%;
        max-width: 60%;
        padding: 140px 160px
    }
}

@media only screen and (min-width: 768px) {
    .usps__list {
        max-width:480px
    }
}

.usps__item {
    position: relative;
    cursor: default
}

.usps__item:not(:last-child) {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .usps__item:not(:last-child) {
        margin-bottom:48px
    }
}

.usps__item.active .usps__caption {
    border-color: #20201f
}

.usps__item.active .usps__arrow {
    opacity: 1
}

.usps__caption {
    display: inline-block;
    border-bottom: 1px solid transparent;
    font-size: 32px;
    line-height: 1.1;
    transition: border-color var(--transition);
    vertical-align: top;
    text-transform: lowercase
}

@media only screen and (min-width: 1260px) {
    .usps__caption {
        font-size:40px
    }
}

.usps__text {
    margin-top: 16px
}

.usps__arrow {
    position: absolute;
    top: 52px;
    left: calc(100% + 20px);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border: 1px solid #20201f;
    border-radius: 50%;
    opacity: 0;
    transition: background var(--transition),opacity var(--transition)
}

@media only screen and (min-width: 1260px) {
    .usps__arrow {
        top:-40px;
        width: 120px;
        height: 120px
    }
}

.usps__arrow:hover {
    background: #20201f
}

.usps__arrow:hover svg {
    fill: #fff
}

.usps__arrow svg {
    fill: #20201f;
    transition: fill var(--transition)
}

.post {
    position: relative;
    display: block
}

.post:hover picture:after {
    opacity: .2
}

.post:hover img {
    transform: scale(1.05)
}

.post:hover .post__arrow .arrow {
    animation: post-arrow-in .4s forwards
}

.post picture {
    position: relative;
    margin-bottom: 24px;
    overflow: hidden
}

.post picture:after {
    content: "";
    position: absolute;
    inset: 0;
    background: #20201f;
    opacity: 0;
    transition: opacity var(--transition)
}

.post img {
    width: 100%;
    transition: transform var(--transition-slow);
    height: auto
}

.post__date {
    margin-bottom: 2px;
    font-size: 18px;
    color: #979797
}

.post__title {
    padding-right: 54px;
    font-family: domaine;
    font-size: 24px;
    line-height: 1.333
}

.post__arrow {
    position: absolute;
    right: 0;
    bottom: 14px;
    width: 31px;
    height: 7px;
    overflow: hidden
}

.post__arrow .arrow {
    animation: post-arrow-out .4s forwards
}

@keyframes post-arrow-in {
    0% {
        transform: translate(-100%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes post-arrow-out {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(100%)
    }
}

.posts .head {
    text-transform: lowercase
}

.posts__list {
    margin-bottom: -32px
}

@media only screen and (min-width: 768px) {
    .posts__list {
        display:flex;
        margin: 0 -20px
    }
}

@media only screen and (min-width: 1024px) {
    .posts__list {
        margin:0 -40px
    }
}

@media only screen and (min-width: 1260px) {
    .posts__list {
        margin:0 -80px
    }
}

.posts__list li {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .posts__list li {
        flex:1;
        margin: 0 20px
    }
}

@media only screen and (min-width: 1024px) {
    .posts__list li {
        margin:0 40px
    }
}

@media only screen and (min-width: 1260px) {
    .posts__list li {
        margin:0 80px
    }
}

.samples {
    background: #f2f0ed;
    overflow: hidden
}

@media only screen and (min-width: 1024px) {
    .samples {
        margin-top:100px;
        padding: 0
    }
}

@media only screen and (min-width: 1024px) {
    .samples__inner {
        display:flex;
        align-items: center;
        height: 480px
    }
}

@media only screen and (min-width: 1024px) {
    .samples__col:nth-child(1) {
        flex-grow:1
    }
}

.samples__col:nth-child(2) {
    margin: 32px 0
}

@media only screen and (min-width: 768px) {
    .samples__col:nth-child(2) {
        width:320px
    }
}

@media only screen and (min-width: 1024px) {
    .samples__col:nth-child(2) {
        flex:0 0 320px;
        margin: 0 80px
    }
}

@media only screen and (min-width: 1520px) {
    .samples__col:nth-child(2) {
        margin:0 160px
    }
}

.samples__col:nth-child(2) .btn,.samples__col:nth-child(2) .form .actions button[type=submit],.form .actions .samples__col:nth-child(2) button[type=submit],.samples__col:nth-child(2) .subscribe .fui-btn,.subscribe .samples__col:nth-child(2) .fui-btn,.samples__col:nth-child(2) .fui-i .fui-submit,.fui-i .samples__col:nth-child(2) .fui-submit {
    width: 100%
}

.samples__col:nth-child(2) .btn:not(:last-child),.samples__col:nth-child(2) .form .actions button[type=submit]:not(:last-child),.form .actions .samples__col:nth-child(2) button[type=submit]:not(:last-child),.samples__col:nth-child(2) .subscribe .fui-btn:not(:last-child),.subscribe .samples__col:nth-child(2) .fui-btn:not(:last-child),.samples__col:nth-child(2) .fui-i .fui-submit:not(:last-child),.fui-i .samples__col:nth-child(2) .fui-submit:not(:last-child) {
    margin-bottom: 16px
}

@media only screen and (min-width: 1024px) {
    .samples__col:nth-child(3) {
        align-self:stretch;
        flex: 0 0 160px;
        max-width: 160px
    }
}

@media only screen and (min-width: 1520px) {
    .samples__col:nth-child(3) {
        flex:0 0 320px;
        max-width: 320px
    }
}

@media only screen and (min-width: 1024px) {
    .samples__col:nth-child(3) picture {
        width:240px;
        height: 100%
    }
}

@media only screen and (min-width: 1520px) {
    .samples__col:nth-child(3) picture {
        width:400px
    }
}

@media only screen and (min-width: 1760px) {
    .samples__col:nth-child(3) picture {
        width:calc(50vw - 480px)
    }
}

.samples__col:nth-child(3) img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.samples .content .large-title {
    margin-bottom: 16px
}

@media only screen and (min-width: 1024px) {
    .samples--mt0 {
        margin-top:0
    }
}

.text .container {
    max-width: 1120px
}

.text .content h2,.text .content h3,.text .content h4 {
    text-transform: lowercase
}

@media only screen and (min-width: 768px) {
    .feature__row {
        display:flex;
        align-items: center
    }
}

@media only screen and (min-width: 768px) {
    .feature__row--video {
        align-items:flex-start
    }
}

@media only screen and (min-width: 768px) {
    .feature__col {
        flex:0 0 50%
    }
}

.feature__col:first-child {
    margin-bottom: 40px
}

@media only screen and (min-width: 768px) {
    .feature__col:first-child {
        margin:0
    }
}

@media only screen and (min-width: 768px) {
    .feature__col:last-child {
        padding-left:40px
    }
}

@media only screen and (min-width: 1024px) {
    .feature__col:last-child {
        padding-left:80px
    }
}

@media only screen and (min-width: 1260px) {
    .feature__col:last-child {
        padding-left:160px
    }
}

@media only screen and (min-width: 768px) {
    .feature__col--video {
        position:sticky;
        top: 1rem
    }
}

@media only screen and (min-width: 768px) {
    .feature--reversed .feature__row {
        flex-direction:row-reverse
    }
}

@media only screen and (min-width: 768px) {
    .feature--reversed .feature__col:last-child {
        padding:0 40px 0 0
    }
}

@media only screen and (min-width: 1024px) {
    .feature--reversed .feature__col:last-child {
        padding:0 80px 0 0
    }
}

@media only screen and (min-width: 1260px) {
    .feature--reversed .feature__col:last-child {
        padding:0 160px 0 0
    }
}

.feature--title .content h2 {
    font-family: domaine;
    font-size: 48px;
    line-height: 1.167
}

.feature .video-wrapper {
    position: relative;
    padding-top: 56.25%
}

.feature .video-frame {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.feature--dark {
    background-color: #20201f;
    color: #f2f0ed
}

.bundle {
    margin-bottom: 60px
}

@media only screen and (min-width: 768px) {
    .bundle {
        margin-bottom:100px
    }
}

@media only screen and (min-width: 1260px) {
    .bundle {
        margin:0
    }
}

@media only screen and (min-width: 768px) {
    .bundle__item {
        display:flex;
        align-items: center
    }
}

@media only screen and (min-width: 768px) {
    .bundle__item:nth-child(2n) {
        flex-direction:row-reverse
    }
}

.bundle__item:not(:last-child) {
    margin-bottom: 120px
}

@media only screen and (min-width: 768px) {
    .bundle__item:not(:last-child) {
        margin-bottom:200px
    }
}

@media only screen and (min-width: 768px) {
    .bundle__item:nth-child(2n) .bundle__col:nth-child(2) {
        padding:0 40px 0 0
    }
}

@media only screen and (min-width: 1024px) {
    .bundle__item:nth-child(2n) .bundle__col:nth-child(2) {
        padding:0 160px 0 0
    }
}

.bundle__col {
    position: relative
}

@media only screen and (min-width: 768px) {
    .bundle__col {
        flex:0 0 50%
    }
}

.bundle__col:nth-child(2) {
    margin-top: 32px
}

@media only screen and (min-width: 768px) {
    .bundle__col:nth-child(2) {
        margin:0;
        padding-left: 40px
    }
}

@media only screen and (min-width: 1024px) {
    .bundle__col:nth-child(2) {
        padding-left:160px
    }
}

.bundle__box {
    position: absolute;
    right: 0;
    bottom: 0;
    padding: 20px 0 0 20px;
    background: white
}

@media only screen and (min-width: 1024px) {
    .bundle__box {
        padding:40px 0 0 40px
    }
}

.bundle__box a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    transition: opacity var(--transition)
}

@media only screen and (min-width: 1024px) {
    .bundle__box a {
        width:120px;
        height: 120px
    }
}

.bundle__box a:hover {
    opacity: .7
}

.bundle__box svg {
    fill: #fff
}

.bundle .content h2 {
    margin-bottom: 16px;
    font-family: domaine;
    font-size: 48px;
    line-height: 1.167
}

.bundle .content h3 {
    margin-bottom: 20px;
    font-size: 32px;
    line-height: 1.25
}

.bundle .content p {
    margin-bottom: 32px
}

.main {
    margin-bottom: 20px
}

.main .container {
    padding: 0;
    background: var(--page-color)
}

@media only screen and (min-width: 1024px) {
    .main .container {
        display:flex;
        flex-direction: row-reverse
    }
}

.main__col {
    position: relative;
    flex: 0 0 50%
}

.main__col:first-child {
    display: flex
}

.main__col:first-child img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.main__col:last-child {
    padding: 40px 20px
}

@media only screen and (min-width: 768px) {
    .main__col:last-child {
        padding:60px 40px
    }
}

@media only screen and (min-width: 1024px) {
    .main__col:last-child {
        display:flex;
        align-items: center;
        padding: 120px 80px
    }
}

.main .content {
    max-width: 480px;
    color: #fff
}

.main .content h1 {
    margin-bottom: 16px;
    font-family: domaine;
    font-size: 48px;
    line-height: 1.167;
    text-transform: none
}

.main .content h2 {
    margin-bottom: 20px;
    font-size: 32px;
    line-height: 1.25
}

.main .badge {
    position: absolute;
    top: 24px;
    right: 24px
}

@media only screen and (min-width: 768px) {
    .main .badge {
        padding:10px 14px 9px;
        font-size: 21px
    }
}

.main__date {
    margin-bottom: 16px;
    opacity: .6
}

.main__shapes {
    display: flex;
    margin-top: 32px
}

@media only screen and (min-width: 1024px) {
    .main__shapes {
        position:absolute;
        left: 80px;
        bottom: 32px;
        margin: 0
    }
}

.main__shapes li {
    margin-right: 24px
}

.main__shapes li img {
    transform: scale(1.5)
}

.main--product .content h2 {
    margin-bottom: 8px;
    font-weight: 400;
    opacity: .6
}

.main--product .picture {
    width: 100%;
    height: 320px
}

@media only screen and (min-width: 768px) {
    .main--product .picture {
        height:680px
    }
}

.main--product .picture .image {
    height: 100%;
    width: 100%;
    object-fit: cover
}

.main--blog .container {
    background-color: #20201f
}

.main--blog .picture {
    width: 100%;
    height: 320px
}

@media only screen and (min-width: 768px) {
    .main--blog .picture {
        height:680px
    }
}

.main--blog .picture .image {
    height: 100%;
    width: 100%;
    object-fit: cover
}

@media only screen and (min-width: 768px) {
    .layout {
        display:flex
    }
}

.layout__open {
    position: fixed;
    top: 122px;
    left: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #20201f;
    font-size: 0
}

@media only screen and (min-width: 768px) {
    .layout__open {
        display:none
    }
}

.layout__open svg {
    fill: #fff
}

.layout__sidebar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100%;
    padding: 100px 20px 60px;
    background: white;
    opacity: 0;
    transition: opacity var(--transition);
    pointer-events: none;
    overflow: auto
}

@media only screen and (min-width: 768px) {
    .layout__sidebar {
        position:static;
        z-index: 0;
        flex: 0 0 240px;
        margin-right: 40px;
        padding: 0;
        opacity: 1;
        pointer-events: all;
        overflow: visible
    }
}

@media only screen and (min-width: 1260px) {
    .layout__sidebar {
        flex:0 0 320px;
        margin-right: 160px
    }
}

.layout__sidebar.visible {
    opacity: 1;
    pointer-events: all
}

.layout__close {
    position: absolute;
    top: 12px;
    right: 12px
}

@media only screen and (min-width: 768px) {
    .layout__close {
        display:none
    }
}

@media only screen and (min-width: 768px) {
    .layout__container {
        flex:0 0 calc(100% - 280px)
    }
}

@media only screen and (min-width: 1260px) {
    .layout__container {
        flex:0 0 calc(100% - 480px)
    }
}

.search {
    position: relative
}

.search input {
    width: 100%;
    height: 56px;
    padding: 0 20px 0 52px;
    background: rgba(242,240,237,.3);
    border: 1px solid transparent;
    border-radius: 4px;
    font-size: 18px;
    transition: background var(--transition),border-color var(--transition)
}

.search input::placeholder {
    color: #979797;
    transition: color var(--transition)
}

.search input:focus {
    background: white;
    border-color: #20201f
}

.search input:focus::placeholder {
    color: #20201f
}

.search svg {
    position: absolute;
    top: 19px;
    left: 17px
}

.search .btn-clear {
    position: absolute;
    top: 17px;
    right: 17px;
    font-size: 1.4rem;
    opacity: .5;
    transition: opacity var(--transition)
}

.search .btn-clear:hover {
    opacity: 1
}

.filters .search {
    margin-bottom: -10px
}

.filters__group {
    margin-top: 44px
}

.filters__group--collections .filters__title {
    padding-bottom: 8px;
    border-bottom: 1px solid #20201f
}

.filters__group--collections>.filters__list>li {
    margin-bottom: 10px;
    border-bottom: 1px solid #f2f0ed
}

.filters__group--collections>.filters__list .filters__list {
    padding: 16px 0 10px 36px
}

.filters__title {
    margin-bottom: 16px;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.25
}

.filters__title--clear {
    display: flex;
    align-items: center;
    gap: .5rem
}

.filters__title--clear .btn-clear {
    display: block;
    width: 20px;
    height: 20px;
    font-weight: 700;
    font-size: 20px;
    opacity: .5
}

.filters__title--clear .btn-clear:hover {
    opacity: 1
}

.filters__list li:not(:last-child) {
    margin-bottom: 16px
}

.card__grid--product-info {
    display: grid;
    grid-template-columns: minmax(0,auto);
    grid-gap: 48px 0;
    width: 100%
}

@media only screen and (min-width: 768px) {
    .card__grid--product-info {
        grid-template-columns:minmax(0,50%) 1fr;
        grid-template-rows: minmax(0,auto) 1fr auto
    }
}

.card__grid--product-info>.card__col,.card__grid--product-info>.card__col:first-child,.card__grid--product-info>.card__col:last-child {
    margin: 0;
    flex: none;
    width: auto;
    max-width: none
}

@media only screen and (min-width: 768px) {
    .card__grid--product-info .gallery {
        grid-column:1/span 1;
        grid-row: 1/span 1
    }
}

@media only screen and (min-width: 768px) {
    .card__grid--product-info .info {
        grid-column:2/span 1;
        grid-row: 1/span 2
    }
}

.card__grid--product-info .info .card__caption {
    margin-bottom: 5px
}

.card__grid--product-info .info .card__caption+.card__caption--title {
    margin-top: 15px
}

@media only screen and (min-width: 768px) {
    .card__grid--product-info .related-projects {
        grid-column:1/span 1;
        grid-row: 2/span 2
    }
}

.card__grid--product-info .related-projects .projects-slider {
    position: relative;
    max-width: 480px;
    margin-left: 0
}

.card__grid--product-info .related-projects .projects-slider .swiper-pagination {
    display: block;
    position: static;
    transform: none;
    margin: 0 auto
}

.card__grid--product-info .related-projects .projects-slider .swiper-pagination-bullet-active {
    background-color: #20201f
}

@media only screen and (min-width: 768px) {
    .card__grid--product-info .related-products {
        grid-column:2/span 1;
        grid-row: 3/span 1
    }
}

.product {
    display: block;
    position: relative
}

.product:hover .product__preview img {
    transform: scale(1.05)
}

.product:hover .product__title {
    border-color: #20201f
}

.product__preview {
    position: relative;
    margin-bottom: 8px;
    overflow: hidden
}

.product__preview img {
    width: 100%;
    transition: transform var(--transition)
}

.product__preview .badge {
    position: absolute;
    top: 8px;
    left: 8px
}

.product__collection {
    color: #979797
}

.product__title {
    display: inline;
    border-bottom: 1px solid transparent;
    font-weight: 400;
    transition: border-color var(--transition)
}

.product--selection {
    cursor: pointer
}

.product--selection input[type=checkbox] {
    display: none
}

.product--selection:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 8px;
    width: 32px;
    height: 32px;
    border: 2px solid #20201f;
    border-radius: 50%
}

.product--selection:after {
    content: "";
    position: absolute;
    right: 9px;
    bottom: 18px;
    width: 13px;
    height: 10px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='10'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.6' d='M11.899 1L5.472 9.054 1 5.054'/%3E%3C/svg%3E");
    transition: background-image var(--transition)
}

.product--selection.active {
    background: #20201f;
    box-shadow: 0 0 0 8px #20201f
}

.product--selection.active:before {
    border-color: #fff
}

.product--selection:not(.active):hover:after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='10'%3E%3Cpath fill='none' stroke='%23666' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.6' d='M11.899 1L5.472 9.054 1 5.054'/%3E%3C/svg%3E")
}

.product--selection.other-options-item {
    padding-bottom: 5px
}

.product--selection.other-options-item .product__preview {
    margin-bottom: 12px
}

.product--selection.other-options-item:before {
    bottom: 1px
}

.product--selection.other-options-item:after {
    bottom: 12px
}

.product--selection.active .product__title {
    color: #fff
}

.product--tool {
    padding-bottom: 8px
}

.product--tool:before,.product--tool:after {
    transform: translateY(4px)
}

.product--tool .product__preview {
    margin-bottom: 16px
}

.product.disabled {
    cursor: not-allowed;
    opacity: .5
}

.products:not(:last-child) {
    margin-bottom: 80px
}

.products__head {
    display: flex;
    align-items: center;
    min-height: 56px;
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .products__head {
        margin-bottom:40px
    }
}

.products__counter {
    flex-shrink: 0;
    margin-left: auto;
    color: #979797;
    text-align: right
}

.products__message {
    margin: -8px 0 32px
}

@media only screen and (min-width: 768px) {
    .products__message {
        margin-bottom:40px
    }
}

@media only screen and (min-width: 1024px) {
    .products__collection {
        display:flex
    }
}

.products__inner,.products__preview {
    flex: 0 0 50%
}

.products__inner {
    display: flex;
    align-items: center;
    padding: 40px 20px
}

@media only screen and (min-width: 768px) {
    .products__inner {
        padding:40px
    }
}

@media only screen and (min-width: 1260px) {
    .products__inner {
        padding:40px 80px
    }
}

.products__inner .content {
    color: #fff
}

.products__inner .content h2 {
    margin-bottom: 16px;
    font-family: domaine;
    font-size: 48px;
    line-height: 1.167
}

.products__inner .content h3 {
    margin: 0
}

.products__preview {
    display: flex
}

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

.products__list {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -12px -32px
}

@media only screen and (min-width: 768px) {
    .products__list {
        margin:0 -20px -40px
    }
}

.products__list li {
    flex: 0 0 50%;
    margin-bottom: 32px;
    padding: 0 12px
}

@media only screen and (min-width: 1024px) {
    .products__list li {
        flex:0 0 33.33%;
        margin-bottom: 40px;
        padding: 0 20px
    }
}

@media only screen and (min-width: 1520px) {
    .products__list li {
        flex:0 0 25%
    }
}

@media only screen and (min-width: 1760px) {
    .products__list li {
        flex:0 0 20%
    }
}

.files h3 {
    display: flex;
    align-items: center;
    margin-bottom: 24px;
    font-size: 24px
}

.files h3 picture {
    margin: -4px 14px 0 -4px
}

.files h3 img {
    width: 32px
}

.files li {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 16px;
    padding-bottom: 16px
}

.files li:not(.title) {
    border-bottom: 1px solid #dcdad6
}

.files li:not(:first-of-type).title {
    margin-top: 56px
}

.files .link {
    top: 2px;
    flex-shrink: 0
}

.files h6 {
    margin-right: 32px;
    font-size: 18px;
    font-weight: 400
}

.files-video {
    position: relative;
    padding-left: 32px
}

.files-video:before {
    content: "";
    position: absolute;
    top: 4px;
    left: 0;
    width: 24px;
    height: 24px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Ccircle cx='12' cy='12' r='12' fill='%2320201F'/%3E%3Cpolygon fill='%23FFF' fill-rule='nonzero' points='11 14.571 11 9 15.5 11.797'/%3E%3C/g%3E%3C/svg%3E")
}

@media only screen and (min-width: 768px) {
    .card__row {
        display:flex
    }
}

.card__row:first-child {
    margin-bottom: 80px
}

@media only screen and (min-width: 768px) {
    .card__row:first-child {
        margin-bottom:160px
    }
}

@media only screen and (min-width: 768px) {
    .card__col {
        flex:0 0 50%;
        max-width: 50%
    }
}

.card__col:first-child {
    margin-bottom: 48px
}

@media only screen and (min-width: 768px) {
    .card__col:first-child {
        padding-right:64px
    }
}

@media only screen and (min-width: 1024px) {
    .card__col:first-child {
        padding-right:104px
    }
}

@media only screen and (min-width: 1260px) {
    .card__col:first-child {
        padding-right:160px
    }
}

@media only screen and (min-width: 768px) {
    .card__col:last-child {
        max-width:640px
    }
}

.card__title {
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid #20201f
}

.card__section:not(:last-child) {
    margin-bottom: 48px
}

.card__section .btn,.card__section .form .actions button[type=submit],.form .actions .card__section button[type=submit],.card__section .subscribe .fui-btn,.subscribe .card__section .fui-btn,.card__section .fui-i .fui-submit,.fui-i .card__section .fui-submit {
    width: 100%;
    justify-content: center
}

.card__caption {
    margin-bottom: 16px;
    font-size: 18px
}

.card__availability {
    display: flex
}

.card__availability li:not(:last-child) {
    margin-right: 64px
}

.card__type {
    display: flex;
    align-items: center;
    margin-bottom: 10px
}

.card__type picture {
    width: 24px;
    height: 24px;
    margin-right: 8px
}

.card__type picture img {
    transform: scale(1.5)
}

.card__value {
    font-size: 16px
}

.card .project {
    max-width: 480px
}

.gallery__preview {
    margin-bottom: 24px
}

.gallery__thumbs {
    display: none;
    position: relative
}

@media only screen and (min-width: 1024px) {
    .gallery__thumbs {
        display:block
    }
}

.gallery__thumbs:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    height: 100%;
    background-image: linear-gradient(to right,transparent,white);
    aspect-ratio: 1/2;
    pointer-events: none
}

.gallery__thumbs img {
    aspect-ratio: 1;
    object-fit: cover
}

.gallery__next {
    display: none
}

@media only screen and (min-width: 1024px) {
    .gallery__next {
        position:absolute;
        top: calc(50% - 32px);
        right: -76px;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 64px;
        height: 64px;
        border: 1px solid #20201f;
        border-radius: 50%;
        transition: background var(--transition)
    }
}

.gallery__next:hover {
    background: #20201f
}

.gallery__next:hover svg {
    stroke: #fff
}

.gallery__next svg {
    margin-left: 4px;
    stroke: #20201f;
    transition: stroke var(--transition)
}

.gallery .swiper-slide a {
    display: block
}

.gallery .swiper-pagination {
    display: flex;
    margin-top: 24px
}

.gallery .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin-right: 10px;
    border: 1px solid #20201f
}

.gallery .swiper-pagination-bullet-active {
    background: #20201f
}

.related {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -12px -32px
}

@media only screen and (min-width: 768px) {
    .related {
        margin:0 -20px -40px
    }
}

.related li {
    flex: 0 0 50%;
    margin-bottom: 32px;
    padding: 0 12px
}

@media only screen and (min-width: 1024px) {
    .related li {
        flex:0 0 33.33%;
        margin-bottom: 40px;
        padding: 0 20px
    }
}

.featured {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0 -12px 32px
}

@media only screen and (min-width: 768px) {
    .featured {
        margin:0 -20px -40px
    }
}

.featured li {
    flex: 0 0 50%;
    margin-bottom: 32px;
    padding: 0 12px
}

@media only screen and (min-width: 768px) {
    .featured li {
        flex:0 0 25%
    }
}

@media only screen and (min-width: 1024px) {
    .featured li {
        flex:0 0 20%;
        margin-bottom: 40px;
        padding: 0 20px
    }
}

@media only screen and (min-width: 1260px) {
    .featured li {
        flex:0 0 14.2857142857%
    }
}

.back {
    padding: 60px 0 16px
}

@media only screen and (min-width: 768px) {
    .back {
        padding:100px 0 32px
    }
}

.back .container:before {
    content: "";
    display: block;
    height: 1px;
    margin-bottom: 20px;
    background: #dcdad6
}

@media only screen and (min-width: 768px) {
    .back .container:before {
        margin-bottom:40px
    }
}

.back__link {
    display: inline-flex;
    align-items: center;
    font-weight: 700
}

.back__link:hover .back__arrow .arrow:first-child {
    animation: arrow1 .4s forwards
}

.back__link:hover .back__arrow .arrow:last-child {
    animation: arrow2 .4s forwards
}

.back__arrow {
    position: relative;
    top: -2px;
    width: 31px;
    height: 7px;
    margin-right: 24px;
    transform: rotate(180deg);
    overflow: hidden
}

.back__arrow .arrow:first-child {
    position: absolute;
    top: 0;
    left: 0
}

.back--simple {
    padding: 0
}

@keyframes arrow1 {
    0% {
        transform: translate(-200%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes arrow2 {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(200%)
    }
}

@media only screen and (min-width: 768px) {
    .grid {
        display:flex;
        flex-wrap: wrap;
        margin: 0 -40px -64px
    }
}

@media only screen and (min-width: 768px) and (min-width: 768px) {
    .grid {
        margin-bottom:-160px
    }
}

.grid li {
    margin-bottom: 64px
}

@media only screen and (min-width: 768px) {
    .grid li {
        flex:0 0 50%;
        margin-bottom: 160px;
        padding: 0 40px
    }
}

@media only screen and (min-width: 1024px) {
    .grid li {
        flex:0 0 33.33%
    }
}

.pager {
    display: flex;
    justify-content: center;
    margin-top: 64px
}

@media only screen and (min-width: 768px) {
    .pager {
        margin-top:160px
    }
}

.pager li {
    margin: 0 8px
}

.pager a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    line-height: 1.1;
    color: #979797;
    text-align: center;
    transition: background var(--transition),color var(--transition)
}

.pager a:hover,.pager a.active {
    color: #20201f
}

.pager a:hover span,.pager a.active span {
    border-color: #20201f
}

.pager a.disabled {
    cursor: default;
    user-select: none;
    pointer-events: none
}

.pager a.disabled svg {
    stroke: #979797
}

.pager__arrow {
    border-radius: 50%
}

.pager__arrow:not(.disabled):hover {
    background: #f2f0ed
}

.pager span {
    min-width: 10px;
    border-bottom: 2px solid transparent;
    transition: border-color var(--transition)
}

.pager svg {
    width: 8px;
    height: 16px;
    stroke: #20201f
}

.images__list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0 -10px -20px
}

@media only screen and (min-width: 768px) {
    .images__list {
        margin:0 -60px -160px
    }
}

.images__list li {
    margin: 0 10px 20px
}

@media only screen and (min-width: 768px) {
    .images__list li {
        margin:0 60px 160px
    }
}

.images__list li:nth-child(1) {
    flex-grow: 1
}

.images__list li:nth-child(3n),.images__list li:nth-child(3n-1) {
    flex: 0 0 calc(50% - 20px);
    max-width: 580px;
    min-height: 720px
}

@media only screen and (min-width: 768px) {
    .images__list li:nth-child(3n),.images__list li:nth-child(3n-1) {
        flex:0 0 calc(50% - 120px)
    }
}

.images__list li:nth-child(3n+4) {
    max-width: 1280px
}

.images__list li a {
    display: flex;
    height: 100%
}

.images__list li a .image {
    height: 100%;
    object-fit: cover
}

.tabs {
    display: flex;
    justify-content: center;
    margin: 0 -12px 40px
}

@media only screen and (min-width: 768px) {
    .tabs {
        margin:0 -20px 80px
    }
}

.tabs li {
    margin: 0 12px
}

@media only screen and (min-width: 768px) {
    .tabs li {
        margin:0 20px
    }
}

.tabs a {
    position: relative;
    display: inline-flex;
    padding-bottom: 2px;
    font-size: 18px;
    line-height: 1.2;
    overflow: hidden
}

.tabs a:hover:before {
    animation: tabsline1 .4s forwards
}

.tabs a.active:before {
    animation: tabsline1 .4s forwards
}

.tabs a:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #20201f;
    animation: tabsline2 .4s forwards
}

@keyframes tabsline1 {
    0% {
        transform: translate(-100%)
    }

    to {
        transform: translate(0)
    }
}

@keyframes tabsline2 {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(100%)
    }
}

.masonry {
    margin-bottom: -40px
}

@media only screen and (min-width: 768px) {
    .masonry {
        margin:0 -20px -64px
    }
}

@media only screen and (min-width: 1260px) {
    .masonry {
        margin:0 -60px -120px
    }
}

@media only screen and (min-width: 1520px) {
    .masonry {
        margin:0 -80px -120px
    }
}

.masonry li {
    margin-bottom: 40px
}

@media only screen and (min-width: 768px) {
    .masonry li {
        width:50%;
        margin-bottom: 40px;
        padding: 0 20px
    }
}

@media only screen and (min-width: 1260px) {
    .masonry li {
        width:33.33%;
        margin-bottom: 120px;
        padding: 0 60px;
        height: 450px;
    }
}

@media only screen and (min-width: 1520px) {
    .masonry li {
        padding:0 80px
    }
}

@media only screen and (min-width: 768px) {
    .subscribe .container {
        display:flex;
        height: 640px
    }
}

.subscribe__inner {
    padding: 60px 40px;
    background: #20201f;
    color: #fff;
    text-align: center
}

@media only screen and (min-width: 768px) {
    .subscribe__inner {
        display:flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        flex: 0 0 50%;
        padding: 60px
    }
}

@media only screen and (min-width: 1024px) {
    .subscribe__inner {
        flex:0 0 60%
    }
}

.subscribe .content {
    max-width: 406px;
    margin: 0 auto 32px
}

.subscribe .content h2 {
    margin-bottom: 16px
}

.subscribe__preview {
    background: #20201f
}

@media only screen and (min-width: 768px) {
    .subscribe__preview {
        display:flex;
        flex: 0 0 50%
    }
}

@media only screen and (min-width: 1024px) {
    .subscribe__preview {
        flex:0 0 40%
    }
}

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

.subscribe__form {
    width: 100%;
    max-width: 560px
}

@media only screen and (min-width: 1024px) {
    .subscribe .fui-page {
        display:flex;
        align-items: flex-start
    }
}

.subscribe .fui-page-container {
    flex-grow: 1
}

.subscribe .fui-row {
    margin: 0
}

.subscribe .fui-field {
    margin: 0 0 16px;
    padding: 0
}

@media only screen and (min-width: 1024px) {
    .subscribe .fui-field {
        margin:0 -1px 0 0
    }
}

.subscribe .fui-label {
    display: none
}

.subscribe .fui-input {
    height: 56px;
    padding: 0 24px;
    background: #20201f;
    border-color: #fff;
    color: #fff
}

.subscribe .fui-input:hover {
    border-color: #fff
}

.subscribe .fui-btn-wrapper {
    margin: 0;
    padding: 0
}

.subscribe .fui-btn {
    width: 100%;
    margin: 0;
    border-radius: 0;
    font-family: brown
}

@media only screen and (min-width: 1024px) {
    .detail__row {
        display:flex;
        justify-content: space-between;
        margin: 0 -40px
    }
}

@media only screen and (min-width: 1260px) {
    .detail__row {
        margin:0 -80px
    }
}

@media only screen and (min-width: 1024px) {
    .detail__col {
        flex:1;
        padding: 0 40px
    }
}

@media only screen and (min-width: 1260px) {
    .detail__col {
        padding:0 80px
    }
}

.detail__col:first-child {
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .detail__col:first-child {
        max-width:834px
    }
}

.detail__col:first-child h1 {
    margin-bottom: 12px;
    font-family: domaine;
    font-size: 56px;
    line-height: 1
}

.detail__col:first-child h2 {
    margin-bottom: 36px
}

.detail__col:first-child table {
    width: auto
}

.detail__col:first-child table td {
    padding-top: 4px
}

.detail__col:first-child table td:first-child {
    font-weight: 700
}

.detail__col:first-child table td:not(:last-child) {
    padding-right: 16px
}

@media only screen and (min-width: 768px) {
    .detail__col:last-child {
        max-width:800px
    }
}

.image a {
    display: block;
    position: relative
}

.image a:not(:first-child) {
    display: none
}

.image__counter {
    position: absolute;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: #20201f;
    font-size: 18px;
    font-weight: 700;
    color: #fff
}

@media only screen and (min-width: 768px) {
    .image__counter {
        width:120px;
        height: 120px;
        font-size: 32px
    }
}

.page>.container {
    padding: 0
}

@media only screen and (min-width: 1024px) {
    .page>.container {
        display:flex;
        align-items: flex-start;
        max-width: 1600px
    }
}

@media only screen and (min-width: 1024px) {
    .page__sections {
        width:100%
    }
}

.page__sticky {
    padding: 0 20px
}

@media only screen and (min-width: 768px) {
    .page__sticky {
        padding:0 40px
    }
}

@media only screen and (min-width: 1024px) {
    .page__sticky {
        position:sticky;
        top: 100px;
        width: 52px;
        margin-left: -52px;
        padding: 100px 0
    }
}

@media only screen and (min-width: 1024px) {
    .page__sticky .share {
        position:relative;
        right: 14px
    }
}

.share {
    display: flex
}

@media only screen and (min-width: 1024px) {
    .share {
        display:block
    }
}

.share li:not(:last-child) {
    margin-right: 12px
}

@media only screen and (min-width: 1024px) {
    .share li:not(:last-child) {
        margin:0 0 12px
    }
}

.share a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    background: white;
    border: 1px solid #20201f;
    border-radius: 50%;
    transition: background var(--transition)
}

.share a:hover {
    background: #20201f
}

.share a:hover svg {
    fill: #fff
}

.share a svg {
    fill: #20201f;
    transition: fill var(--transition)
}

.contacts {
    margin-bottom: 60px
}

@media only screen and (min-width: 768px) {
    .contacts {
        margin-bottom:100px
    }
}

.contacts .container {
    padding: 0
}

@media only screen and (min-width: 1024px) {
    .contacts .container {
        display:flex
    }
}

.contacts__inner {
    padding: 60px 20px;
    background: #20201f;
    color: #fff
}

@media only screen and (min-width: 768px) {
    .contacts__inner {
        padding:80px 40px
    }
}

@media only screen and (min-width: 1024px) {
    .contacts__inner {
        flex:0 0 50%;
        padding: 80px
    }
}

@media only screen and (min-width: 1260px) {
    .contacts__inner {
        padding:120px 80px
    }
}

.contacts__form {
    padding: 60px 20px;
    background: #f2f0ed
}

@media only screen and (min-width: 768px) {
    .contacts__form {
        padding:80px 40px
    }
}

@media only screen and (min-width: 1024px) {
    .contacts__form {
        flex:0 0 50%;
        padding: 80px
    }
}

@media only screen and (min-width: 1260px) {
    .contacts__form {
        padding:120px 160px
    }
}

.contacts__form .title {
    margin-bottom: 16px
}

.contacts__head {
    max-width: 416px;
    margin-bottom: 32px
}

.contacts .content h2 {
    margin-bottom: 16px
}

.contacts .content a {
    border-bottom: 1px solid transparent;
    color: #fff;
    transition: border-color var(--transition)
}

.contacts .content a:hover {
    border-color: #fff
}

.contacts__select {
    display: block;
    width: 100%;
    max-width: 640px;
    height: 56px;
    margin-bottom: 64px;
    padding: 0 20px;
    background-color: #20201f;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='6' viewBox='0 0 9 6'%3E%3Cpolygon fill='%23FFF' fill-rule='evenodd' points='9 0 0 0 4.5 6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: calc(100% - 24px) 50%;
    background-size: 9px 6px;
    border: 1px solid white;
    font-size: 18px;
    color: #fff;
    appearance: none;
    transition: border-color var(--transition)
}

.contacts__select:hover {
    border-color: #ffffff80
}

@media only screen and (min-width: 1260px) {
    .contacts__group {
        display:flex;
        flex-direction: column;
        gap: 3rem
    }
}

.contacts__group .email-placeholder {
    display: none;
    visibility: hidden
}

.contacts__group .content:not(:last-child) {
    margin-bottom: 32px
}

@media only screen and (min-width: 1260px) {
    .contacts__group .content:not(:last-child) {
        margin:0 80px 0 0
    }
}

@media only screen and (min-width: 1520px) {
    .contacts__group .content:not(:last-child) {
        margin:0 120px 0 0
    }
}

.contacts__group .content .btn,.contacts__group .content .form .actions button[type=submit],.form .actions .contacts__group .content button[type=submit],.contacts__group .content .fui-i .fui-submit,.fui-i .contacts__group .content .fui-submit,.contacts__group .content .subscribe .fui-btn,.subscribe .contacts__group .content .fui-btn {
    color: inherit;
    transition: background var(--transition),color var(--transition);
    margin: -13px 0 -11px -23px
}

.contacts__group .content .btn:hover,.contacts__group .content .form .actions button[type=submit]:hover,.form .actions .contacts__group .content button[type=submit]:hover,.contacts__group .content .fui-i .fui-submit:hover,.fui-i .contacts__group .content .fui-submit:hover,.contacts__group .content .subscribe .fui-btn:hover,.subscribe .contacts__group .content .fui-btn:hover {
    color: #20201f
}

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

.selection__title {
    margin-right: 32px;
    font-size: 16px;
    font-weight: 700
}

@media only screen and (min-width: 768px) {
    .selection__title {
        margin-right:80px;
        font-size: 24px
    }
}

.selection .btn,.selection .form .actions button[type=submit],.form .actions .selection button[type=submit],.selection .fui-i .fui-submit,.fui-i .selection .fui-submit,.selection .subscribe .fui-btn,.subscribe .selection .fui-btn {
    flex-shrink: 0
}

.selection--sticky {
    position: fixed;
    left: 0;
    bottom: 0;
    z-index: 99;
    justify-content: center;
    width: 100%;
    padding: 10px 20px;
    background: #ffcf22
}

@media only screen and (min-width: 768px) {
    .selection--sticky {
        padding:20px
    }
}

@media only screen and (min-width: 1520px) {
    .selection--sticky {
        padding:32px
    }
}

.orders {
    padding-top: 32px;
    border-top: 1px solid #f2f0ed
}

@media only screen and (min-width: 768px) {
    .orders {
        padding-top:64px
    }
}

@media only screen and (min-width: 768px) {
    .orders .container {
        display:flex
    }
}

.orders .back {
    min-width: 100px;
    margin-bottom: 32px
}

@media only screen and (min-width: 768px) {
    .orders .back {
        margin:8px 40px 0 0
    }
}

@media only screen and (min-width: 1520px) {
    .orders .back {
        margin:8px 0 0
    }
}

@media only screen and (min-width: 768px) {
    .orders__inner {
        width:100%;
        max-width: 960px;
        margin: 0 auto
    }
}

@media only screen and (min-width: 1520px) {
    .orders__inner {
        transform:translate(-50px)
    }
}

.orders__section:not(:last-child) {
    margin-bottom: 64px
}

@media only screen and (min-width: 768px) {
    .orders__section:not(:last-child) {
        margin-bottom:80px
    }
}

.orders__head {
    display: flex;
    align-items: center;
    margin-bottom: 24px
}

.orders__head h2 {
    margin-right: 32px;
    font-size: 24px
}

.orders__head .link {
    opacity: .5;
    transition: opacity var(--transition)
}

.orders__head .link:hover {
    opacity: 1
}

.orders__products {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -12px -32px
}

@media only screen and (min-width: 768px) {
    .orders__products {
        margin:0 -20px -40px
    }
}

.orders__products li {
    flex: 0 0 50%;
    margin-bottom: 32px;
    padding: 0 12px
}

@media only screen and (min-width: 768px) {
    .orders__products li {
        flex:0 0 33.33%;
        margin-bottom: 40px;
        padding: 0 20px
    }
}

@media only screen and (min-width: 1520px) {
    .orders__products li {
        flex:0 0 25%
    }
}

@media only screen and (min-width: 768px) {
    .orders__products--other li {
        flex:0 0 25%
    }
}

.orders__products--other li .other-options-item input {
    width: 0;
    height: 0;
    visibility: hidden;
    display: none
}

.docs__section:not(:last-child) {
    margin-bottom: 56px
}

.image-grid .content+.images__grid {
    margin-top: 4rem
}

.image-grid .images__grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 20px
}

@media only screen and (min-width: 768px) {
    .image-grid .images__grid {
        grid-template-columns:repeat(2,1fr);
        grid-gap: 40px
    }
}

@media only screen and (min-width: 1260px) {
    .image-grid .images__grid {
        grid-template-columns:repeat(3,1fr);
        grid-gap: 80px
    }
}

.image-grid .images__grid li a {
    position: relative;
    display: flex;
    height: 100%;
    padding-top: 80%
}

.image-grid .images__grid li a .image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    transition: transform var(--transition),box-shadow var(--transition)
}

.image-grid .images__grid li a:hover .image {
    transform: scale(1.025);
    box-shadow: 0 0 20px #00000040
}

.quote .container {
    display: flex;
    flex-direction: column;
    max-width: 1120px
}

.quote blockquote {
    font-size: 2rem;
    position: relative
}

.quote blockquote:before {
    content: '"';
    display: none;
    font-size: 15rem;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
    transform: rotate(-15deg) translate(-1rem) translateY(-5rem);
    opacity: .1;
    z-index: -1
}

@media only screen and (min-width: 768px) {
    .quote blockquote:before {
        display:block
    }
}

.quote blockquote p:before,.quote blockquote p:after {
    content: '"'
}

.quote .author {
    align-self: flex-end;
    font-weight: 300;
    opacity: .5
}

.cta-button .container {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    max-width: 1120px
}

@media only screen and (min-width: 768px) {
    .cta-button .container {
        justify-content:center
    }
}

.cta-button .container .btn,.cta-button .container .form .actions button[type=submit],.form .actions .cta-button .container button[type=submit],.cta-button .container .fui-i .fui-submit,.fui-i .cta-button .container .fui-submit,.cta-button .container .subscribe .fui-btn,.subscribe .cta-button .container .fui-btn {
    display: block;
    width: 100%
}

@media only screen and (min-width: 768px) {
    .cta-button .container .btn,.cta-button .container .form .actions button[type=submit],.form .actions .cta-button .container button[type=submit],.cta-button .container .fui-i .fui-submit,.fui-i .cta-button .container .fui-submit,.cta-button .container .subscribe .fui-btn,.subscribe .cta-button .container .fui-btn {
        width:auto
    }
}

@media only screen and (min-width: 768px) {
    .form .container {
        display:flex
    }
}

.form .picture {
    margin-bottom: 2rem
}

@media only screen and (min-width: 768px) {
    .form .picture {
        max-width:45%;
        margin-right: 5%;
        margin-bottom: 0
    }
}

.form .content {
    width: 100%
}

.form .field-group {
    display: flex;
    flex-direction: column
}

.form .field-group+.field-group,.form .field-group+.actions {
    margin-top: 16px
}

.form .field-group label {
    appearance: none;
    width: 100%;
    color: #20201f;
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.25;
    padding: 0;
    margin: 0 0 4px
}

.form .field-group input,.form .field-group textarea,.form .field-group select {
    appearance: none;
    display: block;
    width: 100%;
    font-family: inherit;
    font-size: 18px;
    line-height: 30px;
    border: 1px solid #20201f;
    margin: 0;
    padding: 12px 24px;
    transition-duration: .15s;
    transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform;
    transition-timing-function: cubic-bezier(.4,0,.2,1)
}

.form .field-group input::placeholder,.form .field-group textarea::placeholder,.form .field-group select::placeholder {
    white-space-collapse: preserve;
    text-wrap: nowrap;
    overflow-wrap: normal;
    overflow-x: hidden;
    overflow-y: hidden;
    line-height: initial
}

.form .field-group select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='6' viewBox='0 0 9 6'%3E%3Cpolygon fill='%2320201f' fill-rule='evenodd' points='9 0 0 0 4.5 6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: calc(100% - 24px) 50%;
    background-size: 9px 6px;
    padding-right: 50px
}

.form .actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    justify-content: center
}

.form .actions button[type=submit] {
    padding: 13px 23px 11px;
    justify-content: center;
    width: 100%
}

.form .actions a {
    font-size: 15px
}

.product-info {
    padding-bottom: 0
}

.product-info .projects {
    display: flex;
    flex-direction: column;
    gap: 2rem
}

.product-info .projects .picture {
    padding-top: 75%
}

.product-info .projects .picture .image {
    object-fit: cover
}

.product-info .card__section--properties {
    position: relative;
    max-height: 11.5rem;
    overflow: hidden;
    will-change: max-height;
    transition: max-height var(--transition)
}

.product-info .card__section--properties:after {
    content: "";
    display: block;
    width: 100%;
    height: 5rem;
    background: linear-gradient(to bottom,rgba(255,255,255,0) 0%,rgba(255,255,255,.5) 30%,rgba(255,255,255,.9) 50%,rgb(255,255,255) 100%);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
    will-change: opacity;
    transition: opacity var(--transition)
}

.product-info .card__section--properties .show-more {
    display: inline-flex;
    align-items: center;
    width: auto;
    height: auto;
    text-align: left;
    cursor: pointer;
    font-size: 14px;
    text-transform: uppercase;
    font-weight: 700;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 3;
    transition: opacity var(--transition)
}

.product-info .card__section--properties .show-more i {
    display: block;
    width: 6px;
    height: 6px;
    margin-left: 6px;
    border-bottom: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: rotate(45deg) translateY(-5px)
}

.product-info .card__section--properties .show-more:hover {
    opacity: .5
}

.product-info .card__section--properties.open {
    max-height: 10000rem
}

.product-info .card__section--properties.open:after {
    opacity: 0
}

.product-info .card__section--properties.open .show-more {
    display: none;
    visibility: hidden
}

.product-info .card__col hr {
    margin: 2rem 0;
    border: 1px solid #eee
}

#blogsOverview .not-found {
    display: flex;
    justify-content: center
}

nav.lang-nav {
    padding: 0;
    border: none;
    font-size: 16px;
    color: #20201f;
    transition: opacity var(--transition);
    appearance: none;
    cursor: pointer
}

nav.lang-nav .lang-nav__list-item {
    position: relative;
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0
}

nav.lang-nav .lang-nav__list-item>a {
    background-color: transparent;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath fill='%23000' d='M8 1.477L4.49 4.486a.75.75 0 0 1-.881.072l-.098-.072L0 1.477.979.335 4 2.923 7.021.335 8 1.477z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 100% 50%;
    background-size: 8px 5px;
    padding-right: 18px;
    pointer-events: none
}

nav.lang-nav .lang-nav__list-item .lang-nav__sublist {
    clip-path: inset(0 0 100% 0);
    position: absolute;
    right: 0;
    background: white;
    box-shadow: 0 10px 15px -3px #00000026;
    transition: clip-path var(--transition)
}

nav.lang-nav .lang-nav__list-item .lang-nav__sublist-item {
    display: flex;
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;
    justify-content: center
}

nav.lang-nav .lang-nav__list-item .lang-nav__sublist-item .nav__link {
    padding: 12px;
    text-align: center;
    width: 100%;
    transition: background-color var(--transition),color var(--transition)
}

nav.lang-nav .lang-nav__list-item .lang-nav__sublist-item .nav__link:hover {
    background-color: #20201f;
    color: #fff
}

nav.lang-nav .lang-nav__list-item .lang-nav__sublist-item:not(:first-of-type) .nav__link {
    border-top: 1px solid lightgray
}

nav.lang-nav .lang-nav__list-item:hover .lang-nav__sublist {
    clip-path: inset(-100%)
}

.footer__links nav.lang-nav .lang-nav__list-item>a {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath fill='%23fff' d='M8 1.477L4.49 4.486a.75.75 0 0 1-.881.072l-.098-.072L0 1.477.979.335 4 2.923 7.021.335 8 1.477z'/%3E%3C/svg%3E")
}

.footer__links nav.lang-nav .lang-nav__list-item .lang-nav__sublist {
    left: 0;
    top: 0;
    background: #20201f;
    color: #fff;
    clip-path: inset(100% 0 0 0);
    transform: translateY(calc(-100% - 12px));
    box-shadow: 0 10px 15px -3px #000000a6
}

.footer__links nav.lang-nav .lang-nav__list-item .lang-nav__sublist-item .nav__link:hover {
    background-color: #fff;
    color: #20201f
}

.footer__links nav.lang-nav .lang-nav__list-item:hover .lang-nav__sublist {
    clip-path: inset(-100%)
}

.section.account .title {
    text-align: center
}

.section.account .title+.account-actions {
    transform: translateY(-30px)
}

.section.account .account-actions {
    text-align: center
}

.section.account .alert {
    color: #20201f;
    background-color: #f2f2f2;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1rem;
    margin: 0 auto 2rem;
    max-width: 400px;
    text-align: center
}

.section.account .alert-succes {
    background-color: #ecfaeb
}

.section.account .alert-warning {
    color: #e6b000;
    background-color: #fff7db
}

.section.account .alert-error {
    color: #e8452c;
    background-color: #faedeb
}

.section.account .form {
    max-width: 400px;
    margin: 0 auto
}

.page-404 .container__content {
    text-align: center;
    padding: 10rem 0
}

.page-404 .container__content p {
    margin-bottom: 2rem
}

.projects-filter {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 64px;
    margin-top: -64px
}

@media only screen and (min-width: 768px) {
    .projects-filter {
        flex-direction:row;
        align-items: center
    }
}

.projects-filter .field-group {
    margin: 0;
    width: auto
}

.projects-filter .field-group+.field-group {
    margin: 0
}

@media only screen and (min-width: 768px) {
    .projects-filter .field-group:last-child {
        flex:1 0 auto
    }
}

.projects-filter .field-group select {
    width: auto
}

#projects-grid {
    position: relative;
    border: 1px solid transparent
}

#projects-grid .sprig-loader {
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition),visibility var(--transition);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 100;
    background-color: #fffc;
    text-align: center
}

#projects-grid .sprig-loader span {
    display: block;
    width: 3.6rem;
    height: 3.6rem;
    margin: 2rem auto;
    position: sticky;
    top: 5rem
}

#projects-grid .sprig-loader span div {
    box-sizing: border-box;
    display: block;
    position: absolute;
    width: 3.6rem;
    height: 3.6rem;
    margin: 0 auto;
    border: .5rem solid var(--c-brand);
    border-radius: 50%;
    animation: lds-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;
    border-color: var(--c-brand) transparent transparent transparent
}

#projects-grid .sprig-loader span div:nth-child(1) {
    animation-delay: -.45s
}

#projects-grid .sprig-loader span div:nth-child(2) {
    animation-delay: -.3s
}

#projects-grid .sprig-loader span div:nth-child(3) {
    animation-delay: -.15s
}

@keyframes lds-ring {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

#projects-grid .sprig-loader.htmx-request {
    opacity: 1;
    visibility: visible
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-next,.swiper-button-prev {
    position: absolute;
    top: var(--swiper-navigation-top-offset,50%);
    width: calc(var(--swiper-navigation-size)/ 44 * 27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size)/ 2));
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color,var(--swiper-theme-color))
}

.swiper-button-next.swiper-button-disabled,.swiper-button-prev.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-next.swiper-button-hidden,.swiper-button-prev.swiper-button-hidden {
    opacity: 0;
    cursor: auto;
    pointer-events: none
}

.swiper-navigation-disabled .swiper-button-next,.swiper-navigation-disabled .swiper-button-prev {
    display: none!important
}

.swiper-button-next:after,.swiper-button-prev:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none!important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev,.swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset,10px);
    right: auto
}

.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after {
    content: "prev"
}

.swiper-button-next,.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset,10px);
    left: auto
}

.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after {
    content: "next"
}

.swiper-button-lock {
    display: none
}

.swiper-pagination {
    position: absolute;
    text-align: center;
    transition: .3s opacity;
    transform: translateZ(0);
    z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled {
    display: none!important
}

.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal,.swiper-pagination-custom,.swiper-pagination-fraction {
    bottom: var(--swiper-pagination-bottom,8px);
    top: var(--swiper-pagination-top,auto);
    left: 0;
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    overflow: hidden;
    font-size: 0
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transform: scale(.33);
    position: relative
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(.33)
}

.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width,var(--swiper-pagination-bullet-size,8px));
    height: var(--swiper-pagination-bullet-height,var(--swiper-pagination-bullet-size,8px));
    display: inline-block;
    border-radius: var(--swiper-pagination-bullet-border-radius,50%);
    background: var(--swiper-pagination-bullet-inactive-color,#000);
    opacity: var(--swiper-pagination-bullet-inactive-opacity, .2)
}

button.swiper-pagination-bullet {
    border: none;
    margin: 0;
    padding: 0;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none!important
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color,var(--swiper-theme-color))
}

.swiper-pagination-vertical.swiper-pagination-bullets,.swiper-vertical>.swiper-pagination-bullets {
    right: var(--swiper-pagination-right,8px);
    left: var(--swiper-pagination-left,auto);
    top: 50%;
    transform: translate3d(0,-50%,0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: var(--swiper-pagination-bullet-vertical-gap,6px) 0;
    display: block
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: .2s transform,.2s top
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap,4px)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translate(-50%);
    white-space: nowrap
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform,.2s left
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,:host(.swiper-horizontal.swiper-rtl) .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform,.2s right
}

.swiper-pagination-fraction {
    color: var(--swiper-pagination-fraction-color,inherit)
}

.swiper-pagination-progressbar {
    background: var(--swiper-pagination-progressbar-bg-color,rgba(0,0,0,.25));
    position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color,var(--swiper-theme-color));
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 100%;
    height: var(--swiper-pagination-progressbar-size,4px);
    left: 0;
    top: 0
}

.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-vertical>.swiper-pagination-progressbar {
    width: var(--swiper-pagination-progressbar-size,4px);
    height: 100%;
    left: 0;
    top: 0
}

.swiper-pagination-lock {
    display: none
}

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-fade .swiper-slide-active,.swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}
