@import url('https://fonts.googleapis.com/css2?family=Cantarell:ital,wght@0,400;0,700;1,400;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap');

:root {
  --bc-1: #0077b6;
  --bc-2: #00a8e8; 
  --bc-3: #48cae4; 
  --bc-4: #90e0ef; 
  --bc-5: #caf0f8; 

  --cb-1: #003d46;  
  --cb-2: #006f74;  
  --cb-3: #3a6f66;  
  --cb-4: #a39e6a;  
  --cb-5: #d8d8d0;  

  --gr-1: radial-gradient(circle, var(--bc-1), var(--bc-2));
  --gr-2: radial-gradient(circle, var(--bc-3), var(--bc-1));
  --gr-3: radial-gradient(circle, var(--bc-1), var(--bc-5));  
  --gr-4: linear-gradient(to right, var(--bc-1), var(--bc-3));
  --gr-5: radial-gradient(circle, var(--bc-2), var(--bc-4));
}

*{
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body{
  background: var(--gr-5);
  direction: ltr;
  font-family: 'Cantarell', sans-serif !important;
  font-size: clamp(14px, 4vw, 17px);
  margin: 0;
  padding: 0;
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
p{
  padding: 0;
  margin: 0;
}

p, li{
  padding: 5px 0;
  line-height: 2.5;
}

li{
  margin: 0 5px;
}

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

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

ul{
  margin: 0;
  padding: 0;
}

.box-container{
  width: auto;
  padding-right: 19px;
  padding-left: 19px;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (min-width: 480px) {
  .box-container{
  max-width: 450px;
  }
}
@media screen and (min-width: 575px){
  .box-container{
    max-width: 540px;
  }
}
@media screen and (min-width: 768px) {
  .box-container{
  max-width: 730px;
  }
}
@media screen and (min-width: 992px) {
  .box-container{
    max-width: 960px;
  }
}

@media screen and (min-width: 1200px){
  .box-container{
    max-width: 1170px;
    }
}

@media (min-width: 1400px){
  .box-container{
    max-width: 1274px;
  }
}
.col-blok {
  display: flex;
  gap:33px;
  flex-direction: column;
}

.page-privacy__block{
  padding: 51px 0;
  overflow: hidden;
  width: 100%;
}

.politic-title{
  text-transform: uppercase;
  text-align: center;
  color: #fff;
  margin-bottom: 29px;
  font-size: clamp(30px, 4vw, 50px);
}

.content-politics{
  opacity: 0.8;
  font-size: clamp(16px, 4vw, 18px);
  color: #fff;
  text-align: justify;
}

.page-privacy__block a{
  transition: 0.3s ease;
  color: #fff;
}

.page-privacy__block a:hover{
  color: #fff;
  opacity: 0.5;
}

.header-wrapper{
  position: relative;
  width: 100%;
  background-position: center;
  background-size: cover;
  min-height: 100vh;
}

.header-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(visualtreasure/background/bg-all-0684aa7508cf0b.jpg);
  background-attachment: fixed;
  background-position: center;
  filter: brightness(0.5);
  background-size: cover;
  z-index: -1;
}

.header-back{
  padding: 19px 0;
}

.fixed-nav {
  background-color: #fff;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99;
  transition: top 0.3s ease;
}

.fixed-nav .logo__title h2, .fixed-nav .navigation__link{
  color: #040807 !important;
}

.fixed-nav .navigation__link::after{
  background-color: #040807 !important;
}

.header{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 36px;
}

.logo {
  transition: 0.5s ease;
  display: flex;
  align-items: center;
  cursor: pointer;
  gap: 23px;
}

.logo:hover{
  transform: scale(1.05);
}

.logo__image img {
  max-height: 50px;
  object-fit: contain;
  width: 45px;
}

.logo a {
  color: #fff;
  display: flex;
  align-items: center;
  gap: 19px;
  transition: color 0.3s ease;
}

.logo__title h2 {
  font-size: 17px;
  margin: 0;
}

.navigation{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 29px;
}

.navigation__link {
  position: relative;
  transition: color 0.5s ease;
  color: #fff;
  font-size: clamp(16px, 4vw, 18px);
  text-decoration: none;
}

.navigation__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px; 
  width: 100%;
  height: 2px; 
  background-color: #ffffffb3;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
}

.navigation__link:hover::after {
  transform: scaleX(1);
}

.btn {
  display: inline-block;
  padding: 5px 29px;
  font-size: clamp(16px, 4vw, 18px);  
  font-weight: bold;
  text-transform: uppercase;
  border: none;
  border-radius: 13px;
  cursor: pointer;
  transition: 0.5s ease;
}

.btn-project-1 {
  background-color: var(--cb-1);
  color: #fff;
}

.btn-project-1:hover {
  opacity: 0.5;
}

.btn-project-2 {
  background-color: var(--cb-2);
  color: #fff;
}

.btn-project-2:hover {
  transform: rotate(5deg);
}

.btn-project-3 {
  background-color: var(--cb-3);
  color: #fff;
}

.btn-project-3:hover {
  box-shadow: 0px 0px 15px rgba(72, 202, 228, 0.8);
}

.btn-project-4 {
  background-color: var(--cb-4);
  color: #040807;
}

.btn-project-4:hover {
  transform: scale(1.2);
}

.btn-project-5 {
  background-color: var(--cb-5);
  color: #040807;
}

.btn-project-5:hover {
  filter: brightness(1.2);
}

.header-hero{
  text-align: center;
  min-height: 80vh;
  padding: 97px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 19px;
}

.header-hero h1{
  font-size: clamp(30px, 4vw, 50px);
  color: #fff;
}

.header-hero p{
  font-size: clamp(18px, 4vw, 22px);
  color: #fff;
  opacity: 0.8;
}

.step-game{
  transform: translateY(-30%);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 19px;
}

.step-game__card{
  transition: 0.3s ease;
  box-shadow: rgba(0, 0, 0, 0.35) 4px 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background-color: #fff;
  border-radius: 19px;
  padding: 19px;
  padding-top: 0;
}

.step-game__card:hover img{
  transform: translateY(-40%) scale(1.1);
}

.step-game__card img{
  transition: 0.3s ease;
  transform: translateY(-40%);
  object-fit: contain;
  height: 51px;
  width: 51px;
}

.step-game__card p{
  padding: 0;
  font-size: clamp(14px, 4vw, 14px);
  color: #040807;
}

.aboutus{
  display: flex;
  justify-content: space-between;
  gap: 51px;
  flex-direction: row-reverse;
  padding: 51px 0;
}

.aboutus_text{
  flex: 1;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: start;
  gap: 29px;
}

.aboutus_text h2{
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.aboutus__subtitle{
  opacity: 0.8;
  font-size: clamp(14px, 4vw, 16px);
  color: #fff;
}

.aboutus__img{
  flex: 1;
  position: relative;
}

.aboutus__img img{
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  filter: brightness(0.9);
  border-radius: 29px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.aboutus__img::before{
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  transform: translateY(38%);
  height: 180px;
  background-repeat: no-repeat;
  background-image: url(visualtreasure/tematik/fish-0684aa7508d3bb.svg);
  background-size: contain;
  background-position: right;
  z-index: 1;
}

.game{
  display: none;
  flex-direction: column;
  gap: 51px;
  padding: 51px 0;
}

.game h2{
  text-align: center;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.game-block{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 29px;
}

.game-card{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 29px;
  border-radius: 29px;
  padding: 29px;
  position: relative;
  width: 100%;
  background-position: center;
  background-size: cover;
}

.game-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-position: center;
  background-attachment: fixed;
  background-image: url(visualtreasure/background/bg-dark-0684aa7508cc50.jpg);
  border-radius: 29px;
  filter: brightness(0.5);
  background-size: cover;
  z-index: -1;
}

.game-card__img{
  height: 180px;
  width: 180px;
}

.game-card__img img{
  border: 2px solid var(--bc-5);
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  border-radius: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.game-card__text{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 19px;
}

.game-card__text h5{
  color: #fff;
  font-size: clamp(18px, 4vw, 22px);
}

.catalog-container {
  display: none;
  flex-direction: column;
  gap: 51px;
  padding: 51px 0;
}

.catalog-container h2 {
  text-align: center;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
}

.catalog-item {
  position: relative;
  overflow: hidden;
  border-radius: 29px;
}

.item-image img {
  border-radius: 29px;
  width: 100%;
  height: 100%;
  min-height: 316px;
  object-fit: cover;
  display: block;
}

.item-details {
  text-align: center;
  margin: 19px;
  border-radius: 29px;
  position: absolute;
  bottom: 0;
  left: 0;
  background: var(--gr-5);
  color: #fff;
  padding: 13px;
  transition: transform 0.5s ease;
  transform: translateY(0);
  overflow: hidden; 
}

.item-details a h5 {
  transition: 0.3s ease;
  margin: 0;
  font-size: clamp(16px, 4vw, 18px);
}

.item-details a h5:hover {
  opacity: 0.5;
}

.item-details p {
  display: -webkit-box;      
  -webkit-box-orient: vertical; 
  overflow: hidden;           
  text-overflow: ellipsis;    
  -webkit-line-clamp: 3;     
  line-clamp: 3; 
  color: #fff;
  padding: 0;
  font-size: clamp(14px, 4vw, 14px);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.3s ease, max-height 0.5s ease, margin 0.3s ease; 
}

.item-details:hover p {
  margin: 13px 0 0;
  opacity: 0.8;
  max-height: 160px; 
}

.stats-back{
  margin: 51px 0;
  padding: 97px 0;
  position: relative;
  width: 100%;
  background-position: center;
  background-size: cover;
}

.stats-back::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(visualtreasure/background/bg-all-1684aa7508cf78.jpg);
  background-position: center;
  filter: brightness(0.5);
  background-size: cover;
  z-index: -1;
}

.stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 29px;
}

.stats-card{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 5px;
}

.stats-card h5{
  opacity: 0.8;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.stats-card p{
  padding: 0;
  color: #fff;
  font-size: clamp(16px, 4vw, 18px);
}

.benefit{
  position: relative;
  display: flex;
  justify-content: space-between;
  gap: 51px;
  flex-direction: row-reverse;
  padding: 51px 0;
}

.benefit-img{
  flex: 1;
  position: sticky;
  height: 100%;
  top: 29%;
}

.benefit-img img{
  width: 100%;
  height: 100%;
  max-height: 50vh;
  object-fit: contain;
}

.benefit-box{
  display: flex;
  flex-direction: column;
  gap: 51px;
  flex: 2;
}

.benefit-card{
  transition: 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: start;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  background-color: #fff;
  border-radius: 29px;
  padding: 29px;
  padding-top: 0;
}

.benefit-card:hover img{
  transform: translateY(-40%) scale(1.1);
}

.benefit-card img{
  transition: 0.3s ease;
  transform: translateY(-40%);
  width: 51px;
  height: 51px;
  object-fit: contain;
}

.benefit-card h5{
  color: #040807;
  font-size: clamp(16px, 4vw, 18px);
}

.workers{
  display: flex;
  flex-direction: column;
  gap: 51px;
  padding: 51px 0;
}

.workers h2{
  text-align: center;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.workers-box{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 29px;
}

.workers-card {
  position: relative;
  clip-path: polygon(25% 5%, 75% 5%, 100% 50%, 75% 95%, 25% 95%, 0% 50%);
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.workers-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

.workers-text {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6); 
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  opacity: 0;
  transition: opacity 0.3s ease;
  text-align: center;
  padding: 13px;
}

.workers-text h5 {
  color: #fff;
  font-size: clamp(18px, 4vw, 22px);
}

.workers-text p {
  opacity: 0.8;
  padding: 0;
  color: #fff;
  font-size: clamp(14px, 4vw, 16px);
}

.workers-card:hover img {
  opacity: 0.5;
}

.workers-card:hover .workers-text {
  opacity: 1;
}

.comments-back{
  margin: 51px 0;
  position: relative;
  width: 100%;
  background-position: center;
  background-size: cover;
}

.comments-back::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(visualtreasure/background/bg-all-2684aa7508cfd2.jpg);
  background-position: center;
  filter: brightness(0.5);
  background-size: cover;
  z-index: -1;
}

.comments{
  display: flex;
  flex-direction: column;
  gap: 51px;
  padding: 51px 0;
}

.comments h2{
  text-align: center;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.comments-box{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
}

.comments-card{
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  display: flex;
  align-items: start;
  gap: 29px;
  flex-direction: column;
  background-color: #fff;
  border-radius: 29px;
  padding: 29px;
}

.rating-box{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 5px;
}

.rating-box svg{
  width: 23px;
  height: 23px;
  fill: gold;
}

.comments-card h5{
  font-weight: normal;
  color: #040807;
  font-size: clamp(14px, 4vw, 16px);
}

.form-block{
  display: flex;
  align-items: center;
  gap: 51px;
  flex-direction: row-reverse;
  padding: 51px 0;  
}

.form-img{
  flex: 1;
}

.form-block img{
  width: 100%;
  height: 100%;
  max-height: 60vh;
  object-fit: contain;
}

.form-box{
  flex: 2;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  border-radius: 29px;
  background-color: #fff;
  padding: 29px;
  display: flex;
  flex-direction: column;
  gap: 29px;
}

.title-box h2{
  text-align: center;
  text-transform: uppercase;
  color: #040807;  
  font-size: clamp(22px, 4vw, 30px);
}

.osn-form {
  position: relative;
  display: flex;
  flex-direction: column;
}

.input-container {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.input-container label{
  color: #040807;
}

.input-container .input-input_elementcomponent, .input-container .textarea-input_elementcomponent {
  outline: none;
  margin: 5px 0;
}

.input-container .input-input_elementcomponent {
  transition: 0.3s ease;
  border-radius: 29px;
  border: none;
  color: rgb(161, 161, 161);
  box-shadow: inset 6px 6px 8px rgba(97, 97, 97, 0.075), 6px 6px 6px rgba(255, 255, 255, 0.781);
  background-color: #f7f7f7;
  padding: 19px; 
  font-size: 16px; 
  line-height: 20px; 
}

.input-container .textarea-input_elementcomponent {
  transition: 0.3s ease;
  border-radius: 29px;
  border: none;
  color: rgb(161, 161, 161);
  box-shadow: inset 6px 6px 8px rgba(97, 97, 97, 0.075), 6px 6px 6px rgba(255, 255, 255, 0.781);
  background-color: #f7f7f7;
  padding: 19px; 
  font-size: 16px; 
  line-height: 20px; 
  resize: vertical;
  min-height: 36px;
  max-height: 116px;
}

.input-container .input-input_elementcomponent:focus, .input-container .textarea-input_elementcomponent:focus{
  box-shadow: -3px -3px 5px white, 3px 3px 5px rgba(209, 209, 209, 0.705);
}

.input-container .input-input_elementcomponent::placeholder, .input-container .textarea-input_elementcomponent::placeholder{
  color: rgb(161, 161, 161);
}

.check{
  transition: 0.3s ease;
  color: #040807;
}

.check:hover{
  opacity: 0.5;
  color: #040807;
}

.form-check {
  color: #040807;
  display: flex;
  align-items: center;
  gap: 13px;
  justify-content: flex-start;
  padding: 19px 0;
}

.form-check .form-check-input{
  margin: 0;
}

.osn-form button{
  margin: 0 auto;
}

.ui-checkbox {
  --primary-color: #1677ff;
  --secondary-color: #fff;
  --primary-hover-color: #4096ff;
  --checkbox-diameter: 20px;
  --checkbox-border-radius: 5px;
  --checkbox-border-color: #d9d9d9;
  --checkbox-border-width: 1px;
  --checkbox-border-style: solid;
  --checkmark-size: 1.2;
}

.ui-checkbox,
.ui-checkbox *,
.ui-checkbox *::before,
.ui-checkbox *::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.ui-checkbox {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: var(--checkbox-diameter);
  height: var(--checkbox-diameter);
  border-radius: var(--checkbox-border-radius);
  background: var(--secondary-color);
  border: var(--checkbox-border-width) var(--checkbox-border-style) var(--checkbox-border-color);
  -webkit-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  cursor: pointer;
  position: relative;
}

.ui-checkbox::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-box-shadow: 0 0 0 calc(var(--checkbox-diameter) / 2.5) var(--primary-color);
  box-shadow: 0 0 0 calc(var(--checkbox-diameter) / 2.5) var(--primary-color);
  border-radius: inherit;
  opacity: 0;
  -webkit-transition: all 0.5s cubic-bezier(0.12, 0.4, 0.29, 1.46);
  -o-transition: all 0.5s cubic-bezier(0.12, 0.4, 0.29, 1.46);
  transition: all 0.5s cubic-bezier(0.12, 0.4, 0.29, 1.46);
}

.ui-checkbox::before {
  top: 40%;
  left: 50%;
  content: "";
  position: absolute;
  width: 4px;
  height: 7px;
  border-right: 2px solid var(--secondary-color);
  border-bottom: 2px solid var(--secondary-color);
  -webkit-transform: translate(-50%, -50%) rotate(45deg) scale(0);
  -ms-transform: translate(-50%, -50%) rotate(45deg) scale(0);
  transform: translate(-50%, -50%) rotate(45deg) scale(0);
  opacity: 0;
  -webkit-transition: all 0.1s cubic-bezier(0.71, -0.46, 0.88, 0.6),opacity 0.1s;
  -o-transition: all 0.1s cubic-bezier(0.71, -0.46, 0.88, 0.6),opacity 0.1s;
  transition: all 0.1s cubic-bezier(0.71, -0.46, 0.88, 0.6),opacity 0.1s;
}

.ui-checkbox:hover {
  border-color: var(--primary-color);
}

.ui-checkbox:checked {
  background: var(--primary-color);
  border-color: transparent;
}

.ui-checkbox:checked::before {
  opacity: 1;
  -webkit-transform: translate(-50%, -50%) rotate(45deg) scale(var(--checkmark-size));
  -ms-transform: translate(-50%, -50%) rotate(45deg) scale(var(--checkmark-size));
  transform: translate(-50%, -50%) rotate(45deg) scale(var(--checkmark-size));
  -webkit-transition: all 0.2s cubic-bezier(0.12, 0.4, 0.29, 1.46) 0.1s;
  -o-transition: all 0.2s cubic-bezier(0.12, 0.4, 0.29, 1.46) 0.1s;
  transition: all 0.2s cubic-bezier(0.12, 0.4, 0.29, 1.46) 0.1s;
}

.ui-checkbox:active:not(:checked)::after {
  -webkit-transition: none;
  -o-transition: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  transition: none;
  opacity: 1;
}

.site-footer {
  position: relative;
  width: 100%;
  background-position: center;
  background-size: cover;
}

.site-footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(visualtreasure/background/bg-all-3684aa7508d02c.jpg);
  background-position: center;
  filter: brightness(0.5);
  background-size: cover;
  z-index: -1;
}

.footer-section {
  display: flex;
  flex-direction: column;
}

.footer-header {
  text-align: center;
  padding: 51px 0;
  display: flex;
  flex-direction: column;
  gap: 29px;
}

.footer-disclaimer {
  border: 2px solid var(--cb-5);
  padding: 29px;
  border-radius: 13px;
  margin-inline: auto;
  text-align: center;
  position: relative;
}

.disclaimer-heading {
  text-transform: uppercase;
  font-weight: bold;
  font-size: clamp(22px, 4vw, 30px);
  color: #fff;
  margin-bottom: 29px;
  position: relative;
  width: max-content;
  margin-inline: auto;
}

.disclaimer-heading::after {
  content: "";
  position: absolute;
  width: 0;
  height: 2;
  background: linear-gradient(270deg, var(--cb-5), var(--bc-5));
  inset-inline-start: 0;
  inset-block-end: 0;
  border-radius: 13px;
  transition: 0.5s ease-in-out;
}

.disclaimer-text {
  padding: 0;
  font-size: clamp(16px, 4vw, 18px);
  color: #fff;
  opacity: 0.7;
}

.footer-disclaimer::after,
.footer-disclaimer::before {
  content: "";
  position: absolute;
  background-image: conic-gradient(from var(--angle), transparent 70%, var(--cb-5));
  width: 100%;
  height: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
  padding: 2;
  box-sizing: content-box;
  border-radius: inherit;
  animation: move 3s linear infinite;
}

.footer-disclaimer::before {
  filter: blur(10px);
  opacity: 0.7;
}

.footer-disclaimer:hover .disclaimer-heading::after {
  width: 100%;
}

@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

@keyframes move {
  from {
    --angle: 0deg;
  }
  to {
    --angle: 360deg;
  }
}

.footer-links ul {
  padding: 0;
  list-style: none;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  text-align: center;
  justify-content: center;
  flex-direction: row;
  gap: 19px;
}

.footer-links ul li a {
  font-size: clamp(16px, 4vw, 18px);
  transition: 0.3s ease;
  text-decoration: none;
  color: #fff;
}

.footer-links ul li a:hover {
  color: #fff;
  opacity: 0.5;
}

.footer-bottom {
  border-top: 0.1px solid #fff;
  padding: 29px 0;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 29px;
}

.footer-bottom p {
  padding: 0;
  color: #fff;
  font-size: clamp(16px, 4vw, 18px);
}

.footer-bottom img {
  max-width: 51px;
}

.article {
  padding: 51px 0;
  display: flex;
  flex-direction: column;
  gap: 51px;
  position: relative;
}

.article h1 {
  text-align: center;
  color: #fff;
  font-size: clamp(30px, 4vw, 50px);
}

.article-wrapper {
  display: flex;
  flex-direction: row;
  gap: 36px;
  position: relative;
}

.article-image {
  position: relative;
  flex: 1;
}

.article-image img {
  object-fit: contain;
  box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px, rgba(10, 37, 64, 0.35) 0px -2px 6px 0px inset;  width: 100%;
  border-radius: 19px;
  position: sticky;
  top: 29%;
}

.article-text {
  color: #fff;
  flex: 2;
  font-size: clamp(16px, 4vw, 18px);
}

.article-text ul {
  list-style: inside;
}

.game-frame {
  padding: 36px 0;
  width: 100%;
  height: 554px;
}

.game-frame iframe {
  border: none;
  width: 100%;
  height: 100%;
}

.contact-section {
  direction: initial;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;  
  border-radius: 29px;
  background-color: #fff;
  padding: 29px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: 51px;
  margin: 51px 0;
}

.contact-form {
  flex: 1;
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.contact-form__title {
  margin-bottom: 51px;
}

.contact-form__title h2 {
  font-size: clamp(22px, 4vw, 30px);
  color: #040807;
}

.contact-form__inputs .contact-form__input, 
.contact-form__inputs .contact-form__textarea {
  outline: none;
  margin: 5px 0;
}

.contact-form__row {
  display: flex;
  flex-direction: row;
  gap: 29px;
  align-items: center;
  justify-content: space-between;
}

.contact-form__input {
  width: 100%;
  transition: 0.3s ease;
  border-radius: 29px;
  border: none;
  color: rgb(161, 161, 161);
  box-shadow: inset 6px 6px 8px rgba(97, 97, 97, 0.075), 6px 6px 6px rgba(255, 255, 255, 0.781);
  background-color: #f7f7f7;
  padding: 19px; 
  font-size: 16px; 
  line-height: 20px; 
}

.contact-form__textarea {
  width: 100%;
  transition: 0.3s ease;
  border-radius: 29px;
  border: none;
  color: rgb(161, 161, 161);
  box-shadow: inset 6px 6px 8px rgba(97, 97, 97, 0.075), 6px 6px 6px rgba(255, 255, 255, 0.781);
  background-color: #f7f7f7;
  padding: 19px; 
  font-size: 16px; 
  line-height: 20px; 
  resize: vertical;
  min-height: 36px;
  max-height: 116px;
}

.contact-form__input::placeholder, 
.contact-form__textarea::placeholder {
  color: rgb(161, 161, 161);
}

.contact-form__input:focus, 
.contact-form__textarea:focus {
  box-shadow: -3px -3px 5px white, 3px 3px 5px rgba(209, 209, 209, 0.705);
}

.contact-form button {
  margin: 0 auto;
  margin-top: 29px;
}

.contacts {
  flex: 1;
  border-left: 1px solid #040807;
  padding-left: 51px;
}

.contacts h2 {
  margin-bottom: 51px;
  font-size: clamp(22px, 4vw, 30px);
  color: #040807;
}

.contacts__list {
  display: flex;
  flex-direction: column;
  gap: 29px;
}

.contacts__item {
  display: flex;
  gap: 19px;
  align-items: flex-start;
  margin-bottom: 25px;
}

.contacts__item svg{
  flex-shrink: 0;
  width: 19px;
  height: 19px;
  color: var(--bc-1);
}

.contacts__item a{
  color: inherit;
  transition: color 0.3s ease;
}

.contacts__item a h5 {
  margin: 0;
  color: var(--bc-1);
  font-weight: 600;
  transition: color 0.3s ease;
}

.contacts__item a h5:hover {
  color: var(--bc-2);
}

.contacts__item h5 {
  margin: 0 0 5px 0;
  color: var(--bc-1);
  font-weight: 600;
}

.contacts__item p {
  margin: 2px 0;
  color: #666;
  font-size: 0.9em;
  line-height: 1.4;
}

.contacts__item div {
  flex: 1;
}

.nav-toggle {
  cursor: pointer;
  display: none;
  width: 30px;
  height: 30px;
  position: relative;
  z-index: 100;
}

.nav-toggle span {
  width: 23px;
  height: 2px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  transition: all 0.5s;
}

.fixed-nav .nav-toggle span{
  background-color: #040807 !important;
}

.nav-toggle span:nth-of-type(2) {
  top: calc(50% - 7px);
}

.nav-toggle span:nth-of-type(3) {
  top: calc(50% + 7px);
}

.nav-toggle.is-active span:nth-of-type(1) {
  display: none;
}

.nav-toggle.is-active span:nth-of-type(2) {
  background-color: #040807 !important;
  top: 50%;
  transform: translate(-50%, 0%) rotate(45deg);
}

.nav-toggle.is-active span:nth-of-type(3) {
  background-color: #040807 !important;
  top: 50%;
  transform: translate(-50%, 0%) rotate(-45deg);
}

.nav-panel {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  padding: 44px 0;
  z-index: 99;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  background: #fff;
  transform: translateY(-110%);
  transition: transform 0.5s;
}

.nav-panel.is-open {
  transform: translateY(0);
}

.nav-panel nav {
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
}

.nav-panel ul {
  display: flex;
  flex-direction: column;
  gap: 13px;
  text-align: center;
  padding: 0;
}

.nav-panel li {
  list-style-type: none;
}

.nav-panel li a {
  letter-spacing: 2px;
  text-align: center;
  font-size: clamp(18px, 4vw, 23px);
  color: #040807;
}

.nav-panel li a:hover {
  opacity: 0.6;
  color: #040807;
}

@media (max-width: 1199px){
  
}

@media (max-width: 991px) {
  .step-game{
    gap: 36px;
    padding: 51px 0;
    transform: none;
    grid-template-columns: repeat(2, 1fr);
  }

  .navigation{
    display: none;
  }

  .nav-toggle{
    display: block;
  }

  .game-block{
    grid-template-columns: repeat(1, 1fr);
  }

  .workers-box{
    grid-template-columns: repeat(2, 1fr);
  }

  .form-block{
    flex-direction: column;
  }

  .catalog-grid{
    grid-template-columns: repeat(2, 1fr);
  }

  .article-wrapper{
    flex-direction: column;
  }

  .article-image img{
    position: relative;
    top: 0;
    max-width: 554px;
    margin: 0 auto;
  }

  .contact-section{
    flex-direction: column;
  }

  .contacts {
    border-top: 0.1px solid #040807;
    padding-top: 51px;
    border-left: none;
    padding-left: 0;
  }
}

@media (max-width: 767px) {
  .article-image img{
    max-width: 100%;
  }

  .contact-form__row{
    flex-direction: column;
    gap: 0;
  }
  
  .aboutus{
    flex-direction: column;
  }

  .stats{
    grid-template-columns: repeat(1, 1fr);
  }

  .catalog-grid{
    grid-template-columns: repeat(1, 1fr);
  }

  .benefit{
    flex-direction: column;
  }

  .benefit-img{
    position: relative;
    top: 0;
  }

  .comments-box{
    grid-template-columns: repeat(1, 1fr);
  }

  .step-game{
    grid-template-columns: repeat(1, 1fr);
  }

  .aboutus__img::before{
    transform: translateY(20%);
  }

  .game-card::before{
    background-image: unset;
    background-attachment: unset;
  }

  .game-card:nth-child(1)::before{
    background-image: url(visualtreasure/background/bg-dark-0684aa7508cc50.jpg);
  }

  .game-card:nth-child(2)::before{
    background-image: url(visualtreasure/background/bg-dark-2684aa7508ccb3.jpg);
  }

  .game-card:nth-child(3)::before{
    background-image: url(visualtreasure/background/bg-dark-3684aa7508cd14.jpg);
  }

  .game-card:nth-child(4)::before{
    background-image: url(visualtreasure/background/bg-dark-4684aa7508cd5d.jpg);
  }

  .game-card:nth-child(5)::before{
    background-image: url(visualtreasure/background/bg-dark-5684aa7508cddc.jpg);
  }

  .game-card:nth-child(6)::before{
    background-image: url(visualtreasure/background/bg-dark-6684aa7508ce37.jpg);
  }

  .workers-box{
    grid-template-columns: repeat(1, 1fr);
  }

  .workers-card img{
    min-height: 238px;
  }

  .workers-text {
    opacity: 1;
  }
}

@media (max-width: 576px){
  .aboutus__img::before{
    height: 97px;
  }
}

