@charset "UTF-8";
/**
 * Modern CSS Reset Tweaks
 * ==================================================
 * A collection of modern CSS reset and normalization styles
 * to ensure consistent behavior across browsers, OS and devices.
 */
/* Ensure consistent font resizing on mobile devices */
html {
  -webkit-text-size-adjust: 100%;
}
html:focus-within {
  scroll-behavior: smooth;
}

/* Basic body setup for layout and text rendering optimization */
body {
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  position: relative;
  width: 100%;
  min-height: 100vh;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeSpeed;
}

/* Apply box-sizing globally for consistent element sizing */
*,
::after,
::before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Style unclassed links for better accessibility */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

/**
 * CSS Reset Tweaks
 * Based on Eric Meyer's CSS Reset v2.0-modified (public domain)
 * URL: http://meyerweb.com/eric/tools/css/reset/
 */
a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
br,
button,
canvas,
caption,
center,
cite,
code,
col,
colgroup,
data,
datalist,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
head,
header,
hgroup,
hr,
html,
i,
iframe,
img,
input,
ins,
kbd,
label,
legend,
li,
link,
main,
map,
mark,
menu,
meta,
meter,
nav,
noscript,
object,
ol,
optgroup,
option,
output,
p,
param,
picture,
pre,
progress,
q,
rb,
rp,
rt,
rtc,
ruby,
s,
samp,
script,
section,
select,
small,
source,
span,
strong,
style,
svg,
sub,
summary,
sup,
table,
tbody,
td,
template,
textarea,
tfoot,
th,
thead,
time,
title,
tr,
track,
tt,
u,
ul,
var,
video,
wbr {
  font-size: 100%;
  font: inherit;
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

/* Add focus styles to improve accessibility */
:focus {
  outline: 0;
}

/* Normalize HTML5 elements for older browsers */
article,
aside,
details,
embed,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
object,
section {
  display: block;
}

canvas,
iframe {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Remove default list styling */
ol,
ul {
  list-style: none;
}

/* Normalize quote styling */
blockquote,
q {
  quotes: none;
}
blockquote:before, blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

/* Reset and normalize form inputs */
input:required,
input {
  -webkit-box-shadow: none;
          box-shadow: none;
}

/* Autofill styling for better compatibility */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset;
}

/* Improve appearance of search inputs */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
  -webkit-appearance: none;
  -moz-appearance: none;
}

input[type=search] {
  -webkit-appearance: none;
  -moz-appearance: none;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

textarea {
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

input:focus {
  outline: none;
}

video {
  background: #000;
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.
 */
[hidden] {
  display: none;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: none;
}

/**
 * Make media easier to work with
 */
audio,
img,
picture,
svg,
video {
  max-width: 100%;
  display: inline-block;
  vertical-align: middle;
  height: auto;
}

/**
 * Address Firefox 3+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none;
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button;
  cursor: pointer;
  border: 0;
  background: transparent;
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/* Additional attribute handling for accessibility */
[disabled],
[disabled=true],
[aria-disabled=true] {
  pointer-events: none;
}

/**
 * Address box sizing set to content-box in IE 8/9.
 */
input[type=checkbox],
input[type=radio] {
  padding: 0;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type=search] {
  -webkit-appearance: textfield;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Remove inner padding and border in Firefox 3+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

button {
  border: 0;
  background: transparent;
}

textarea {
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
  text-indent: 0;
}

/**
 * Based on normalize.css v8.0.1
 * github.com/necolas/normalize.css
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  overflow: visible;
  background: #000;
  border: 0;
  height: 1px;
  line-height: 0;
  margin: 0;
  padding: 0;
  page-break-after: always;
  width: 100%;
}

/**
 * Correct the inheritance and scaling of font size in all browsers.
 */
pre {
  font-family: monospace, monospace;
  font-size: 100%;
}

/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  text-decoration: none;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 75%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -5px;
}

sup {
  top: -5px;
}

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1;
  margin: 0;
  padding: 0;
}

/**
 * Show the overflow in IE and Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
  outline: 0;
}

legend {
  color: inherit;
  white-space: normal;
  display: block;
  border: 0;
  max-width: 100%;
  width: 100%;
}

fieldset {
  min-width: 0;
}

body:not(:-moz-handler-blocked) fieldset {
  display: block;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
template {
  display: none;
}

/**
 * Swiper 11.2.10
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2025 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: June 28, 2025
 */
@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") format("woff");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  */
}

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block;
}

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

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

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translate3d(0px, 0, 0);
          transform: translate3d(0px, 0, 0);
}

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

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

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

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

/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}

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

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

/* 3D Effects */
.swiper-3d.swiper-css-mode .swiper-wrapper {
  -webkit-perspective: 1200px;
          perspective: 1200px;
}

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

.swiper-3d {
  -webkit-perspective: 1200px;
          perspective: 1200px;
}
.swiper-3d .swiper-slide,
.swiper-3d .swiper-cube-shadow {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}

/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none; /* For Firefox */
  -ms-overflow-style: none; /* For Internet Explorer and Edge */
}
.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}
.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}
.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  -ms-scroll-snap-type: x mandatory;
      scroll-snap-type: x mandatory;
}
.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  -ms-scroll-snap-type: y mandatory;
      scroll-snap-type: y mandatory;
}
.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  -ms-scroll-snap-type: none;
      scroll-snap-type: none;
}
.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none;
}
.swiper-css-mode.swiper-centered > .swiper-wrapper::before {
  content: "";
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-order: 9999;
      order: 9999;
}
.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}
.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-start: var(--swiper-centered-offset-before);
          margin-inline-start: var(--swiper-centered-offset-before);
}
.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}
.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-before: var(--swiper-centered-offset-before);
          margin-block-start: var(--swiper-centered-offset-before);
}
.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

/* Slide styles start */
/* 3D Shadows */
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  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, 0.15);
}
.swiper-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

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

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

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

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

@-webkit-keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
/* Slide styles end */
.swiper-fade.swiper-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
          transition-timing-function: ease-out;
}
.swiper-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  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;
}

@namespace svg "http://www.w3.org/2000/svg";
/**
 * Total Reset
 * ==================================================
 * Universal reset of styles for all elements and pseudo-elements for customizing Web Components and browser extensions.
 */
/* Selector targets all elements except tables and svg elements */
*:where(:not(table, thead, tbody, tr, th, td, svg|*)) {
  /* Resets all styles for the selected elements */
  all: unset;
  /* Set box-sizing to border-box so padding and borders do not affect the total width and height of elements */
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* Resets styles for ::before and ::after pseudo-elements */
}
*:where(:not(table, thead, tbody, tr, th, td, svg|*))::before, *:where(:not(table, thead, tbody, tr, th, td, svg|*))::after {
  /* Unsets all styles for pseudo-elements */
  all: unset;
  /* Set box-sizing to border-box for pseudo-elements */
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

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

article,
aside,
blockquote,
details,
div,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
main,
menu,
nav,
p,
pre,
section {
  display: block;
}

audio,
canvas,
video,
img,
picture,
svg {
  display: inline-block;
  max-width: 100%;
  vertical-align: middle;
}

canvas,
iframe {
  display: block;
}

[hidden] {
  display: none;
}

head,
link,
meta,
script,
title,
template,
style {
  display: none;
}

a[href],
label[for],
select,
button {
  cursor: pointer;
}

/**
 * Table
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
  text-indent: 0;
}

table,
thead,
tbody,
tr,
th,
td {
  font-size: 100%;
  font: inherit;
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

/**
 * Forms
 */
input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-block;
}

input[type=color] {
  width: 15px;
  height: 15px;
}

input[type=color]::-webkit-color-swatch-wrapper {
  padding: 0;
}

input[type=color]::-webkit-color-swatch {
  border: none;
}

input:required,
input {
  -webkit-box-shadow: none;
          box-shadow: none;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
  -webkit-appearance: none;
  -moz-appearance: none;
}

input[type=search] {
  -webkit-appearance: none;
  -moz-appearance: none;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

textarea {
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

input:focus {
  outline: none;
}

/**
 * Only apply smooth scrolling when the user hasn't set their motion preference to "reduce"
 */
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}
:root {
  font-size: 2.5641025641vw;
}
@media (min-width: 768px) {
  :root {
    font-size: 1.3020833333vw;
  }
}
@media (min-width: 1200px) {
  :root {
    --toIndex: 28.65;
    font-size: calc((var(--vw, 1vw) + var(--vh, 1vh)) * 10 / var(--toIndex, 30));
  }
}

body {
  font-smooth: always;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  min-height: auto;
  background: #fff9eb;
}

html::-webkit-scrollbar {
  display: none;
  scrollbar-width: none;
}
@media (min-width: 1200px) {
  html {
    scroll-behavior: auto;
  }
}

img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

a {
  text-decoration: none;
  color: inherit;
}

svg.hidden {
  display: none;
}

@font-face {
  font-family: "NeverMind Compact";
  src: url("../fonts/NeverMindCompact-ExtraLight.woff2") format("woff2"), url("../fonts/NeverMindCompact-ExtraLight.woff") format("woff");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeverMind Compact";
  src: url("../fonts/NeverMindCompact-Light.woff2") format("woff2"), url("../fonts/NeverMindCompact-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeverMind Compact";
  src: url("../fonts/NeverMindCompact-Regular.woff2") format("woff2"), url("../fonts/NeverMindCompact-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeverMind Compact";
  src: url("../fonts/NeverMindCompact-Medium.woff2") format("woff2"), url("../fonts/NeverMindCompact-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "NeverMind Compact";
  src: url("../fonts/NeverMindCompact-DemiBold.woff2") format("woff2"), url("../fonts/NeverMindCompact-DemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
body, .body {
  font-family: "NeverMind Compact", sans-serif;
  color: #1a1a1a;
}

.h1 {
  font-size: 4rem;
  font-weight: 600;
  font-family: "NeverMind Compact", sans-serif;
}

.h2 {
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 104%;
  letter-spacing: 0.04em;
  color: #1a1a1a;
}

.h3 {
  color: #fff9eb;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 500;
  font-size: 2.4rem;
}

.h4 {
  font-size: 2rem;
  font-weight: 300;
  color: #1a1a1a;
  font-family: "NeverMind Compact", sans-serif;
}

.title_big {
  font-weight: 600;
  font-size: 4.8rem;
  line-height: 110%;
  font-family: "NeverMind Compact", sans-serif;
  color: #fff9eb;
}

.highlighter {
  color: #e52a2c;
}

.text {
  font-size: 1.6rem;
  font-weight: 400;
  font-family: "NeverMind Compact", sans-serif;
  color: #fff9eb;
  line-height: 30px;
}

@media (min-width: 768px) {
  .title_big {
    font-size: 8.8rem;
  }
  .h3 {
    font-size: 4.4rem;
  }
  .text {
    font-size: 2rem;
  }
}
@media (min-width: 1200px) {
  .h1 {
    font-size: 9.6rem;
  }
  .h2 {
    font-size: 4.8rem;
  }
  .h3 {
    font-size: 3.6rem;
    font-weight: 600;
  }
  .title_big {
    font-size: 12.8rem;
  }
  .text {
    font-size: 2.4rem;
  }
}
.cta-button {
  max-width: 16.7rem;
  width: 100%;
  height: 6.2rem;
  padding: 0.6rem 0.9rem;
  display: none;
  -webkit-column-gap: 0.9rem;
     -moz-column-gap: 0.9rem;
          column-gap: 0.9rem;
  background-color: #e52a2c;
  border-radius: 5px;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  border: none;
}
.cta-button .icon {
  width: 100%;
}
.cta-button__text {
  color: #fff9eb;
}
.cta-button__text_small {
  font-size: 1.6rem;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 400;
}
.cta-button__text_big {
  font-size: 2.4rem;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 400;
}
@media (hover: hover) {
  .cta-button {
    overflow: hidden;
    position: relative;
  }
  .cta-button:after {
    background: #fff;
    content: "";
    height: 155px;
    left: -75px;
    opacity: 0.2;
    position: absolute;
    top: -50px;
    -webkit-transform: rotate(35deg);
        -ms-transform: rotate(35deg);
            transform: rotate(35deg);
    -webkit-transition: all 550ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: all 550ms cubic-bezier(0.19, 1, 0.22, 1);
    width: 50px;
  }
  .cta-button:hover::after {
    left: 120%;
    -webkit-transition: all 550ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: all 550ms cubic-bezier(0.19, 1, 0.22, 1);
  }
}

@media (min-width: 1200px) {
  .cta-button {
    display: -ms-flexbox;
    display: flex;
  }
}
.button__link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1rem 3rem;
  border-radius: 2rem;
  background-color: #fff9eb;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  height: 5.9rem;
}
@media (hover: hover) {
  .button__link {
    background-image: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #1a1a1a), color-stop(50%, #fff9eb));
    background-image: linear-gradient(to bottom, #1a1a1a 50%, #fff9eb 50%);
    background-size: 100% 201%; /* Фон вдвічі ширший за кнопку */
    background-position: left bottom;
    -webkit-transition: background-position 0.3s ease, color 0.3s ease;
    transition: background-position 0.3s ease, color 0.3s ease;
  }
  .button__link:hover {
    /* Текст стає білим */
    color: white;
    /* Фон зміщується вліво, показуючи чорну частину */
    background-position: left top;
  }
  .button__link:hover .button__text {
    color: #fff9eb;
  }
  .button__link:hover .button__icon path {
    fill: #fff9eb;
  }
}
.button__text {
  color: #1a1a1a;
  font-size: 1.6rem;
  font-weight: 300;
  font-family: "NeverMind Compact", sans-serif;
  text-transform: uppercase;
}
.button__icon {
  width: 3rem;
}
.button__icon .icon {
  width: 100%;
  fill: currentColor;
}
.button__icon--bottom {
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}

@media (min-width: 768px) {
  .button__text {
    font-size: 2.4rem;
  }
}
@media (min-width: 1200px) {
  .button__link {
    height: 8rem;
  }
  .button__text {
    font-size: 3.2rem;
  }
  .button__icon {
    width: 3.9rem;
  }
}
.breadcrumbs {
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-pack: start;
      justify-content: flex-start;
  gap: 1rem;
  text-transform: uppercase;
}
.breadcrumbs a {
  color: #1a1a1a;
  text-decoration: underline;
  text-underline-offset: 0.15em;
  text-decoration-thickness: 0.05em;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.breadcrumbs a:hover {
  text-decoration-color: transparent;
}
@media (min-width: 768px) {
  .breadcrumbs {
    font-size: 1.4rem;
  }
}

.socials-list {
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
.socials-list__item {
  -ms-flex-positive: 0;
      flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 4rem;
  aspect-ratio: 1/1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  color: #1a1a1a;
}
.socials-list__item .icon {
  width: 100%;
  height: 100%;
}
@media (hover: hover) {
  .socials-list__item {
    -webkit-transition: -webkit-transform 0.3s ease-in-out;
    transition: -webkit-transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  }
  .socials-list__item:hover, .socials-list__item:focus {
    -webkit-transform: scale(1.5);
        -ms-transform: scale(1.5);
            transform: scale(1.5);
  }
}
@media (min-width: 768px) {
  .socials-list {
    gap: 1rem;
  }
  .socials-list__item {
    width: 5rem;
  }
}

.card-project-category {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
      align-items: end;
  -ms-flex-pack: center;
      justify-content: center;
  position: relative;
  overflow: hidden;
  aspect-ratio: 390/600;
}
@media (hover: hover) {
  .card-project-category:hover .card-project-category__picture {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
  }
}
.card-project-category::before {
  content: "";
  background-color: rgba(0, 0, 0, 0.2);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.card-project-category__picture {
  position: absolute;
  top: 0;
}
.card-project-category__content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  text-align: center;
  margin-bottom: 4.3rem;
  width: calc(100% - 4rem);
  word-break: break-all;
  z-index: 1;
}
.card-project-category__title {
  font-size: 3.6rem;
  color: #fff9eb;
  font-weight: 500;
  font-family: "NeverMind Compact", sans-serif;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.card-project-category__subtitle {
  color: #ffffff;
  font-size: 2rem;
  text-transform: uppercase;
  margin-bottom: 2.7rem;
}
.card-project-category__link {
  padding: 1.3rem 1.1rem;
  border: solid 1px #fff9eb;
  text-transform: uppercase;
  color: #fff9eb;
  font-family: "NeverMind Compact", sans-serif;
  font-size: 2rem;
  border-radius: 5px;
  text-align: center;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
}
@media (hover: hover) {
  .card-project-category__link:before {
    content: "";
    position: absolute;
    top: -100%;
    left: 0;
    display: block;
    width: 100%;
    background-color: #fff9eb;
    height: 100%;
    z-index: -1;
    -webkit-transition: top 0.2s ease;
    transition: top 0.2s ease;
  }
  .card-project-category__link:hover:before {
    top: 0;
  }
  .card-project-category__link:hover {
    color: #1a1a1a;
  }
}
@media (min-width: 768px) {
  .card-project-category {
    aspect-ratio: auto;
    height: 50svh;
  }
  .card-project-category__picture {
    -webkit-transition: -webkit-transform 1s;
    transition: -webkit-transform 1s;
    transition: transform 1s;
    transition: transform 1s, -webkit-transform 1s;
  }
  .card-project-category__title {
    font-size: 4rem;
  }
}

.card-project__thumb {
  margin-bottom: 1rem;
  aspect-ratio: 16/9;
  overflow: hidden;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
}
.card-project__thumb img {
  -webkit-transition: -webkit-transform 0.6s ease-in-out;
  transition: -webkit-transform 0.6s ease-in-out;
  transition: transform 0.6s ease-in-out;
  transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out;
}
.card-project__title {
  margin-left: 1rem;
  font-weight: 400;
  font-size: 2.4rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-pack: start;
      justify-content: flex-start;
  gap: 1rem;
}
.card-project__title .icon {
  width: 0.95em;
  height: auto;
  -webkit-transition: -webkit-transform 0.6s ease-in-out;
  transition: -webkit-transform 0.6s ease-in-out;
  transition: transform 0.6s ease-in-out;
  transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out;
}
@media (hover: hover) {
  .card-project__link:hover .card-project__title .icon {
    -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .card-project__link:hover .card-project__thumb img {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
  }
}

.list {
  padding-left: 2rem;
}
.list__item {
  font-size: 1.6rem;
  font-weight: 200;
  font-family: "NeverMind Compact", sans-serif;
  color: #fff9eb;
  list-style-type: disc;
  line-height: 3rem;
}

@media (min-width: 768px) {
  .list__item {
    font-size: 2rem;
  }
}
@media (min-width: 1200px) {
  .list__item {
    font-size: 2.4rem;
    line-height: 40px;
  }
  .list__item::marker {
    font-size: 1rem;
  }
}
.stats-block {
  display: none;
}

@media (min-width: 1200px) {
  .stats-block {
    display: -ms-flexbox;
    display: flex;
    grid-column: 1/3;
    -ms-flex-pack: justify;
        justify-content: space-between;
    max-width: 146rem;
    justify-self: center;
    width: 100%;
  }
  .stats-block__card {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    display: grid;
    row-gap: 1rem;
    -ms-flex-align: center;
        align-items: center;
    justify-items: center;
  }
  .stats-block__value {
    color: #fff9eb;
    font-size: 6.4rem;
    font-family: "NeverMind Compact", sans-serif;
    font-weight: 500;
    text-align: center;
  }
  .stats-block__title {
    font-size: 3.2rem;
    color: #fff9eb;
    line-height: 4rem;
    font-family: "NeverMind Compact", sans-serif;
    font-weight: 300;
    text-align: center;
  }
}
.form__title {
  margin-bottom: 4rem;
  text-align: center;
}
.form__body {
  width: 100%;
  display: grid;
  row-gap: 2rem;
  position: relative;
}
.form__body.is-loading {
  opacity: 0.5;
  pointer-events: none;
}
.form__loader {
  display: none; /* Приховуємо за замовчуванням */
  width: 20px;
  height: 20px;
  border: 3px solid rgba(255, 255, 255, 0.3);
  border-top-color: red; /* Акцентний колір на верхівці кола */
  border-radius: 50%;
  -webkit-animation: spin 0.8s linear infinite;
          animation: spin 0.8s linear infinite;
  position: absolute;
  top: 50%;
  left: 50%;
  /* Додайте це, коли процес завантаження активний */
}
@-webkit-keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.form__body.is-loading .form__loader {
  display: inline-block;
}
.form__field-wrap {
  position: relative;
}
.form-field,
.form .just-validate-error-label,
.form .form-message--error {
  font-family: "NeverMind Compact", sans-serif;
  font-size: 1.2em;
  position: absolute;
  bottom: -1.5rem;
  color: black !important;
}
.form__input {
  width: 100%;
  background-color: transparent;
  color: #1a1a1a;
  font-family: "NeverMind Compact", sans-serif;
  border-bottom: solid 2px #1a1a1a;
  padding-bottom: 1rem;
  font-size: 2rem;
  font-weight: 200;
}
.form__input::-webkit-input-placeholder {
  color: #1a1a1a;
}
.form__input::-moz-placeholder {
  color: #1a1a1a;
}
.form__input:-ms-input-placeholder {
  color: #1a1a1a;
}
.form__input::-ms-input-placeholder {
  color: #1a1a1a;
}
.form__input::placeholder {
  color: #1a1a1a;
}
.form__button {
  overflow: hidden;
}
@media (min-width: 768px) {
  .form__body {
    margin-inline: auto;
    row-gap: 1.8rem;
    max-width: 58.5rem;
  }
  .form__input {
    border-bottom: solid 2px #ffffff;
    color: #ffffff;
  }
  .form__input::-webkit-input-placeholder {
    color: #ffffff;
  }
  .form__input::-moz-placeholder {
    color: #ffffff;
  }
  .form__input:-ms-input-placeholder {
    color: #ffffff;
  }
  .form__input::-ms-input-placeholder {
    color: #ffffff;
  }
  .form__input::placeholder {
    color: #ffffff;
  }
}
@media (min-width: 1200px) {
  .form__title {
    text-align: start;
    margin-bottom: 3rem;
    margin-top: 0;
  }
  .form__body {
    margin-inline: 0;
  }
  .form__input {
    margin-top: 2rem;
    margin-bottom: 1rem;
    border-bottom: solid 2px #ffffff;
    color: #ffffff;
    font-size: 3.2rem;
    font-weight: 200;
  }
  .form__input::-webkit-input-placeholder {
    color: #ffffff;
  }
  .form__input::-moz-placeholder {
    color: #ffffff;
  }
  .form__input:-ms-input-placeholder {
    color: #ffffff;
  }
  .form__input::-ms-input-placeholder {
    color: #ffffff;
  }
  .form__input::placeholder {
    color: #ffffff;
  }
  .form-field,
  .form .just-validate-error-label,
  .form .form-message--error {
    font-size: 1.6rem;
    color: white !important;
  }
}

.project-meta__list {
  margin-bottom: 2.5rem;
  display: grid;
  row-gap: 1.5rem;
}
.project-meta__label {
  margin-bottom: 5px;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 265;
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: 0.01em;
  color: #1a1a1a;
}
.project-meta__value {
  font-size: 2rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
}
.project-meta__button-cta {
  display: -ms-flexbox;
  display: flex;
}
@media (min-width: 768px) {
  .project-meta__list {
    margin-bottom: 3rem;
    row-gap: 2rem;
  }
  .project-meta__label {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  .project-meta__value {
    font-size: 2.4rem;
  }
}
@media (min-width: 1200px) {
  .project-meta__list {
    margin-bottom: 3.5rem;
    gap: 2.5rem;
  }
  .project-meta__label {
    font-size: 2rem;
  }
  .project-meta__value {
    font-size: 3.2rem;
  }
}

.card-team__list {
  display: grid;
  overflow-x: scroll;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  scrollbar-width: none;
}
.card-team__item {
  width: 35rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  row-gap: 1rem;
  padding: 0 1rem;
}
.card-team__image {
  aspect-ratio: 350/400;
  margin-left: -1rem;
  margin-right: -1rem;
}
@media (min-width: 1200px) {
  .card-team__list {
    overflow-x: unset;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
  }
  .card-team__list:has(.card-team__item:hover) .card-team__item {
    -webkit-filter: brightness(0.4);
            filter: brightness(0.4);
  }
  .card-team__item {
    width: 25%;
    -webkit-transition: all ease-in-out 0.3s;
    transition: all ease-in-out 0.3s;
  }
}
@media (min-width: 1200px) and (hover: hover) {
  .card-team__item:hover {
    width: 28%;
    -webkit-filter: unset !important;
            filter: unset !important;
  }
}
@media (min-width: 1200px) {
  .card-team__image {
    aspect-ratio: auto;
    height: 45rem;
  }
}

.container {
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

:root {
  --container-padding: 1.5rem;
  --container-padding-n: -1.5rem;
}
@media (min-width: 768px) {
  :root {
    --container-padding: 2.5rem;
    --container-padding-n: -2.5rem;
  }
}
@media (min-width: 1200px) {
  :root {
    --container-padding: 4rem;
    --container-padding-n: -4rem;
  }
}

.section {
  --p-btm: 12rem;
}
.section--fh {
  padding-bottom: var(--p-btm);
  min-height: calc(100lvh - var(--header-height));
}
.section-pc {
  overflow: hidden;
}

@media (min-width: 1200px) {
  .section-pc {
    height: 100vh;
    display: grid;
    -ms-flex-line-pack: center;
        align-content: center;
  }
}
:root {
  --header-height: 8rem;
  --header-vertical-spacing: calc(var(--header-height) + 2.4rem);
}
@media (min-width: 768px) {
  :root {
    --header-height: 12rem;
    --header-vertical-spacing: calc(var(--header-height) + 3.2rem);
    --header-vertical-spacing-bottom: calc(var(--header-height) / 2);
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
}
.header__container {
  height: var(--header-height);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
}
.header .custom-logo-link {
  width: 5.5rem;
  height: auto;
  aspect-ratio: 1/1;
}
.header__burger {
  width: 8.5rem;
  aspect-ratio: 85/65;
  display: -ms-flexbox;
  display: flex;
}
.header__burger .icon {
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .header .custom-logo-link {
    width: 8.5rem;
  }
  .header__burger {
    width: 9rem;
  }
}

.footer {
  padding: 4rem 0 1.5rem;
}
.footer__container {
  margin: 0 auto;
  display: grid;
  grid-template-columns: -webkit-max-content -webkit-max-content 1fr;
  grid-template-columns: max-content max-content 1fr;
  -webkit-column-gap: 3.5rem;
     -moz-column-gap: 3.5rem;
          column-gap: 3.5rem;
}
.footer .custom-logo-link {
  margin-left: var(--container-padding);
  grid-column: 1;
  width: 5.5rem;
  height: auto;
  aspect-ratio: 1/1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
}
.footer__nav {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  gap: 1rem;
}
.footer__address-title {
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  text-transform: uppercase;
}
.footer__socials {
  margin-top: 2rem;
  padding: 1rem var(--container-padding);
  border-top: 1px solid #1a1a1a;
  grid-column: 1/-1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  gap: 1rem;
}
.footer__socials-title {
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  text-transform: uppercase;
}
.footer__nav-link {
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  text-transform: uppercase;
}
@media (hover: hover) {
  .footer__nav-link {
    position: relative;
    overflow: hidden;
    -webkit-transition: -webkit-transform 0.5s;
    transition: -webkit-transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
  }
  .footer__nav-link::after {
    content: attr(data-after);
    display: inline-block;
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
    position: absolute;
    left: 0;
    -webkit-transition: inherit;
    transition: inherit;
  }
  .footer__nav-link > span {
    display: inline-block;
    -webkit-transform: translateY(0%);
        -ms-transform: translateY(0%);
            transform: translateY(0%);
    -webkit-transition: inherit;
    transition: inherit;
  }
  .footer__nav-link:hover > span {
    -webkit-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  .footer__nav-link:hover::after {
    -webkit-transform: translateY(0%);
        -ms-transform: translateY(0%);
            transform: translateY(0%);
  }
}
.footer__contacts {
  padding-right: var(--container-padding);
  justify-self: end;
}
.footer__address, .footer__phone {
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: 0.01em;
  color: #1a1a1a;
}
.footer__phone {
  font-weight: 500;
}
.footer__email {
  margin-bottom: 1.5rem;
  padding: 1rem var(--container-padding);
  grid-column: 1/-1;
  border-top: 1px solid #1a1a1a;
  border-bottom: 1px solid #1a1a1a;
  font-weight: 600;
  font-size: 2rem;
  letter-spacing: 0.05em;
  text-align: center;
  color: #1a1a1a;
}
.footer__copyright {
  grid-column: 1/-1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 0 var(--container-padding) 0;
  -ms-flex-pack: justify;
      justify-content: space-between;
  font-weight: 500;
  gap: 2rem;
  font-size: 1.4rem;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .footer__container {
    -webkit-column-gap: 7rem;
       -moz-column-gap: 7rem;
            column-gap: 7rem;
  }
  .footer .custom-logo-link {
    width: 9.5rem;
  }
  .footer__socials {
    gap: 2rem;
  }
  .footer__nav-link {
    font-size: 2.4rem;
  }
  .footer__socials {
    grid-column: 2/-1;
    justify-self: start;
    padding-left: 0;
    width: 100%;
    -ms-flex-pack: start;
        justify-content: start;
    position: relative;
    border-top: none;
  }
  .footer__socials::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100vw;
    height: 1px;
    background-color: #1a1a1a;
  }
  .footer__address-title, .footer__address, .footer__phone, .footer__socials-title {
    font-size: 2.4rem;
  }
  .footer__copyright {
    font-size: 1.6rem;
  }
  .footer__email {
    font-size: 4rem;
  }
}
@media (min-width: 1200px) {
  .footer {
    padding: 6rem 0 2rem;
  }
  .footer__container {
    grid-template-columns: -webkit-max-content 820fr 490fr 360fr;
    grid-template-columns: max-content 820fr 490fr 360fr;
  }
  .footer__container::before {
    margin: 2.5rem 0;
    content: "";
    grid-column: 1/-1;
    grid-row: 2;
    width: 100%;
    height: 1px;
    background-color: currentColor;
  }
  .footer__nav {
    grid-column: 3;
    grid-row: 1;
  }
  .footer__socials {
    grid-column: 4;
    grid-row: 1;
  }
  .footer__socials::before {
    display: none;
  }
  .footer__contacts {
    margin-bottom: 2.5rem;
    grid-column: 3;
    grid-row: 3;
    padding: 0;
    justify-self: start;
  }
  .footer__address br {
    display: none;
  }
  .footer__email {
    font-size: 9.6rem;
  }
}

.menu {
  padding: var(--header-height) 0 var(--container-padding);
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  background: #fffef9;
  z-index: 1000;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: 0;
  -webkit-transition: visibility ease-in-out 2s;
  transition: visibility ease-in-out 2s;
  visibility: hidden;
  pointer-events: none;
}
.menu.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  left: 0;
}
.menu__container {
  height: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: justify;
      justify-content: space-between;
}
.menu__header {
  position: fixed;
  top: 0;
  right: 0;
  padding: var(--container-padding);
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: end;
      justify-content: flex-end;
  height: var(--header-height);
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
.menu__close {
  width: 8.5rem;
  aspect-ratio: 95/60;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  color: #1a1a1a;
}
.menu__close .icon {
  width: 100%;
  height: 100%;
}
.menu__nav {
  padding: 2.5rem 0;
  -ms-flex-positive: 1;
      flex-grow: 1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  gap: 3rem;
  -ms-flex-item-align: center;
      align-self: center;
}
.menu__link {
  color: #1a1a1a;
}
.menu__link-label {
  margin-bottom: 0.5rem;
  display: block;
  font-size: 3.2rem;
  line-height: 1.25;
  letter-spacing: 0.01em;
  color: currentColor;
  text-transform: uppercase;
}
.menu__link-label--is-file {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  gap: 1.5rem;
}
.menu__link-description {
  min-height: 1lh;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: currentColor;
}
.menu__link-icon {
  width: 0.75em;
  aspect-ratio: 1/1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
}
.menu__link-icon .icon {
  width: 100%;
  height: 100%;
}
.menu__socials {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  gap: 5px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
@media (min-width: 768px) {
  .menu__link-label {
    margin-bottom: 1rem;
    font-size: 2.4rem;
  }
  .menu__link-description {
    font-size: 1.4rem;
  }
}
@media (min-width: 1200px) {
  .menu {
    padding: 0;
  }
  .menu__container {
    padding: 0 15rem;
  }
  .menu__close {
    width: 10.5rem;
  }
  .menu__nav {
    position: relative;
    width: 100%;
    padding: 0;
    -ms-flex-direction: row;
        flex-direction: row;
    gap: 0;
    z-index: 1;
  }
  .menu__item {
    width: 100%;
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    position: relative;
  }
  .menu__item::before {
    content: "";
    height: 0;
    width: 100%;
    background-color: #e52a2c;
    top: 0;
    left: 0;
    -webkit-transition: height ease-in-out 0.3s;
    transition: height ease-in-out 0.3s;
    display: block;
    position: absolute;
  }
  .menu__item:hover::before {
    height: 100%;
  }
  .menu__item:hover .menu__link {
    color: #fffef9;
  }
  .menu__link {
    padding: 0;
    width: 100%;
    max-width: 100%;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    height: 100%;
    display: grid;
    -ms-flex-align: center;
        align-items: center;
    -ms-flex-pack: center;
        justify-content: center;
    -webkit-transition: color 0.3s ease-in-out;
    transition: color 0.3s ease-in-out;
  }
  .menu__link:hover {
    color: #fffef9;
  }
  .menu__link-wrapper {
    z-index: 2;
  }
  .menu__link-label {
    font-size: 3.2rem;
    -webkit-transition: -webkit-transform 0.3s ease-in-out;
    transition: -webkit-transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
    overflow: hidden;
  }
  .menu__link-label--is-file {
    gap: 2rem;
  }
  .menu__link-description {
    min-height: 2lh;
    font-size: 1.6rem;
    -webkit-transition: -webkit-transform 0.3s ease-in-out;
    transition: -webkit-transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  }
  .menu__socials {
    position: absolute;
    bottom: var(--container-padding);
    left: var(--container-padding);
  }
}

.section {
  scroll-margin-top: var(--header-height);
}
@media (min-width: 768px) {
  .section {
    margin-bottom: 14rem;
  }
}
.section-hero {
  position: relative;
  height: calc(100svh - var(--header-height));
}
.section-hero__swiper {
  height: 100%;
  width: 100%;
}
.section-hero__slide {
  z-index: 1;
  height: 100%;
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: end;
      justify-content: flex-end;
  padding: var(--container-padding) 0 calc(var(--container-padding) + 8rem);
  position: relative;
}
.section-hero__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -1;
}
.section-hero__title {
  margin-bottom: 2rem;
  font-weight: 600;
  font-size: 4rem;
  letter-spacing: 0.01em;
  color: #fffef9;
  text-wrap: balance;
}
.section-hero__link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  gap: 1rem;
  font-size: 2.4rem;
  line-height: 1.66667;
  letter-spacing: 0.01em;
  color: #fffef9;
}
@media (hover: hover) {
  .section-hero__link .icon {
    -webkit-transition: -webkit-transform 0.6s ease-in-out;
    transition: -webkit-transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out;
  }
  .section-hero__link:hover .icon {
    -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
}
.section-hero__thumbnails {
  position: absolute;
  bottom: var(--container-padding);
  left: 0;
  width: 100%;
  z-index: 2;
  padding: 0 var(--container-padding);
}
.section-hero__thumbnails .swiper-wrapper {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}
.section-hero__thumbnail {
  aspect-ratio: 10/6;
  width: auto;
  height: 6rem;
  border: 1px solid #fffef9;
  cursor: pointer;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  overflow: hidden;
  position: relative;
}
@media (min-width: 768px) {
  .section-hero__title {
    margin-bottom: 3rem;
    font-size: 5.6rem;
  }
}
@media (min-width: 1200px) {
  .section-hero__slide {
    padding: var(--header-vertical-spacing) 0 var(--header-vertical-spacing-bottom);
  }
  .section-hero__title {
    margin-bottom: 4rem;
    font-size: 9rem;
  }
  .section-hero__link {
    font-size: 3.2rem;
  }
  .section-hero__thumbnails {
    margin: 0;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    left: auto;
    right: calc(var(--nav-bullet-spacing) + var(--container-padding));
    padding: 0;
    bottom: var(--header-vertical-spacing-bottom);
    width: 62rem;
  }
  .section-hero__thumbnail {
    height: auto;
    width: 14rem;
  }
  .section-hero__thumbnail-overlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 3;
  }
}

.section-showroom {
  padding: var(--header-vertical-spacing) 0;
  display: grid;
  position: relative;
  min-height: 100svh;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
}
.section-showroom__picture {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.section-showroom__picture::before {
  content: "";
  background-color: rgba(0, 0, 0, 0.2);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.section-showroom__image {
  -webkit-filter: blur(3px);
          filter: blur(3px);
}
.section-showroom__container {
  z-index: 1;
}
.section-showroom__title {
  margin-bottom: 8rem;
}
.section-showroom__subtitle {
  margin-bottom: 2rem;
}
.section-showroom__list {
  margin-bottom: 8rem;
}
.section-showroom__buttons {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
}
@media (min-width: 1200px) {
  .section-showroom {
    padding: calc(var(--header-vertical-spacing)) 0 var(--header-vertical-spacing-bottom);
  }
  .section-showroom__container {
    -ms-flex-item-align: center;
        align-self: center;
  }
  .section-showroom__title {
    margin-bottom: 4rem;
    max-width: -webkit-min-content;
    max-width: -moz-min-content;
    max-width: min-content;
    font-size: 11.5rem;
  }
  .section-showroom__subtitle {
    margin-bottom: 2.4rem;
  }
  .section-showroom__list {
    margin-bottom: 6.4rem;
  }
  .section-showroom__buttons {
    padding-right: var(--nav-bullet-spacing);
  }
}

.section-projects-categories__container {
  padding-inline: 0;
}
@media (min-width: 1200px) {
  .section-projects-categories {
    height: 100vh;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-pack: center;
        justify-content: center;
    padding: 0;
  }
  .section-projects-categories__container {
    padding-inline: calc(var(--container-padding) + var(--nav-bullet-spacing));
    height: 100%;
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    grid-template-columns: 1fr;
    -ms-flex-align: center;
        align-items: center;
  }
  .section-projects-categories__wrapper {
    grid-row: 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    -webkit-column-gap: 7rem;
       -moz-column-gap: 7rem;
            column-gap: 7rem;
  }
  .section-projects-categories__cta-button {
    margin-bottom: var(--header-vertical-spacing-bottom);
    margin-left: 6.4rem;
    grid-row: 3;
    align-self: flex-end;
  }
}

.section-team {
  padding: var(--header-vertical-spacing) 0 var(--header-height);
}
.section-team__title {
  margin-bottom: 4rem;
  font-size: 3.2rem;
  font-weight: 700;
  font-family: "NeverMind Compact", sans-serif;
}
.section-team__wrapper {
  overflow: hidden;
  margin-left: var(--container-padding-n);
  margin-right: var(--container-padding-n);
}

@media (min-width: 768px) {
  .section-team__title {
    font-size: 6.4rem;
    margin-bottom: 4rem;
  }
}
@media (min-width: 1200px) {
  .section-team {
    padding-bottom: calc(var(--header-height) / 2);
  }
  .section-team__title {
    font-size: 9rem;
    margin-bottom: 4rem;
  }
  .section-team__wrapper {
    padding-inline: var(--nav-bullet-spacing);
    overflow: hidden;
    margin-left: 0;
    margin-right: 0;
  }
  .section-team__cta-button {
    margin-left: calc(var(--nav-bullet-spacing) + 1rem);
    margin-top: 4rem;
  }
}
.section-about {
  position: relative;
}
.section-about__container {
  padding: var(--header-vertical-spacing) var(--container-padding) var(--header-height);
  min-height: 100svh;
  height: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}
.section-about__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  overflow: hidden;
}
.section-about__image img {
  -webkit-filter: blur(3px);
          filter: blur(3px);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.section-about__image::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(23.08%, #e52a2c), to(rgba(229, 42, 44, 0.1)));
  background-image: linear-gradient(to right, #e52a2c 23.08%, rgba(229, 42, 44, 0.1) 100%);
  opacity: 0.7;
  -webkit-filter: blur(3px);
          filter: blur(3px);
  z-index: 1;
}
.section-about__title {
  margin-bottom: 2.4rem;
}
.section-about__subtitle {
  margin-bottom: 8rem;
  font-size: 1.6rem;
  color: #fff9eb;
  font-weight: 400;
  text-wrap: balance;
}
.section-about__text {
  line-height: 1.75;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.75;
  color: #fff9eb;
  text-wrap: balance;
}
.section-about__cta {
  margin-top: auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-item-align: end;
      align-self: end;
  justify-self: end;
}
@media (min-width: 768px) {
  .section-about__title {
    max-width: 162rem;
  }
  .section-about__subtitle {
    font-size: 4rem;
  }
  .section-about__text {
    max-width: 80.3rem;
    font-size: 2rem;
  }
}
@media (min-width: 1200px) {
  .section-about__container {
    padding-bottom: var(--header-vertical-spacing-bottom);
  }
  .section-about__cta {
    margin-right: var(--nav-bullet-spacing);
  }
}

.section-form {
  display: grid;
  position: relative;
  padding: var(--header-vertical-spacing) 0 var(--header-height);
}
.section-form__image {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
.section-form__gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: -webkit-gradient(linear, right top, left top, color-stop(23.08%, #e52a2c), to(rgba(229, 42, 44, 0.1)));
  background-image: linear-gradient(to left, #e52a2c 23.08%, rgba(229, 42, 44, 0.1) 100%);
  opacity: 0.7;
  z-index: 1;
}
.section-form__picture {
  -webkit-filter: blur(3px);
          filter: blur(3px);
}
.section-form__content {
  z-index: 1;
}
.section-form__title {
  text-align: center;
  margin-bottom: 4rem;
  font-weight: 600;
}
.section-form__text {
  font-weight: 400;
  margin-bottom: 4rem;
}
.section-form__button {
  margin-top: 2rem;
}

@media (min-width: 1200px) {
  .section-form {
    height: 100vh;
    overflow: hidden;
  }
  .section-form__image {
    height: 100%;
  }
  .section-form__content {
    display: grid;
    grid-template-rows: 17rem 1fr;
    row-gap: 8rem;
    -ms-flex-line-pack: center;
        align-content: center;
  }
  .section-form__title {
    text-align: left;
    margin-bottom: 2.8rem;
    font-weight: 600;
    color: #1a1a1a;
  }
  .section-form__text-wrapper {
    grid-column: 1/2;
    max-width: 78.5rem;
  }
  .section-form__text {
    font-weight: 500;
    color: #1a1a1a;
  }
  .section-form__form {
    grid-column: 2/3;
  }
  .section-form__button {
    margin-top: 5rem;
  }
}
.section-project-single-hero {
  height: 100svh;
  position: relative;
  padding-bottom: 5.5rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: end;
      justify-content: flex-end;
}
.section-project-single-hero__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -1;
}
.section-project-single-hero__title {
  font-weight: 600;
  font-size: 4rem;
  letter-spacing: 0.01em;
  color: #fff9eb;
}
@media (min-width: 768px) {
  .section-project-single-hero {
    padding-bottom: 6.5rem;
  }
  .section-project-single-hero__title {
    font-size: 5.6rem;
  }
}
@media (min-width: 1200px) {
  .section-project-single-hero {
    padding-bottom: 8rem;
  }
  .section-project-single-hero__title {
    font-size: 9.6rem;
  }
}

:root {
  --nav-bullet-size: clamp(1.4rem, 14px, 1.4rem);
  --nav-bullet-spacing: calc(var(--container-padding) + var(--nav-bullet-size));
}

.page-flexible-layout__bullets {
  display: none;
}
@media (min-width: 1200px) {
  .page-flexible-layout__wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  .page-flexible-layout__sections-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  .page-flexible-layout__sections-container > * {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
  }
  .page-flexible-layout__sections-container > *:nth-child(1) {
    z-index: 9;
  }
  .page-flexible-layout__sections-container > *:nth-child(2) {
    z-index: 8;
  }
  .page-flexible-layout__sections-container > *:nth-child(3) {
    z-index: 7;
  }
  .page-flexible-layout__sections-container > *:nth-child(4) {
    z-index: 6;
  }
  .page-flexible-layout__sections-container > *:nth-child(5) {
    z-index: 5;
  }
  .page-flexible-layout__sections-container > *:nth-child(6) {
    z-index: 4;
  }
  .page-flexible-layout__sections-container > *:nth-child(7) {
    z-index: 3;
  }
  .page-flexible-layout__sections-container > *:nth-child(8) {
    z-index: 2;
  }
  .page-flexible-layout__sections-container > *:nth-child(9) {
    z-index: 1;
  }
  .page-flexible-layout__bullets {
    z-index: 100;
    position: fixed;
    bottom: 0;
    right: var(--container-padding);
    padding-bottom: clamp(2rem, 20px, 2rem);
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    gap: clamp(0.2rem, 2px, 0.2rem);
  }
  .page-flexible-layout__bullet {
    display: block;
    width: var(--nav-bullet-size);
    height: var(--nav-bullet-size);
    border-radius: 50%;
    background-color: #1a1a1a;
    -webkit-transform: scale(0.5);
        -ms-transform: scale(0.5);
            transform: scale(0.5);
  }
  .page-flexible-layout__bullet:hover {
    -webkit-transform: scale(1) !important;
        -ms-transform: scale(1) !important;
            transform: scale(1) !important;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  }
  .page-flexible-layout .footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
  }
}

.page-project-single {
  padding-top: 0;
}
.page-project-single__hero {
  margin-bottom: 2rem;
}
.page-project-single__breadcrumbs {
  margin-bottom: 2.5rem;
}
.page-project-single__title {
  font-size: 2rem;
  padding: 2rem 0rem 1rem 0rem;
  font-weight: 500;
  color: #1a1a1a;
  font-family: "NeverMind Compact", sans-serif;
}
.page-project-single__excerpt {
  margin-bottom: 2.5rem;
  font-size: 1.6rem;
  line-height: 1.5625;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  text-wrap: balance;
}
.page-project-single__meta {
  margin-bottom: 3.5rem;
}
.page-project-single__wysiwyg {
  margin-bottom: 3.5rem;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.5625;
  letter-spacing: 0.01em;
  color: #1a1a1a;
}
.page-project-single__wysiwyg p {
  margin-bottom: 1rem;
  text-wrap: balance;
}
.page-project-single__wysiwyg h1,
.page-project-single__wysiwyg h2,
.page-project-single__wysiwyg h3,
.page-project-single__wysiwyg h4,
.page-project-single__wysiwyg h5,
.page-project-single__wysiwyg h6 {
  margin-bottom: 1rem;
  font-weight: 500;
  text-wrap: balance;
}
.page-project-single__wysiwyg h1 {
  font-size: 1.714em;
}
.page-project-single__wysiwyg h2 {
  font-size: 1.428em;
}
.page-project-single__wysiwyg h3 {
  font-size: 1.285em;
}
.page-project-single__wysiwyg h4 {
  font-size: 1.142em;
}
.page-project-single__wysiwyg h5 {
  font-size: 1em;
}
.page-project-single__wysiwyg h6 {
  font-size: 0.857em;
}
.page-project-single__wysiwyg ul {
  list-style: none;
  padding-left: 2rem;
}
.page-project-single__wysiwyg ol {
  list-style: decimal;
  padding-left: 3rem;
}
.page-project-single__wysiwyg li {
  margin-bottom: 0.5rem;
  text-wrap: balance;
  position: relative;
}
.page-project-single__wysiwyg li::before {
  content: "";
  position: absolute;
  left: -1.5rem;
  top: calc(50% - 2.5px);
  width: 5px;
  height: 5px;
  background-color: #1a1a1a;
  border-radius: 50%;
}
.page-project-single__wysiwyg a {
  color: #1a1a1a;
  text-decoration: underline;
  text-underline-offset: 0.1em;
  text-decoration-thickness: 0.05em;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  font-weight: 600;
}
.page-project-single__wysiwyg a:hover {
  text-decoration-color: transparent;
}
@media (min-width: 768px) {
  .page-project-single__hero {
    margin-bottom: 4rem;
  }
  .page-project-single__breadcrumbs {
    margin-bottom: 3.5rem;
  }
  .page-project-single__content {
    display: grid;
    grid-template-columns: 1fr 20rem;
    -webkit-column-gap: 3.5rem;
       -moz-column-gap: 3.5rem;
            column-gap: 3.5rem;
    grid-auto-rows: -webkit-max-content;
    grid-auto-rows: max-content;
  }
  .page-project-single__title {
    font-size: 3.5rem;
  }
  .page-project-single__excerpt {
    margin-bottom: 3.5rem;
  }
  .page-project-single__meta {
    margin-bottom: 4.5rem;
    grid-column: 2;
    grid-row: 1/4;
  }
  .page-project-single__gallery-slide {
    aspect-ratio: 9/16;
    max-height: 100svh;
    overflow: hidden;
  }
}
@media (min-width: 1200px) {
  .page-project-single__hero {
    margin-bottom: 6rem;
  }
  .page-project-single__content {
    grid-template-columns: 1fr 30rem;
    -webkit-column-gap: 3.5rem;
       -moz-column-gap: 3.5rem;
            column-gap: 3.5rem;
  }
  .page-project-single__title {
    font-size: 6.4rem;
    max-width: 120rem;
  }
  .page-project-single__excerpt {
    font-size: 2.4rem;
    max-width: 120rem;
  }
  .page-project-single__wysiwyg {
    max-width: 120rem;
    font-size: 2.4rem;
  }
  .page-project-single__wysiwyg ul {
    margin-bottom: 3.5rem;
  }
}

.page-project-archive {
  padding-top: 0;
}
.page-project-archive .header {
  position: relative;
}
.page-project-archive__header {
  margin-bottom: 4rem;
}
.page-project-archive__breadcrumbs {
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: solid 1px #1a1a1a;
}
.page-project-archive__title {
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  text-transform: uppercase;
  font-weight: 600;
}
.page-project-archive__grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 4.5rem;
}
@media (min-width: 768px) {
  .page-project-archive__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 768px) {
  .page-project-archive__header {
    margin-bottom: 6rem;
  }
  .page-project-archive__breadcrumbs {
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
  }
  .page-project-archive__title {
    font-size: 4.8rem;
  }
  .page-project-archive__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1200px) {
  .page-project-archive__title {
    font-size: 9.6rem;
  }
  .page-project-archive__breadcrumbs {
    padding-bottom: 2rem;
    margin-bottom: 2rem;
  }
  .page-project-archive__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 7rem;
  }
  .page-project-archive__categories {
    height: auto;
  }
  .page-project-archive__categories .section-projects-categories__wrapper {
    margin-bottom: 4rem;
  }
}

.page-content__main {
  padding-top: calc(var(--header-height) + 5rem);
  margin-bottom: 7.5rem;
  margin-inline: auto;
  max-width: 100rem;
  text-wrap: balance;
}
@media (min-width: 768px) {
  .page-content__main {
    padding-top: calc(var(--header-height) + 7.5rem);
    margin-bottom: 10rem;
  }
}

.page-404__main {
  height: 100vh;
  display: grid;
  -ms-flex-line-pack: center;
      align-content: center;
}
.page-404__container {
  padding-left: 1rem;
  padding-right: 1rem;
}
.page-404__title {
  font-weight: 500;
  font-family: "NeverMind Compact", sans-serif;
  text-align: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
  color: #000000;
  font-size: 12.8rem;
  line-height: 9.2rem;
}
.page-404__button-link {
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -ms-flex-pack: center;
      justify-content: center;
  margin-bottom: 1rem;
  -ms-flex-align: center;
      align-items: center;
}
.page-404__button-text {
  text-transform: uppercase;
  font-family: "NeverMind Compact", sans-serif;
  font-weight: 500;
  line-height: 4rem;
  color: #000000;
  font-size: 3.6rem;
}
.page-404__button-icon {
  width: 2.3rem;
  height: 2.3rem;
  display: block;
}
.page-404__subtitle {
  font-weight: 500;
  font-family: "NeverMind Compact", sans-serif;
  text-align: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
  color: #000000;
  font-size: 9.6rem;
  margin-bottom: 1rem;
}
.page-404__aside {
  padding-left: 1rem;
}
.page-404__socials-list {
  -ms-flex-direction: column;
      flex-direction: column;
}
@media (min-width: 768px) {
  .page-404__main {
    height: unset;
  }
  .page-404__title {
    font-size: 21.4rem;
    line-height: 100%;
  }
  .page-404__button-text {
    font-size: 5rem;
  }
  .page-404__button-icon {
    width: 3.1rem;
    height: 3.1rem;
  }
  .page-404__button-icon .icon {
    width: 100%;
  }
  .page-404__subtitle {
    font-size: 19.8rem;
    line-height: 100%;
  }
}
@media (min-width: 1200px) {
  .page-404__main {
    grid-template-columns: 5rem 1fr;
    padding-left: 4rem;
    padding-right: 4rem;
    -webkit-column-gap: 3.5rem;
       -moz-column-gap: 3.5rem;
            column-gap: 3.5rem;
  }
  .page-404__container {
    grid-column: 2/3;
  }
  .page-404__title {
    text-align: start;
    padding-right: 1rem;
    font-size: 30rem;
  }
  .page-404__button-link {
    padding-top: 1rem;
    padding-left: 3rem;
    padding-right: 3rem;
    cursor: pointer;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    justify-self: center;
  }
  .page-404__button-text {
    font-size: 6.4rem;
  }
  .page-404__subtitle {
    text-align: start;
    font-size: 30rem;
    padding: 1rem 0rem 1rem 3.5rem;
    line-height: unset;
  }
  .page-404__aside {
    grid-column: 1/2;
    grid-row: 1/2;
    align-self: end;
    padding-left: 0;
  }
}

.page-template-page-thank-you {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  min-height: 100vh;
}

.page-thank-you__main {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-positive: 1;
      flex-grow: 1;
}
.page-thank-you__title {
  font-weight: 500;
  font-family: "NeverMind Compact", sans-serif;
  text-align: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
  color: #000000;
  font-size: 7rem;
}
.page-thank-you__text {
  font-weight: 500;
  font-family: "NeverMind Compact", sans-serif;
  text-align: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
  color: #000000;
  font-size: 3rem;
  color: #1a1a1a;
}
@media (min-width: 768px) {
  .page-thank-you__title {
    font-size: 10rem;
  }
}